運維自動化------ansible搭建

来源:https://www.cnblogs.com/wang-jin/archive/2018/07/18/9333333.html
-Advertisement-
Play Games

運維自動化發展歷程及技術應用 IaaS基礎設施即服務(相當於賣硬體) ,PaaS平臺即服務(賣操作系統),SaaS軟體即服務(賣軟體) 企業實際應用場景分析 灰度環境(生產環境的一部分) 功能:在全量發佈代碼前將代碼的功能面向少量精準用戶發佈的環境,可基於主機或用戶執行灰度發佈 案例:共100台生產 ...


 

運維自動化發展歷程及技術應用 IaaS基礎設施即服務(相當於賣硬體) ,PaaS平臺即服務(賣操作系統),SaaS軟體即服務(賣軟體) 企業實際應用場景分析 灰度環境(生產環境的一部分) 功能:在全量發佈代碼前將代碼的功能面向少量精準用戶發佈的環境,可基於主機或用戶執行灰度發佈 案例:共100台生產伺服器,先發佈其中的10台伺服器,這10台伺服器就是灰度伺服器 灰度環境:往往該版本功能變更較大,為保險起見特意先讓一部分用戶優化體驗該功能,待這部分用戶使用沒有重大問題的時候,再全量發佈至所有伺服器 程式發佈 程式發佈要求: 不能導致系統故障或造成系統完全不可用 不能影響用戶體驗 預發佈驗證: 新版本的代碼先發佈到伺服器(跟線上環境配置完全相同,只是未接入到調度器) 灰度發佈: 基於主機,用戶,業務 發佈路徑: /webapp/tuangou /webapp/tuangou-1.1 /webapp/tuangou-1.2 發佈過程:在調度器上下線一批主機(標記為maintanance狀態) --> 關閉服務 --> 部署新版本的應用程式 --> 啟動服務 --> 在調度器上啟用這一批伺服器 自動化灰度發佈:腳本、發佈   常用自動化運維工具 Ansible:python,Agentless,中小型應用環境 (管理上百台機器) 利用ssh協議遠程來進行管理,基於key驗證,把管理者的公鑰傳到被管理的主機上去, Saltstack:python,一般需部署agent(代理),執行效率更高 (管理上千台機器) Puppet:ruby, 功能強大,配置複雜,重型,適合大型環境 (管理上百台機器) Fabric:python,agentless Chef: ruby,國內應用少 Cfengine func Ansible簡介 Ansible是一個簡單的自動化運維管理工具,基於Python語言實現,由ParamikoPyYAML兩個關鍵模塊構建,可用於自動化部署應用、配置、編排task(持續交付、無宕機更等)。    Ansible官網:https://www.ansible.com/    github地址:https://github.com/Ansible 特性   模塊化:調用特定的模塊,完成特定任務,一千多個模塊   有Paramiko,PyYAML,Jinja2(模板語言)三個關鍵模塊   支持自定義模塊   基於Python語言實現   部署簡單,基於python和SSH(預設已安裝)免代理,agentless   安全,基於OpenSSH   支持playbook編排任務 冪等性:一個任務執行1遍和執行n遍效果一樣,不因重覆執行帶來意外情況   無需代理不依賴PKI(無需ssl)   可使用任何編程語言寫模塊   AML格式,編排任務,支持豐富的數據結構   較強大的多層解決方案 Ansible主要組成部分 1:ANSIBLE PLAYBOOKS:任務劇本(任務集),編排定義Ansible任務集的配置文件,由Ansible順序 依次執行,通常是JSON格式的YML文件 2:INVENTORY:Ansible管理主機的清單/etc/ansible/hosts 3:MODULES:Ansible執行命令的功能模塊,多數為內置核心模塊,也可自定義 4:PLUGINS:模塊功能的補充,如連接類型插件、迴圈插件、變數插件、過濾插件等,該功能不常用 5:API:供第三方程式調用的應用程式編程介面 6:ANSIBLE:組合INVENTORY、API、MODULES、PLUGINS的綠框,可以理解為是ansible命令工 具,其為核心執行工具 7:Ansible命令執行來源: U7SER,普通用戶,即SYSTEM ADMINISTRATOR CMDB(配置管理資料庫) API 調用 PUBLIC/PRIVATE CLOUD API調用 USER-> Ansible Playbook -> Ansibile 8:利用ansible實現管理的方式: Ad-Hoc 即ansible命令,主要用於臨時命令使用場景 Ansible-playbook 主要用於長期規劃好的,大型項目的場景,需要有前提的規劃 9:Ansible-playbook(劇本)執行過程: 將已有編排好的任務集寫入Ansible-Playbook 通過ansible-playbook命令分拆任務集至逐條ansible命令,按預定規則逐條執行 10:Ansible主要操作對象: HOSTS主機 NETWORKING網路設備 11:註意事項 執行ansible的主機一般稱為主控端,中控,master或堡壘機 主控端Python版本需要2.6或以上 被控端Python版本小於2.4需要安裝python-simplejson 被控端如開啟SELinux需要安裝libselinux-python windows不能做為主控端 安裝 rpm包安裝: EPEL源 yum install ansible 編譯安裝: yum -y install python-jinja2 PyYAML python-paramiko python-babel python-crypto tar xf ansible-1.5.4.tar.gz cd ansible-1.5.4 python setup.py build python setup.py install mkdir /etc/ansible cp -r examples/* /etc/ansible Git方式: git clone git://github.com/ansible/ansible.git --recursive cd ./ansible source ./hacking/env-setup pip安裝: pip是安裝Python包的管理器,類似yum yum install python-pip python-devel yum install gcc glibc-devel zibl-devel rpm-bulid openssl-devel pip install --upgrade pip pip install ansible --upgrade 確認安裝: ansible --version 配置文件 /etc/ansible/ansible.cfg 主配置文件,配置ansible工作特性,(軟連接指向新版本,方便) /etc/ansible/hosts 主機清單 , /etc/ansible/roles/ 存放角色的目錄 程式 /usr/bin/ansible 主程式,臨時命令執行工具 /usr/bin/ansible-doc 查看配置文檔,模塊功能查看工具,相當於man命令 /usr/bin/ansible-galaxy(銀河) 下載/上傳優秀代碼或Roles模塊的官網平臺 /usr/bin/ansible-playbook 定製自動化任務,編排劇本工具/usr/bin/ansible-pull (拉取)遠程執行命令的工具 /usr/bin/ansible-vault 文件加密工具 /usr/bin/ansible-console 基於Console界面與用戶交互的執行工具 主機清單inventory Inventory 主機清單 ansible的主要功用在於批量主機操作,為了便捷地使用其中的部分主機,可以在inventory file中 將其分組命名 /etc/ansible/hosts文件格式 inventory文件遵循INI文件風格,中括弧中的字元為組名。可以將同一個主機同時歸併到多個不同的組中;此外,當如若目標主機使用了非預設的SSH埠,還可以在主機名稱之後使用冒號加埠號來標明 ntp.magedu.com [webservers] www1.magedu.com:2222 www2.magedu.com [dbservers] db1.magedu.com db2.magedu.com db3.magedu.com 如果主機名稱遵循相似的命名模式,還可以使用列表的方式標識各主機 · 示例: [websrvs] www[01:100].example.com [dbsrvs] db-[a:f].example.com ansible 配置文件 Ansible 配置文件/etc/ansible/ansible.cfg (一般保持預設) [defaults] #inventory = /etc/ansible/hosts # 主機列表配置文件 #library = /usr/share/my_modules/ # 庫文件存放目錄 #remote_tmp = $HOME/.ansible/tmp #臨時py命令文件存放在遠程主機目錄 #local_tmp = $HOME/.ansible/tmp # 本機的臨時命令執行目錄 #forks = 5 # 預設併發數 #sudo_user = root # 預設sudo 用戶 #ask_sudo_pass = True #每次執行ansible命令是否詢問ssh密碼 #ask_pass = True #remote_port = 22 #host_key_checking = False # 檢查對應伺服器的host_key,建議取消註釋 #log_path=/var/log/ansible.log #日誌文件   Ansible系列命令 ansible ansible-doc ansible-playbook ansible-vault   ansible-console ansible-galaxy ansible-pull   ansible-doc: 顯示模塊幫助 ansible-doc [options] [module...] -a 顯示所有模塊的文檔 -l, --list 列出可用模塊 -s, --snippet顯示指定模塊的playbook片段 示例: ansible-doc –l 列出所有模塊 ansible-doc ping 查看指定模塊幫助用法 ansible-doc –s ping 查看指定模塊幫助用法   ansible ansible通過ssh實現配置管理、應用部署、任務執行等功能,建議配置ansible端能基於密鑰認證的方式聯繫各被管理節點 ansible <host-pattern> [-m module_name] [-a args] (-a加參數) --version 顯示版本 -m module 指定模塊,預設為command -v 詳細過程 –vv -vvv更詳細 --list-hosts 顯示主機列表,可簡寫—list -k, --ask-pass 提示輸入ssh連接密碼,預設Key驗證 -K, --ask-become-pass 提示輸入sudo時的口令 -C, --check 檢查,並不執行 (測試) -T, --timeout=TIMEOUT 執行命令的超時時間,預設10s -u, --user=REMOTE_USER 執行遠程執行的用戶     -b, --become 代替舊版的sudo 切換 一、環境準備 centos7 192.168.30.110做主控端 192.168.30.100 、192.168.30.107 192.168.30.114 做被控端 二、搭建配置ansible [root@centos7 ~]# yum -y install ansible 查看版本信息 這裡面的ping是ansible的ping模塊; 清單列表不包括本機; 把要管理的主機加入到主機清單中 etc/ansible/hosts   [root@centos7 ~]# ansible 192.168.30.100 -m ping 測試存活性是基於ssh服務的,基於密碼和key驗證,通常是基於key驗證;部署是把ssh的可以驗證做好     建議:在控制主機登錄主機的同時,如果不要每次都通過驗證登錄,則修改配置文件,預設提供YES啟動日誌的功能,手動註釋取消就行了 [root@centos7 ~]# vim /etc/ansible/ansible.cfg   在控制端主機生成公鑰,把公鑰傳到三台被控制端主機上去,實現key驗證   可以對主機清單做分組     ansible的Host-pattern(主機列表) 匹配主機的列表 All :表示所有Inventory(主機清單)中的所有主機 ansible all –m ping * :通配符 ansible “*” -m ping ansible 192.168.1.* -m ping ansible “*srvs” -m ping 或關係 ansible “websrvs:appsrvs” -m ping ansible “192.168.1.10:192.168.1.20” -m ping 邏輯與 ansible “websrvs:&dbsrvs” –m ping 在websrvs組並且在dbsrvs組中的主機 邏輯非 ansible ‘websrvs:!dbsrvs’ –m ping 在websrvs組,但不在dbsrvs組中的主機 註意:此處為單引號 綜合邏輯 ansible ‘websrvs:dbsrvs:&appsrvs:!ftpsrvs’ –m ping 正則表達式 ansible “websrvs:&dbsrvs” –m ping ansible “~(web|db).*\.magedu\.com” –m ping 邏輯與   ansible命令執行過程 ansible命令執行過程 1. 載入自己的配置文件 預設/etc/ansible/ansible.cfg 2. 載入自己對應的模塊文件,如command 3. 通過ansible將模塊或命令生成對應的臨時py文件,並將該 文件傳輸至遠程伺服器的對應執行用戶$HOME/.ansible/tmp/ansible-tmp-數字/XXX.PY文件 4. 給文件+x執行 5. 執行並返回結果 6. 刪除臨時py文件,sleep 0退出 執行狀態: 綠色:執行成功並且不需要做改變的操作 黃色:執行成功並且對目標主機做變更 紅色:執行失敗   ansible使用示例 示例 sudo 切換身份預設就是root, 以wang用戶執行ping存活檢測 ansible all -m ping -u wang -k 以wang sudo至root執行ping存活檢測(用wang用戶連接對方後,sudo到root身份執行操作) ansible all -m ping -u wang –b -k 以wang sudo至mage用戶執行ping存活檢測 ansible all -m ping -u wang –b -k --become-user mage 以wang sudo至root用戶執行ls ansible all -m command -u wang --become-user=root -a 'ls /root' -b –k -K ansible常用模塊 Command:在遠程主機執行命令,預設模塊,可忽略-m選項 ansible srvs -m command -a ‘service vsftpd start’ ansible srvs -m command -a ‘echo magedu |passwd --stdin wang’ 不成功此命令 不支持 $VARNAME < > | ; & 等,用shell模塊實現   Shell:和command相似,用shell執行命令 vim /etc/ansible/ansible.cfg 1:ansible srv -m shell -a ‘echo magedu |passwd –stdin wang’ :2:調用bash執行命令 類似 cat /tmp/stanley.md | awk -F‘|’ ‘{print $1,$2}’ &>/tmp/example.txt 這些複雜命令,即使使用shell也可能會失敗,解決辦法:寫到腳本時,copy到遠程,執行,再把需要的結果拉回執行命令的機器   Script:運行腳本 腳本模式、用於批量執行腳本 -a "/PATH/TO/SCRIPT_FILE“ snsible websrvs -m script -a f1.sh 在控制端的主機上編寫一個腳本,但是運行是在被控制端的主機上   Copy:從伺服器複製文件到客戶端, ansible srv -m copy -a “src=/root/f1.sh dest=/tmp/f2.sh owner=wang mode=600,backup=yes”   如目標存在,預設覆蓋,此處指定先備份 ansible srv -m copy -a “content=‘test content\n’ dest=/tmp/f1.txt” 利用內容,直接生成目標文件 複製模塊、批量複製,拷貝文件到遠程主機 ansible [主機ip、主機組] -m copy -a "src=源文件 dest=目標路徑 owner=所有者 mode=許可權 backup=yes/no是否備份"   備份文件名稱比較長的   Fetch(抓取):把遠程的主機文件抓取到控住端的主機上,copy相反,目錄可先tar ansible srv -m fetch -a ‘src=/root/a.sh dest=/data/scripts’     File:設置文件屬性 (刪除文件的效果,創建軟硬連接) ansible srv -m file -a "path(管理的文件)=/root/a.sh owner=wang mode=755“ ansible web -m file -a ‘src=/app/testfile dest=/app/testfile-link state=link(軟連接) ansible all -m file -a 'path(管理的文件)=/data state=absent(遞歸的刪除,缺席)' 已經刪除data文件夾 還可以[root@centos7 ~]# ansible all -m file -a 'path=/data/test.txt state=touch' 在被控制端的主機上創建test.txt 文件 創建軟連接     Hostname:管理主機名 ansible node1 -m hostname -a “name=websrv” 永久生效,但hosts文件沒有被改   Cron:計劃任務 [root@centos7 ~]# ansible-doc -s cron 調用模塊 支持時間:minute,hour,day,month,weekday ansible srv -m cron -a “minute=*/5(每5分鐘) job(後跟執行的命令)=‘/usr/sbin/ntpdate 172.16.0.1 &>/dev/null’     name=Synctime” 創建任務   ansible srv -m cron -a ‘state=absent name=Synctime’ 刪除任務 結果   Yum:管理包 ansible srv(all) -m yum -a ‘name=httpd state=latest(最新版)’ 安裝 [root@centos7 ~]# scp /etc/yum.repos.d/media.repo 192.168.30.107:/etc/yum. repos.d/media.repo 100% 140 64.3KB/s 00:00 [root@centos7 ~]# ansible all -m yum -a 'name=httpd state=present' ansible srv -m yum -a ‘name=httpd state=absent’ 刪除 ansible常用模塊   Service:管理服務 ansible-doc -s service ansible all -m service -a 'name=httpd state=stopped' ansible all -m service -a 'name=httpd state=started'   ansible all –m service –a ‘name=httpd state=reloaded’ ansible all -m service -a 'name=httpd state=restarted'   User:管理用戶 ansible all-m user -a 'name=user1 comment=“test user” uid=2048 home=/app/user1 group=root‘ ansible all -m user -a 'name=sysuser1 system=yes home=/app/sysuser1 ’ ansible all -m user -a ‘name=user1 state=absent remove=yes‘ 刪除用戶及家目錄等數據 [root@centos7 ~]# ansible all -m user -a 'name=testuser(用戶名) system=yes(系統賬號) groups(組)=wang,bin shell=/bin/csh' (shell類型)     Group:管理組 ansible srv -m group -a "name=testgroup(組名) system=yes“ ansible srv -m group -a "name=testgroup state=absen(刪除組)   ansible系列命令 ansible-galaxy (人們寫的劇本,下載ansible劇本框架工具,根據自己的需求下載相關的角色) 連接 https://galaxy.ansible.com 下載相應的roles 列出所有已安裝的galaxy ansible-galaxy list(列出有哪些裝好的角色) 安裝galaxy ansible-galaxy install geerlingguy.redis 刪除galaxy ansible-galaxy remove geerlingguy.redis ansible-pull 推送命令至遠程,效率無限提升,對運維要求較高 Ansible-playbook(劇本) ansible-playbook hello.yml(劇本文件)   cat hello.yml #hello world yml file       - hosts(主機清單): websrvs (主機清單的分組名)         remote_user: root (遠程連接以root身份)   tasks:(任務)       - name: hello world(之後要做的事)         ommand: /usr/bin/wall hello world (是-a後的所有的操作)   [root@centos7 ~]# vim hello.yml [root@centos7 ~]# ansible-playbook hello.yml 用次命令執行    Ansible-vault 功能:管理加密解密yml文件 ansible-vault [create|decrypt|edit|encrypt|rekey|view] ansible-vault encrypt hello.yml 加密 ansible-vault decrypt hello.yml 解密 ansible-vault view hello.yml 查看 ansible-vault edit hello.yml 編輯加密文件 ansible-vault rekey hello.yml 修改口令 ansible-vault create new.yml 創建新文件 Ansible-console:2.0+新增,可交互執行命令,支持tab root@test (2)[f:10] $ 執行用戶@當前操作的主機組 (當前組的主機數量)[f:併發數]$ 設置併發數: forks n 例如: forks 10 切換組: cd 主機組 例如: cd web 列出當前組主機列表: list 列出所有的內置命令: ?或help 示例: root@all (2)[f:5]$ list root@all (2)[f:5]$ cd appsrvs root@appsrvs (2)[f:5]$ list root@appsrvs (2)[f:5]$ yum name=httpd state=present root@appsrvs (2)[f:5]$ service name=httpd state=started              

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 首先從post一下 http://s.web2.qq.com/api/get_user_friends2 這個鏈接獲取分組categories ,好友信息 friends,info。 string url = "http://s.web2.qq.com/api/get_user_friends2"; ...
  • 一、WCF配置 1 Address 將服務端發佈地址和客戶端訪問地址都配置為https開始的安全地址。參考如下。 2 Bingding 為適應WCF自寄宿的模式,應採用WSHttpBinding作為綁定模式,並選擇Transport安全模式,此模式下支持由伺服器SSL證書保證的信息完整性、保密性、服 ...
  • 委托概述 將方法調用者和目標方法動態關聯起來,委托是一個類,所以它和類是同級的,可以通過委托來掉用方法,不要誤以為委托和方法同級的,方法只是類的成員。委托定義了方法的類型(定義委托和與之對應的方法必須具有相同的參數個數,並且類型相同,返回值類型相同),使得可以將方法當作另一個方法的參數來進行傳遞,這 ...
  • public static void Login_GetPHV() { string urldata = "{\"ptwebqq\":\"#{ptwebqq}\",\"clientid\":53999199,\"psessionid\":\"\",\"status\":\"online\"}".Re ...
  • 原文地址: "https://www.codeproject.com/Articles/57984/WPF Loading Wait Adorner" 界面遮罩 等待動畫全局顏色 等待動畫中的小圓 後臺業務代碼,添加了幾項屬性、動畫控制、小圓的位置設置 ...
  • 概念: MongoDB分片是使用多個伺服器存儲數據的方法,以支持巨大的數據存儲和對數據進行存儲 優勢: 1、減少了每個分片需啊喲處理的請求數,群集可以提高自己的存儲容量和吞吐量 2、減少了每個分片存儲的數據 三個主要組件: 如何部署MongoDB分片群集!!! 編輯mongodb1.conf配置文件 ...
  • 參考網址:https://blog.csdn.net/heyuqian_csdn/article/details/78805029 ...
  • Cache和DMA本身似乎是兩個毫不相關的事物。Cache被用作CPU針對記憶體的緩存利用程式的空間局部性和時間局部性原理,達到較高的命中率,從而避免CPU每次都必須要與相對慢速的記憶體交互數據來提高數據的訪問速率。DMA可以作為記憶體與外設之間傳輸數據的方式,在這種傳輸方式之下,數據並不需要經過CPU中 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...