您好,登錄后才能下訂單哦!
這篇文章主要介紹了怎么使用travis-ci持續部署node.js應用,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
基本原理
從自動測試到自動部署的核心問題是測試機與生產服務器的信任問題,即如何安全地把程序包傳輸到生產服務器。市面上的部署工具如scp、ansible、chef,都繞不開這個核心問題。
以scp為例,測試機登錄生產服務器的方式有兩種:密碼和秘鑰。密碼登錄方式需要交互式地輸入密碼,總不能每次測試的時候,人為地輸入密碼吧,所以密碼方式行不通。
秘鑰的方式可以實現自動登錄,但首次將測試機的公鑰傳輸給生產服務器仍然需要密碼。似乎走入了死胡同,但辦法總是有的。我們知道開發機是可以登錄到生產服務器的,那么我們就可以將開發機的公鑰復制到生產服務器,將開發機的私鑰復制到測試機,測試機通過私鑰來偽裝成開發機,自動地登錄到生產服務器。
解決了自動登錄的問題,另一個問題是怎么將開發機的私鑰復制到測試機上。由于測試機每次都是新開的一個虛擬機,這個新開的虛擬機IP不固定,所以沒辦法直接登錄上去。解決辦法是將私鑰文件作為代碼庫的一部分提交,這樣測試機每次從代碼庫上拉取代碼的同時也獲取到了秘鑰文件,通過這種方式就實現了私鑰從開發機復制到測試機。
將私鑰文件提交到代碼庫有一個很嚴重的安全性問題,即任何人只要得到了這個私鑰文件,他就可以隨心所欲的操縱生產服務器。幸好,travis-ci提供了加密方案,它能夠將私鑰文件加密,加密后的文件只在當前代碼庫有效。
總的來說,通過復制私鑰完成自動登錄以及對私鑰加密來保障安全性,我們就可以建立起測試機與生產服務器的信任通道,測試機就可以安全地操作生產服務器完成自動部署。
配置
現在我以scp方式部署nodejs應用為例,來說明travis-ci做自動部署的配置。
首先,建立起開發機與生產服務器的信任關系:
ssh-copy-id username@host
然后,加密你的私鑰,私鑰文件通常在~/.ssh/id_rsa
。加密私鑰文件需要使用travis這個命令行工具,它是一個ruby包,使用gem安裝:
gem install travis travis login
輸入賬號密碼登錄成功后,使用travis encrypt-file
加密:
travis encrypt-file ~/.ssh/id_rsa --add
上面命令執行完后,會生成一段解密命令并添加到.travis.yml
中:
before_install: - openssl aes-256-cbc -K $encrypted_830d3b21a25d_key -iv $encrypted_830d3b21a25d_iv -in ~/.ssh/id_rsa.enc -out ~/.ssh/id_rsa -d
接下來,把加密后的私鑰文件(id_rsa.enc)復制到代碼庫中,千萬要注意不要錯把未加密的私鑰文件(id_rsa)復制到你的代碼庫中。然后把上面的解密命令的-in ~/.ssh/id_rsa.enc
改為-in id_rsa.enc
。
通過上面的過程就基本建立測試機與生產服務器的信任關系,但還有一些小細節要處理。例如,降低id_rsa文件的權限,否則ssh處于安全方面的原因會拒絕讀取秘鑰;將生產服務器地址加入到測試機的信任列表中,否則連接時會詢問是否信任服務器。更改后的配置如下:
before_install: - openssl aes-256-cbc -K $encrypted_830d3b21a25d_key -iv $encrypted_830d3b21a25d_iv -in id_rsa.enc -out ~/.ssh/id_rsa -d - chmod 600 ~/.ssh/id_rsa - echo -e "Host 102.201.64.94\n\tStrictHostKeyChecking no\n" >> ~/.ssh/config
最后,測試機就可以愉快地操作生產服務器了,例如下面是一個nodejs應用的.travis.yml
文件配置:
language: node_js node_js: - '4.4.4' before_install: - openssl aes-256-cbc -K $encrypted_830d3b21a25d_key -iv $encrypted_830d3b21a25d_iv -in id_rsa.enc -out ~/.ssh/id_rsa -d - chmod 600 ~/.ssh/id_rsa - echo -e "Host 102.201.64.94\n\tStrictHostKeyChecking no\n" >> ~/.ssh/config script: - npm run test after_success: - npm prune --production # 刪除devDependencies - tar -jcf indoor-server.tar.bz2 * # 打包并壓縮代碼 - scp indoor-server.tar.bz2 jingsam@102.201.64.94:~/ # 復制到生產服務器上 - ssh jingsam@102.201.64.94 'mkdir -p indoor-server && tar -jxf indoor-server.tar.bz2 -C indoor-server' # 解壓 - ssh jingsam@102.201.64.94 'cd indoor-server && pm2 startOrReload pm2.json' # 重啟pm2
感謝你能夠認真閱讀完這篇文章,希望小編分享的“怎么使用travis-ci持續部署node.js應用”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。