ansible原理及操作

ansible原理

簡(jiǎn)介

ansible是一款基于python開(kāi)發(fā)的自動(dòng)化運(yùn)維工具鸦致,適用于中小型應(yīng)用環(huán)境杉畜。可實(shí)現(xiàn)如下功能:

(1)自動(dòng)化部署APP瓤漏;
(2)自動(dòng)化管理配置項(xiàng);
(3)自動(dòng)化的持續(xù)交互颊埃;
(4)自動(dòng)化的(AWS)云服務(wù)管理蔬充;

從本質(zhì)上來(lái)講就是在一臺(tái)或多臺(tái)遠(yuǎn)程服務(wù)器上,執(zhí)行一系列的命令班利。

ansible命令執(zhí)行過(guò)程

(1) 加載自己的配置文件饥漫,默認(rèn)為/etc/ansible/ansible.cfg
(2) 加載自己對(duì)應(yīng)的模塊文件,如command
(3) 通過(guò)ansible將模塊或命令生成對(duì)應(yīng)的臨時(shí)py文件肥败,并將該文件傳輸至遠(yuǎn)程服務(wù)器的對(duì)應(yīng)執(zhí)行用戶$HOME/.ansible/tmp/ansible-tmp-數(shù)字/XXX.PY文件
(4)給文件+x執(zhí)行
(5)執(zhí)行并返回結(jié)果
(6)刪除臨時(shí)py文件趾浅,sleep 0退出
執(zhí)行狀態(tài):
(1)綠色:執(zhí)行成功并且不需要做改變的操作
(2)黃色:執(zhí)行成功并且對(duì)目標(biāo)主機(jī)做變更
(3)紅色:執(zhí)行失敗

1.用ansible在多臺(tái)機(jī)器上添加用戶

[root@centos7 ansible]ansible nginxsrvs -m user -a 'name=user1 comment="test user" uid=11211 home=/home/user1 group=root'
192.168.48.131 | CHANGED => {
    "changed": true, 
    "comment": "test user", 
    "create_home": true, 
    "group": 0, 
    "home": "/home/user1", 
    "name": "user1", 
    "shell": "/bin/bash", 
    "state": "present", 
    "system": false, 
    "uid": 11211
}
192.168.48.132 | CHANGED => {
    "changed": true, 
    "comment": "test user", 
    "create_home": true, 
    "group": 0, 
    "home": "/home/user1", 
    "name": "user1", 
    "shell": "/bin/bash", 
    "state": "present", 
    "system": false, 
    "uid": 11211
}
[root@centos7 ansible]ansible nginxsrvs -m shell -a 'id user1'
192.168.48.131 | CHANGED | rc=0 >>
uid=11211(user1) gid=0(root) groups=0(root)

192.168.48.132 | CHANGED | rc=0 >>
uid=11211(user1) gid=0(root) groups=0(root)

2.用ansible安裝nginx服務(wù)

1.安裝ansible并配置主機(jī)清單

[root@centos7 ~]yum install -y ansible
[root@centos7 ~]vim /etc/ansible/hosts
······
[nginxsrvs]
192.168.48.131 
192.168.48.132

2.簡(jiǎn)單搭建roles

搭建roles目錄結(jié)構(gòu)
[root@centos7 ~]mkdir /etc/ansible/roles/nginx
[root@centos7 ~]cd !$
cd /etc/ansible/roles/nginx
[root@centos7 nginx]mkdir {files,templates,tasks,handlers,vars,meta}
[root@centos7 nginx]ls
filrs  handlers  meta  tasks  templates  vars
[root@centos7 nginx]cd tasks

group配置
[root@centos7 tasks]vim group.yml
- name: create group
  group: name=nginx gid=80

user配置
[root@centos7 tasks]vim user.yml
- name: cerate user
  user: name=nginx uid=80 group=nginx system=yes shell=/sbin/nologin

yum安裝配置
[root@centos7 tasks]vim yum.yml
- name: install nginx
  yum: name=nginx state=present

服務(wù)啟動(dòng)配置
[root@centos7 tasks]vim start.yml
- name: start service
  service: name=nginx state=started 

服務(wù)重啟配置
[root@centos7 tasks]vim ../handlers/main.yml
- name: restart service
  service: name=nginx state=restarted

復(fù)制nginx原版配置文件到templates目錄并重命名作為模板
[root@centos7 tasks]cp /etc/nginx/nginx.conf ../templates/nginx.conf.j2

修改啟動(dòng)進(jìn)程數(shù)是cpu數(shù)量的兩倍
vim ../templates/nginx.conf.j2
work_processes {{ ansible_processor_vcpus * 2 }}

模板調(diào)用配置
[root@centos7 tasks]vim templ.yml
- name: copy conf
  template: src=nginx.conf.j2 dest=/etc/nginx/nginx.conf
  notify: restart service
nginx 總配置用于調(diào)用之前所有配置
[root@centos7 tasks]vim main.yml
- include: group.yml
- include: user.yml
- include: yum.yml
- include: templ.yml
- include: start.yml

編寫nginx調(diào)用劇本
[root@centos7 tasks]cd /etc/ansible
[root@centos7 ansible]vim nginx_role.yml
- hosts: nginxsrvs
  remote_user: root
  roles:
    - role: nginx

[root@centos7 ansible]tree roles/nginx
roles/nginx
├── filrs
├── handlers
│   └── main.yml
├── meta
├── tasks
│   ├── group.yml
│   ├── main.yml
│   ├── start.yml
│   ├── templ.yml
│   ├── user.yml
│   └── yum.yml
├── templates
│   └── nginx.conf.j2
└── vars

3.測(cè)試安裝

[root@centos7 ansible]ansible-playbook nginxsrvs nginx_role.yml
[root@centos7 ansible]ansible-playbook nginx_role.yml 

PLAY [nginxsrvs] ********************************************************************************************

TASK [Gathering Facts] **************************************************************************************
ok: [192.168.48.132]
ok: [192.168.48.131]

TASK [nginx : create group] *********************************************************************************
changed: [192.168.48.131]
changed: [192.168.48.132]

TASK [nginx : cerate user] **********************************************************************************
changed: [192.168.48.131]
changed: [192.168.48.132]

TASK [nginx : install nginx] ********************************************************************************
changed: [192.168.48.131]
changed: [192.168.48.132]

TASK [nginx : copy conf] ************************************************************************************
changed: [192.168.48.131]
changed: [192.168.48.132]

TASK [nginx : start service] ********************************************************************************
changed: [192.168.48.131]
changed: [192.168.48.132]

RUNNING HANDLER [nginx : restart service] *******************************************************************
changed: [192.168.48.131]
changed: [192.168.48.132]

PLAY RECAP **************************************************************************************************
192.168.48.131             : ok=7    changed=6    unreachable=0    failed=0   
192.168.48.132             : ok=7    changed=6    unreachable=0    failed=0

[root@centos7 ansible]ansible nginxsrvs -m shell -a 'ps aux|grep nginx'
192.168.48.132 | CHANGED | rc=0 >>
root       5146  0.0  0.1 122908  2104 ?        Ss   20:42   0:00 nginx: master process /usr/sbin/nginx
nginx      5147  0.0  0.2 125376  3564 ?        S    20:42   0:00 nginx: worker process
nginx      5148  0.0  0.2 125376  3564 ?        S    20:42   0:00 nginx: worker process
root       5257  0.0  0.0 113128  1204 pts/1    S+   20:46   0:00 /bin/sh -c ps aux|grep nginx
root       5259  0.0  0.0 113128   188 pts/1    R+   20:46   0:00 /bin/sh -c ps aux|grep nginx

192.168.48.131 | CHANGED | rc=0 >>
root       8298  0.0  0.1 122928  2104 ?        Ss   20:42   0:00 nginx: master process /usr/sbin/nginx
nginx      8299  0.0  0.2 125472  3560 ?        S    20:42   0:00 nginx: worker process
nginx      8300  0.0  0.2 125472  3560 ?        S    20:42   0:00 nginx: worker process
root       8424  0.0  0.0 113128  1204 pts/1    S+   20:46   0:00 /bin/sh -c ps aux|grep nginx
root       8426  0.0  0.0 113128   188 pts/1    R+   20:46   0:00 /bin/sh -c ps aux|grep nginx

[root@centos7 ansible]ansible nginxsrvs -m shell -a 'lscpu | grep ^CPU\(s\)'
192.168.48.131 | CHANGED | rc=0 >>
CPU(s):                1

192.168.48.132 | CHANGED | rc=0 >>
CPU(s):                1
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市馒稍,隨后出現(xiàn)的幾起案子皿哨,更是在濱河造成了極大的恐慌,老刑警劉巖纽谒,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件证膨,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡鼓黔,警方通過(guò)查閱死者的電腦和手機(jī)央勒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門不见,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人崔步,你說(shuō)我怎么就攤上這事稳吮。” “怎么了井濒?”我有些...
    開(kāi)封第一講書人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵灶似,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我瑞你,道長(zhǎng)酪惭,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任者甲,我火速辦了婚禮春感,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘虏缸。我一直安慰自己鲫懒,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布寇钉。 她就那樣靜靜地躺著刀疙,像睡著了一般。 火紅的嫁衣襯著肌膚如雪扫倡。 梳的紋絲不亂的頭發(fā)上谦秧,一...
    開(kāi)封第一講書人閱讀 51,301評(píng)論 1 301
  • 那天,我揣著相機(jī)與錄音撵溃,去河邊找鬼疚鲤。 笑死,一個(gè)胖子當(dāng)著我的面吹牛缘挑,可吹牛的內(nèi)容都是我干的集歇。 我是一名探鬼主播,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼语淘,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼诲宇!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起惶翻,我...
    開(kāi)封第一講書人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤姑蓝,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后吕粗,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體纺荧,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了宙暇。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片输枯。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖占贫,靈堂內(nèi)的尸體忽然破棺而出桃熄,到底是詐尸還是另有隱情,我是刑警寧澤靶剑,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布蜻拨,位于F島的核電站,受9級(jí)特大地震影響桩引,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜收夸,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一坑匠、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧卧惜,春花似錦厘灼、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至茅姜,卻和暖如春闪朱,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背钻洒。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工奋姿, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人素标。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓称诗,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親头遭。 傳聞我的和親對(duì)象是個(gè)殘疾皇子寓免,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容