新增使用者並建立密碼
/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來執行命令了,而無需輸入密碼
目標機器修改php-fpm進程為deploy使用者執行
以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
目標機器修改nginx為進程為deploy使用者執行
以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
PHP拉取git程式碼更新例子
$output = shell_exec('cd ~/www/test && git pull origin master'); var_dump(output);
以上就是php+nginx實現自動化部署指令碼(簡單版)的詳細內容,更多請關注TW511.COM其它相關文章!