头像

Linux指定nologin用户执行命令

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

发布作者:admin

1047

在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. 使用了ssl pinning的APP如何进行抓包?
  2. apache和nodejs共用80端口
  3. apache 设置禁止IP直接访问
  4. swoole 服务端heartbeat_check_interval心跳检测 客户端 swoole_timer_tick 发送心跳包 这里只是个demo参考