jenkins發布項目到遠程主機上,配置linux使用SSH免密碼登錄


一、首先要配置兩台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之后直接加入要執行目標服務器絕對路徑腳本)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM