溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

jenkins,自動(dòng)部署scp傳輸錯(cuò)誤的坑

發(fā)布時(shí)間:2020-07-05 11:46:21 來源:網(wǎng)絡(luò) 閱讀:753 作者:飯?zhí)叵?/span> 欄目:系統(tǒng)運(yùn)維

環(huán)境:centos7

版本:jenkins-2.176.3-1.1.noarch.rpm

問題:使用root帳號(hào)安裝jenkins之后,配置自動(dòng)部署,打包完成項(xiàng)目不能scp到項(xiàng)目服務(wù)器,(測(cè)試服務(wù)器ssh端口默認(rèn)22改為6688之后)提示
Host key verification failed. lost connection
[JENKINS] Archiving /opt/jenkins/workspace/test-microservice/base-zuul/target/base-zuul-0.0.1-SNAPSHOT.jar to com.zjgf/base-zuul/0.0.1-SNAPSHOT/base-zuul-0.0.1-SNAPSHOT.jar
[test-microservice] $ /bin/bash /tmp/jenkins8821230735005579726.sh
channel stopped
Host key verification failed.
lost connection
upload files fail

解決方法:
1、rpm包安裝的jenkins默認(rèn)添加jenkins用戶 默認(rèn)shell為:
jenkins:x:992:989:Jenkins Automation Server:/var/lib/jenkins:/bin/false

2、修改默認(rèn)shell
jenkins:x:992:988:Jenkins Automation Server:/var/lib/jenkins:/bin/bash

3、切換到j(luò)enkins用戶
[root@node60 ~]#su - jenkins
bash-4.2$

4、解決變量問題
可以看到j(luò)enkins用戶沒有變量,原因是在安裝jenkins時(shí),jenkins只是創(chuàng)建了jenkins用戶,并沒有為其創(chuàng)建home目錄。所以系統(tǒng)就不會(huì)在創(chuàng)建用戶的時(shí)候,自動(dòng)拷貝/etc/skel目錄下的用戶環(huán)境變量文件到用戶家目錄,也就導(dǎo)致這些文件不存在,出現(xiàn)-bash-4.2#的問題了。

5、修改jenkins用戶變量
以下命令是在切換到 jenkins用戶下執(zhí)行的(重要事項(xiàng)再說一次,su - jenkins 之后再執(zhí)行命令)?。ㄖ皇怯脩衄F(xiàn)在顯示的是-bash-4.2)這個(gè)時(shí)候不要慌,執(zhí)行下面步驟:

vim ~/.bash_profile

執(zhí)行上面的命令,即使沒有.bash_profile文件,linux會(huì)自動(dòng)創(chuàng)建。
然后再添加這句

export PS1='[\u@\h \W]\$'

:wq (保存退出)

然后再刷新.bash_profile文件,使其起作用

source ~/.bash_profile
然后就看到當(dāng)前的變量生效了

[jenkins@node60 root]$

現(xiàn)在可以看到j(luò)enkins用戶shell變量正常了。

6、再次測(cè)試
再次執(zhí)行jenkins任務(wù),發(fā)現(xiàn)還是報(bào)錯(cuò),在Jenkins的使用過程中,如果在腳本中使用到sudo命令,有可能出現(xiàn)如下所示的錯(cuò)誤:
sudo: no tty present and no askpass program specified
這是因?yàn)镴enkins服務(wù)器在執(zhí)行sudo命令時(shí)的上下文有誤,導(dǎo)致這個(gè)命令執(zhí)行的異常。

7、解決方案:
切換到root或者管理員賬戶

[root@node60 ~]# visudo
在文件中加上一行
Allows people in group wheel to run all commands
%wheel ALL=(ALL) ALL
jenkins ALL=(ALL) NOPASSWD: ALL

再次執(zhí)行jenkins任務(wù),發(fā)現(xiàn)還有報(bào)錯(cuò),經(jīng)過排查需要在測(cè)試服務(wù)器上添加jenkins用戶的密鑰

cat /var/lib/jenkins/.ssh/id_rsa.pub

系統(tǒng)提示我 - -!
cat: /var/lib/jenkins/.ssh/id_rsa.pub: 沒有那個(gè)文件或目錄
于是
創(chuàng)建jenkins用戶的公鑰文件id_rsa.pub (su - jenkins 以下命令在jenkins用戶shell中執(zhí)行?。。。?/p>

[jenkins@node60 root]$ ssh-keygen -t rsa

一路回車下去,然后再查看生成的jenkins密鑰對(duì)

[jenkins@node60 root]$ cat /var/lib/jenkins/.ssh/id_rsa.pub

ssh-rsa AAAAB3NzaWGfcK3(太長(zhǎng)了,默默的刪除一部分)WEDv64dQ+oG/IN2lDQa/ jenkins@node60

然后復(fù)制jenkins生產(chǎn)的公鑰,登錄測(cè)試服務(wù)器,添加到測(cè)試服務(wù)器部署帳號(hào)的~/.ssh/authorized_keys

[jenkins@test1 ~]$ vim ~/.ssh/authorized_keys
ssh-rsa AAAAB3NzaW0Mqv0xwKGfcK3WEDv645lPuhXXReY3jGdQ+onGwqym9G/IN2lDQa/ jenkins@node60
保存退出

8、再次測(cè)試
再次編輯jenkins任務(wù) JOB*{需要注意,scp和ssh使用的指定端口號(hào)參數(shù) -P 和 -p 在jenkins中區(qū)分大小寫}
以下為我測(cè)試時(shí)編寫的測(cè)試腳本
···
!/bin/bash
上傳路徑
UPLOAD="/opt/MService/file/upload"
scp -P 6688 /opt/jenkins/workspace/test-aaa-master/target/aaa-0.0.1-SNAPSHOT.jar jenkins@test1:$UPLOAD;
執(zhí)行測(cè)試服務(wù)器更新腳本
ssh -t -p 6688 jenkins@test1 'sh /home/jenkins/.sh/aaa.sh';
···
至此,問題解決!完事

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI