/usr/sbin/groupadd deploy /usr/sbin/useradd -g deploy -s /bin/bash deploy passwd deploy
输入两次密码,回车确认
附加: 切换用户命令 su - deply
使用新增用户免密使用sudo命令
添加刚才的用户deploy到sudoers里面,进行免密使用sudo命令
visudo //修改/etc/sudoers的内容,或vim or vi 命令 vim /etc/sudoers ## Allow root to run any commands anywhere # 设置xxxx组下面的用户使用sudo不需要输入密码 root ALL=(ALL) ALL deploy ALL=(ALL) ALL # 新添加这一行 %deploy ALL=(ALL) nopASSWD: ALL # 新添加这一行
到这里已经可以正常在exec中使用sudo here is command来执行命令了,而无需输入密码
以centos7.5为例子
vim /etc/PHP-fpm.d/www.conf # 修改用户和用户组为deploy user = deploy group = deploy # 如果存在listen用户和用户组,同样修改,不存在可以忽略 ;listen.owner = deploy ;listen.group = deploy
重启PHP-fpm服务
service PHP-fpm restart
以centos7.5为例子
vim /etc/Nginx/Nginx.conf
头部新增 (如果存在则修改)
user deploy;
重启Nginx
Nginx -t service Nginx restart
至此,可以使用PHP 脚本执行命令,并拉取git代码,同时,注意PHP脚本所属用户,可以修复文件用户归属:
# 批量修改 filedir 目录所属用户为deploy sudo chown -R deploy:deploy filedir
$output = shell_exec('cd ~/www/test && git pull origin master'); var_dump(output);
原文地址:https://www.jb51.cc/php/1211104.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。