亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用GlobalSSH加速Ansible外部署效率步驟解說

發布時間:2020-05-11 15:10:17 來源:億速云 閱讀:310 作者:Leah 欄目:云計算

今天小編就為大家帶來一篇使用GlobalSSH加速Ansible外部署效率步驟解說的文章。小編覺得挺不錯的,為此分享給大家做個參考。一起跟隨小編過來看看吧。

什么是Ansible
Ansible是一個簡單高效、無Agent架構的自動化編排、部署及配置管理工具,通過SSH協議實現遠程節點和管理節點之間的通信。

Ansible的目的是簡化大量復雜重復的運維工作, 以精簡的技術思路建立公司內統一的自動化文化。無Agent的架構使其比其他工具更顯簡單,基于SSH可以做到的事Ansible都可以做的更好,超高的易用度使其可以簡單集成到現有體系之中,因而被廣泛使用。

使用GlobalSSH加速Ansible外部署效率步驟解說

UCloud Ansible使用場景
UCloud內部也大量使用到了Ansible。比如,機×××品部署系統,通過Ansible實現了部署效率的極大提升,目前已經成為UCloud機房部署的重要工具。又如,現網大規模灰度發布系統,通過集成Ansible的基礎API和Callback功能,很好的解決了灰度發布、回滾、控制等難題,該系統已經在線上穩定運行3年以上,完成相關灰度發布任務上萬個。

下面將詳細介紹Ansible在機×××品部署系統中的使用,相信對有多機房部署需求的讀者會有幫助。

海外多機房部署
我們基于Ansible集中式地批量部署和管理服務,集中式管理中心位于北京/上海機房。當海外節點(如拉各斯、胡志明等)需要建設時,通過Ansible來遠程部署云產品及內部服務。部分云產品是基于UCloud云主機作為IaaS層搭建的,所以也是通過SSH連到對應的海外云主機進行操作。

使用GlobalSSH加速Ansible外部署效率步驟解說

這和一般用戶的使用場景有很多相似之處,無論其是自建IDC或用了公有云,甚至多云部署來同時管理不同云上的服務器,都有類似批量部署的需要。

使用GlobalSSH加速Ansible外部署效率步驟解說

海外部署有個額外的痛點,就是部署效率的問題。Ansible使用SSH協議進行通信,SSH通道的創建和通信速度都較慢。當需要通過外網管理,而網絡環境較差或帶寬不足的情況下,執行時間基本上無法忍耐,體現在用Ansible部署時,經常會出現卡頓、連接失敗、傳輸速度較慢等現象,使用Copy模塊傳輸稍大的代碼包/鏡像文件時基本上要等到花兒都謝了。

我們的解決方法,是把UCloud的 PaaS產品GlobalSSH,集成進Ansible,用于提高跨國遠程管理服務器效率。

GlobalSSH
GlobalSSH為了保障海外數據中心的運維而推出,采用了UCloud眾多IaaS產品如ULB4(四層負載均衡)、UDPN(洲際內網互聯、0丟包)及高包量云主機,引入智能DNS服務以提供就近接入的能力。網絡轉發基于成熟穩定的GRE、NAT技術,支持TCP端口(除80、443)四層轉發。

使用GlobalSSH加速Ansible外部署效率步驟解說

Ansible Playbook方式部署
我們將GlobalSSH集成到Ansible,做一個簡單的軟件包拷貝及安裝,步驟如下所示。

1)首先,我們通過UCloud API或控制臺在北京二和拉各斯(尼日利亞)各創建一臺云主機,帶寬為1Mb,其中拉各斯機房會自動開啟GlobalSSH功能(所有UCloud海外機房均會自動開啟),如下圖所示:

使用GlobalSSH加速Ansible外部署效率步驟解說

2)準備一個簡單的Ansible Playbook,分別完成3個步驟:gather facts、copy代碼包以及yum安裝代碼。相關的playbook如下所示:

--- - hosts: all tasks: - name: copy test copy: src=/data/MySQL-devel-5.6.41-1.el6.x86_64.rpm dest=/data/test - name: install mysql-devel yum: name=/data/MySQL-devel-5.6.41-1.el6.x86_64.rpm state=present
3)準備一個hosts文件,用于配置GlobalSSH所生成的域名。Ansible在對GlobalSSH的支持上非常簡單,只要在主機變量里面添加 ansible_ssh_host=xxx.xxx.xxx.xxx.ipssh.net即可。我們的機房部署系統會結合Ansible的Dynamic Inventory功能,直接在生成的inventory中將GlobalSSH的加速域名加到ansible_ssh_host變量中了,使用起來也是非常容易的,如下所示。

[root@10-10-83-122 ~]# cat hosts_nrly [all] 152.32.140.39 ansible_ssh_pass=example [root@10-10-83-122 ~]# cat hosts_nrly_1 [all] 152.32.140.39 ansible_ssh_pass=example ansible_ssh_host=152.32.140.39.ipssh.net
4)使用ansible-playbook命令執行該playbook,任務完成。

測試對比
前面提到,GlobalSSH大幅提高了我們海外部署的效率。可以通過另寫一個無GlobalSSH加速的Playbook,來測試一下具體的加速效果。

無GlobalSSH的Playbook寫起來比較簡單,和上文基本類似,區別在第三步的hosts文件里不使用加速域名,而是直接填寫原有的外網IP地址。

為防止單次測試結果的不準確,這里測試了10次,取平均值進行比較。

測試命令:

time for i in seq 1 10; do ansible-playbook -i hosts_nrly test_playbook.yml; done time for i in seq 1 10; do ansible-playbook -i hosts_nrly_1 test_playbook.yml; done
最終的結果如下所示,可以看到在簡單的Ansible Playbook部署中, 經過GlobalSSH加速后的效果提升了32.23%.

使用GlobalSSH加速Ansible外部署效率步驟解說

Ansible Ad-hoc方式
GlobalSSH在低速的帶寬下可以提升整個網絡傳輸的穩定性和速度,尤其是對RTT (Round-Trip Time)往返延遲的提升,更是有著外網彈性IP所不具備的速度優勢。 因此我們認為它對Ansible Ad-hoc方式也有很大幫助。

運維人員經常會用Ad-hoc方式,它類似pssh,卻支持Ansible所有的module語法,通常的使用場景是批量執行命令并查看回顯結果。為了驗證假設,我們對Ad-hoc方式也做了類似測試,發現GlobalSSH后的優化效果更明顯,優化速度超過50%,詳細結果如下所示。

測試命令:

time for i in seq 1 10; do ansible -i hosts_nrly all -m shell -a "cat /var/log/messages"; done time for i in seq 1 10; do ansible -i hosts_nrly_1 all -m shell -a "cat /var/log/messages"; done

測試結果:

使用GlobalSSH加速Ansible外部署效率步驟解說

總結
Ansible是被大量使用的DevOps工具,我們在使用中根據需要,將GlobalSSH很容易地集成其中,避免了服務器部署中SSH卡頓造成的不良影響。

看完上訴內容,你們掌握使用GlobalSSH加速Ansible外部署效率的方法了嗎?如果想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

白河县| 井陉县| 宁国市| 山西省| 尖扎县| 康平县| 韶关市| 静宁县| 西安市| 永胜县| 广汉市| 祁阳县| 永兴县| 任丘市| 姜堰市| 桦甸市| 沙坪坝区| 长沙市| 赤峰市| 朝阳区| 西华县| 塔河县| 嘉黎县| 克东县| 澄迈县| 响水县| 漯河市| 平山县| 南召县| 靖边县| 建德市| 通化县| 苏尼特右旗| 韶山市| 长泰县| 安远县| 林州市| 长春市| 布尔津县| 大港区| 兴仁县|