在linux中运行的网站,我们一般分配一个www用户给网站应用程序。但这个用户正常情况是不可以登陆的,这时候如果重启一些服务需要求只能使用www用户执行。此时切换到www用户时,会出错。
方法一
修改/etc/passwd文件 nologin改为bin/bash,这样www用户可以登录服务器,但这样操作比较危险。
方法二
可以通过以下办法使用www用户执行命令。
su -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登陆。