一、首先要配置兩台linux如何使用SSH免密碼登錄,這樣腳本執行scp命令以及遠程執行腳本都不需要輸入密碼:
A為本地主機(即用於控制其他主機的機器,jenkins服務器) ;
B為遠程主機(即被控制的機器Server,jenkins運行之后發布項目的服務器), 假如ip為10.0.0.10 ;
A和B的系統都是Linux
在A上的命令:
1、 ssh-keygen -t rsa (連續三次回車,即在本地生成了公鑰和私鑰,不設置密碼)
2、 ssh root@10.0.0.10 "mkdir .ssh;chmod 0700 .ssh" (需要輸入密碼, 注:必須將.ssh的權限設為700),如果提示.ssh已經存在,直接ssh root@10.0.0.10 "chmod 0700 .ssh"
3、scp ~/.ssh/id_rsa.pub root@10.0.0.10:.ssh/id_rsa.pub (需要輸入密碼)
在B上的命令:
4、 touch /root/.ssh/authorized_keys (如果已經存在這個文件, 跳過這條)
5、 chmod 600 ~/.ssh/authorized_keys (# 注意: 必須將~/.ssh/authorized_keys的權限改為600, 該文件用於保存ssh客戶端生成的公鑰,可以修改服務器的ssh服務端配置文件/etc/ssh/sshd_config來指定其他文件名)
6、cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys (將id_rsa.pub的內容追加到 authorized_keys 中, 注意不要用,否則會清空原有的內容,使其他人無法使用原有的密鑰登錄)
7、回到A機器: ssh root@10.0.0.10 (不需要密碼, 登錄成功)
二、將Jenkins打好的項目scp到目標服務器,執行自己的腳本
1、 scp /root/.jenkins/workspace/projectA-test/projectA/target/projectA*.war
root@10.0.0.10:/opt/projectA/webapps/projectA.war,jenkins的workspace下的項目名字根據自己的項目而定
2、 ssh root@10.0.0.10 /opt/myshell.sh(注意執行遠程shell方式,要在ssh root@10.0.0.10之后直接加入要執行目標服務器絕對路徑腳本)