头像

Linux指定nologin用户执行命令

发布时间:2024-09-25 02:15:50

发布作者:admin

227

在linux中运行的网站,我们一般分配一个www用户给网站应用程序。但这个用户正常情况是不可以登陆的,这时候如果重启一些服务需要求只能使用www用户执行。此时切换到www用户时,会出错。

方法一

修改/etc/passwd文件 nologin改为bin/bash,这样www用户可以登录服务器,但这样操作比较危险。

方法二

可以通过以下办法使用www用户执行命令。

1su -s /bin/bash -c "command" www
su -s 是指定shell,这里www用户是nologin用户,是没有默认的shell的,这里指定使用/bin/bash, -c 后面接需要运行的命令, 后面www是指定使用www用户来执行命令。

方法三

sudo -u www command
如果以上都不行,新系统中只能把www设置成不能通过ssh登陆,把此用户设置成可运行shell命令:打开www的shell 。

www:x:1001:1001::/home/www:/bin/bash
然后设置 sshd 在 /etc/ssh/sshd_config  最后加入 DenyUsers 代表禁止www使用ssh。

DenyUsers www
这样www 用户永远不能通过ssh登陆。


相关文章:
  1. RHEL6 Postfix+Dovecot邮件系统配置指南
  2. Centos 添加与删除SWAP(交换分区)
  3. Linux基于libmemcached,php扩展memcached的安装
  4. Thinkphp V5.X 远程代码执行漏洞-POC集合