- 积分
- 16843
在线时间 小时
最后登录1970-1-1
|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?开始注册
x
.使用playbook安装启用httpd服务" c! `! |1 {9 b6 n0 c
首先编写xxx.yaml文件. k# X9 ~3 y2 m* |- D1 @: f/ a
% u' b6 N f# S# z/ ]
--- #多个yaml文件以---开头,以表明这是一个yaml文件,可省略
7 `1 Y/ `4 d% K Y/ x- n! Y- name: apache play #定义一个play的名称,可省略; Y% _. b8 S3 k7 Y9 ]
gather_facts: false #设置不进行facts信息收集(即setup模块收集信息),这可以加快执行速度,如果不使用其中的信息可省略" F9 o+ f$ Y9 Y4 o# i8 H8 u$ |! U/ v2 N
hosts: webservers #指定要执行任务的被管理主机组,如多个主机组用冒号:分隔
0 [, u" l$ Q. g7 x remote_user: root #指定被管理主机上执行任务的用户3 k$ ]( K# Z; n. Q
tasks: #定义任务列表,任务列表中的各任务按次序逐个在hosts中指定的主机上执行" d9 u( C4 q4 I+ q( O
- name: disable selinux #自定义任务名称0 }+ y: L2 k5 h) `" q" S6 I
command: '/usr/sbin/setenforce 0' 键值对,键是ansible模块,值是 -a 中的内容7 R( S* R8 y% u) @, X; ?% W7 N6 ~
ignore_errors: true #如执行命令的返回值不为0,就会报错,tasks停止,可使用ignore_errors忽略失败的任务: X% N7 q) I4 R @9 N
# y/ T* A6 H5 l/ F( G/ K
- name: disable firewalld
& @3 B* H+ O1 E6 c) u service: name=firewalld state=stopped enabled=no
" ^. {+ T* w4 y# a; {: H5 {7 s5 E
& l8 @3 O3 s5 f6 Q6 w( f" E, v5 E4 R - name: prepare local repo
6 y3 K) L$ v1 d ]$ k" e copy: src=/etc/yum.repos.d/local.repo dest=/etc/yum.repos.d/local.repo2 h8 Z: q+ Z) J; F1 r
- C% D/ [! n$ l9 ~
- name: mount cdrom: E# H3 s# ~/ S# U! u) p
mount: src=/dev/sr0 path=/mnt fstype=iso9660 state=mounted, D; C- |; b& b8 o) J
- name: install apache+ `- O. L1 s( q P1 O3 q
yum: name=httpd state=latest
+ \8 `, C3 w, Y: Q, D! ~0 j - name: prepare httpd configuration file7 | H% |" e% Q9 S0 m+ A
copy: src=/opt/httpd.conf dest=/etc/httpd/conf/httpd.conf mode=644 owner=apache group=apache
% p" B5 }! g& Z notify: "restart httpd" #如以上操作后为changed的状态时,会通过notify指定的名称触发对应名称的handlers操作/ y8 ?. x* ~- `
! R% a" G7 o6 g4 W. b+ l! N
- name: start httpd
- R# W7 u; C# L! s% G/ i service: name=httpd state=started enabled=yes
6 y# U$ Q( R8 g' A( k( y$ h* ~1 g7 l$ Q3 a+ Z
handlers: #handlers中定义的就是任务,此处handlers中的任务使用的是service模块
- H @+ G( Q! k4 G6 _ - name: restart httpd #notify和handlers中任务的名称必须一致, H+ C- z6 x" z2 B( k
service: name=httpd state=restarted
; y2 y& C+ \1 D0 \* V P运行playbook( Z' @! j9 c7 B, Q9 W
0 F. G: U2 G8 fansible-playbook xxx.yaml; ~' x& i' l8 x& b. [* `6 y
7 L/ u1 m. _2 ^( N2 R8 n补充参数:
) V- X* q. B# W7 V$ b$ p -k(–ask-pass):用来交互输入ssh密码 u( q1 P" j+ D3 R
-K(-ask-become-pass):用来交互输入sudo密码. R& b4 f, o7 }& g7 D
-u:指定用户
9 I3 Z# Z5 }; u1 T8 }3 g, F( B
& r' Z5 F6 \, g! P
9 a9 N3 ?; K+ _- w
7 ~" h- S" Z; B3 U' [Ansible在执行完某个任务之后并不会立即去执行对应的handler,而是在当前play中所有普通任务都执行完后再去执行handler,这样的好处是可以多次触发notify,但最后只执行一次对应的handler,从而避免多次重启。
7 L' v! _( ]) D# |' F3 r/ N/ C
, B- p" W4 c V- T1 c: u. T8 `) [2.使用playbook安装启用nginx服务
* K) `% M7 S, }2 C# [' w1 R首先编写xxx.yaml文件
$ u" R0 @* A! T! x2 g: p- X7 i' A# g' B7 ]: i8 y
---
6 i( y7 n, y# U$ w; |- name: nginx play
+ l. W. W' L( i+ H, v gather_facts: false/ q. y; @/ n. L. `2 u" y% Q- _$ I: l) X
hosts: webservers3 v C2 l9 U# }' G. v: g
remote_user: root
6 k2 v7 T; `/ f0 {2 n tasks:; T: h4 h9 p9 L2 o0 j3 h9 _% [
- name: test connection r' \) g1 X' A8 x+ O0 ], r+ Z
ping:
9 t. e# k# M+ k, W' ^- Y
. _; C5 ]3 i0 O. Q; Z3 b5 r8 \$ I - name: disable selinux4 J, k# \5 u- O3 A
command: '/usr/sbin/setenforce 0'
' |2 h) D4 g* h# l# |3 x* p0 V. ` ignore_errors: true8 x" K2 D' X9 ?5 A# h K- ~
6 O4 Y, F3 m$ {5 w - name: disable firewalld
! P! k0 H, t0 g service: name=firewalld state=stopped enabled=no
* C1 a* C6 R, ]5 A' d% K9 p: o! A
- name: prepare nginx repo" L; Q5 b7 z9 [
copy: src=/etc/yum.repos.d/nginx.repo dest=/etc/yum.repos.d/nginx.repo, q- a) P$ u3 R. _4 I8 f
8 o( ?- S& Q" r# A - name: add dns
! ^) m% `; L4 J copy: content="nameserver 8.8.8.8" dest=/etc/resolv.conf
- s1 ?# D% m& b$ O+ ^5 M g9 m' n5 O7 r' ?, w3 \1 ]
- name: install nginx
0 G* p1 d# g5 L( m8 D yum: name=nginx state=latest2 P" o6 P: @/ ^# ~, h& u
) m4 k+ z. i1 h - name: prepare nginx configuration file
5 X- j1 }6 a) \# ?4 n/ M copy: src=/opt/nginx.conf dest=/etc/nginx/nginx.conf mode=644 owner=nginx group=nginx
: ~: E& \, n# h' S0 |- A) d/ C- N$ j* t( O
- name: prepare nginx configuration.d file6 b' R- ~) ^( _; w# I& A5 K
copy: src=/opt/default.conf dest=/etc/nginx/conf.d/default.conf mode=644 owner=nginx group=nginx
# { O* G9 } w b" Y notify: "restart nginx"
& U3 C- Y9 O" A2 L4 o. p3 P% }( b0 A. W1 M' [
- name: start nginx1 A$ {% U. P% Q
service: name=nginx state=started enabled=yes& Q V8 a2 i/ ]. Y( R
; C# A# J) t6 B+ j; N7 S
handlers:; j- R8 g( s: m8 o& P* q! k
- name: restart nginx- i# D. I: a( J# q7 [& M! X& M
service: name=nginx state=restarted
$ t$ X7 k- @" e运行playbook+ P4 l4 ?8 }. ?+ l$ P+ S
: ^. d$ v: l; G% K; y" A5 _
检查yaml文件的语法是否正确; o$ f% q, @& ~. \( c$ e
ansible-playbook xxx.yaml --syntax-check
7 N2 l C7 }* U$ S4 Q' X
3 | x& C& p$ y& w- O5 J如果语法格式有问题会报错
9 ?8 K7 B) V% [3 g
( R! ~5 [1 ]8 }3 Q# }! X
3 y3 ]; k7 z8 V; R; M- K$ c2 e' @% I" U; O7 d3 l5 A$ H/ i
2.检查tasks任务/ C/ j7 A: W1 H: N3 n. c3 i$ [
ansible-playbook xxx.yaml --list-task$ f/ O M0 w [' v
1 Q. F" R- v) V y) M如果任务列表中的语法格式有问题会报错
! H* I8 w0 b: q8 r% F% B7 I( v4 v5 m! u7 d& ]5 t
% G4 F5 e* U2 I: T; Q4 s6 E
4 g8 G0 y+ S4 ?! V! R
3.检查指定的主机: n; \- P2 c6 ?. c0 w
ansible-playbook test1.yaml --list-hosts1 I/ w9 ~6 p, ?* D; q: [6 }9 ^
% [" a$ K8 H0 ~. w
# s# n7 E4 i- V/ ]
# T% @$ D9 R! ^3 r$ E2 g0 O
4.指定从某个task开始运行) p8 y- Q+ t& U) r2 |6 l2 M
ansible-playbook xxx.yaml --start-at-task='任务名' . N7 V/ t4 A4 r
7 {3 t( _# W7 X" ?& P7 u
四、playbook进阶语法& M6 G! u, B+ j6 ]
1.引用变量
c" `% M4 Z6 }, h/ G" H. Z(1)自定义变量. ]" L: n" D7 t; ~6 E
编写文件 ?: J* U d8 b, w
2 e$ ]; ~& _4 l" Y; n1 @6 u: k' B" X: V3 ^) h! b/ _
+ B6 Z7 A+ a& W4 O7 S& f5 U
运行playbook- K/ N7 v O. V7 y. Z; @
, S3 f, u! x& {$ K1 h! k
1 U4 j+ i: O/ w% ^2 W
0 w. z% W) Q7 b查看结果
8 v8 Z9 q! k0 S( u
3 {% V6 T6 k( {: @7 ~
- y% R' ]6 g0 }+ c; C1 n( q$ s$ [ b% Z0 C7 p) {# ?- O8 j
(2)引用setup模块信息中的变量
: ?8 Q- v( u5 T$ e2 e* A编写文件+ B8 g( D1 z+ \. _7 `) C0 v! I
: z3 K$ j' j6 l; N- l. _
% o8 t/ Y/ W1 R
- @. L3 s! c- b- w3 C! q运行playbook
I7 I9 L$ A" Q
# E; B+ v3 A0 k* D( [8 { \$ z* F( G/ n* ~
/ B; s" [" B0 O- @0 i4 d查看结果6 S4 j0 ?9 G$ ?4 ~1 X
! \' ^5 ?0 L/ X* }9 `( c7 y3 f# U+ k1 x" c( `: W* ~
T9 W* [- r4 U+ l
2.遍历值0 D7 F3 G$ w& Y: O$ ?2 X- `
Ansible提供了很多种循环结构,一般都命名为with_items,作用等同于 loop 循环。
; J9 m4 p* m* g3 c, _
3 a' D* R1 s! cwith_items:将每个列表中所有值遍历输出。
2 _9 l# }, a' _* [% @6 j- t
1 P5 x4 v7 U. \) I& C: \with_list:将每个列表作为一个整体输出。' A9 A3 d( ]7 S; I/ Q* u# H1 L
0 d7 {0 e# s/ b6 H6 ]/ u
with_together:将每个列表中对应的值混合输出,如果个数不一致,将无法混合输出的值用null值填补组合的空缺。3 a% N( }; }% a/ b( x; t
2 B: e b$ u: X5 ^- [) V/ p* y9 P6 n
with_nested:将每个列表中的每个值组合输出,类似多重循环。! C* o$ B$ C# N# x5 I' v/ i0 {
) K+ T' [) B5 l- A6 ?1 p( [
(1)遍历变量中的值
: k- ^$ `' }) i8 x) B u2 ]* @" I1 `
0 ?$ W0 \( Z$ z8 T- J# m+ @2 ~& U2 f3 A1 u' v6 v
7 l) h b; |9 L7 Y$ X- V7 Z(2)遍历指定的多个值4 F# b9 p9 w4 A% C
; Y0 {$ I3 S x$ _1 E
' k1 ~& x7 w# k
指定方式,也可以是列表的格式+ ^% i3 K) r- p& i9 C6 R9 Y( v6 I
) M: F: p/ y0 Z* Z+ j$ R3 j L
5 [# I2 N ?* q% Y3 ?* u. K0 d+ E' P$ a1 g- y( H
(3)遍历参数列表0 S- f; R, i7 v) s/ R( a7 f
( D, ] e1 E+ b3 ~ z; m% k$ s' B: A3 [4 }2 h+ r
格式也可以是 - {username: zhangsan, filename: 1.txt}
! @3 K+ u7 F4 y% V k+ }( q! x9 y4 ~1 i: S. |/ o* M
, u2 Q3 _' k3 \0 L q" a
/ k3 s' V' U; V3.条件判断
* h/ q& B; K* A0 g i7 n- r 在Ansible中,提供的唯一一个通用的条件判断是when指令,当when指令的值为true时,则该任务执行,否则不执行该任务。
6 L9 R/ U5 p& y! y
; C( g; m o/ e! N- ` when一个比较常见的应用场景是实现跳过某个主机不执行任务或者只有满足条件的主机执行任务。
/ b3 z) a( T4 M0 H) _( @! w5 E
' I9 u! U. a7 g/ kwhen: ansible_default_ipv4.address 条件表达式 "ip地址"
% {2 Z) P4 c! H0 dwhen: inventory_hostname 条件表达式 "主机名"- k6 N$ P7 ?9 q' p" }% W. s
( [0 N9 o9 C9 o6 e
7 h8 o7 y; D. E; L# a1 @3 O& A# L3 a U8 V
( H) \" K/ |9 Z" K/ u D4 s+ A b
; ?; ^+ u6 v1 C6 g) J
4.指定远程主机sudo切换用户
7 J9 U. }1 u% i7 c# u: U当ssh不允许root用户登录时,打开普通用户sudo提权 4 l* G) c$ c/ Z8 X8 P+ r
& D$ p t. [% K0 X3 x& U
m2 A# d- P9 K6 n2 J' ^
3 S+ T3 K0 G4 c. i9 I7 T% P5.tags 模块 ) n9 W( u( f- u; ~/ k9 O+ R% f
可以在一个playbook中为某个或某些任务定义“标签”,在执行此playbook时通过ansible-playbook命令使用--tags选项能实现仅运行指定的tasks。
9 I# ]* h" \4 V0 M$ Y4 N; z" |+ j: V% |; w
playbook还提供了一个特殊的tags为always。作用就是当使用always作为tags的task时,无论执行哪一个tags时,定义有always的tags都会执行。
8 r) o% {; Q" d. Q) A* V7 A! b7 y
0 ^) W+ ^5 s0 x- _! q ?* J# A0 U3 N
3 B) ^# w. K. C% T9 ^2 A- P6 E5 J$ \8 \4 ]+ X! x
/ I9 R. n9 V1 e5 U/ T2 x
* R6 f4 g7 @6 y" ?$ A8 I
! O# K5 }! p! F* L9 |8 E& m& Y! ~& \. J7 V [' J& a7 x$ _- K; }
, T& ^ W4 k# d0 n
7 G' f+ ~$ J, }
- ~* i; y, i* x$ [ |
|