目录
[管理端安装 ansible:](#管理端安装 ansible:)
[ansible 目录结构:](#ansible 目录结构:)
[ansible 命令行模块 :](#ansible 命令行模块 :)
[1.command 模块](#1.command 模块)
[指定 ip 执行 date:](#指定 ip 执行 date:)
[2.shell 模块](#2.shell 模块)
[3.cron 模块](#3.cron 模块)
[4.user 模块](#4.user 模块)
[5.group 模块](#5.group 模块)
[6.copy 模块](#6.copy 模块)
[7.file 模块](#7.file 模块)
[8.hostname 模块](#8.hostname 模块)
[9.ping 模块](#9.ping 模块)
[10.yum 模块](#10.yum 模块)
[11.service/systemd 模块](#11.service/systemd 模块)
[12.script 模块](#12.script 模块)
[13. mount 模块](#13. mount 模块)
[14. archive 模块](#14. archive 模块)
[15. unarchive 模块](#15. unarchive 模块)
[16. replace 模块](#16. replace 模块)
[17.setup 模块](#17.setup 模块)
[三.inventory 主机清单](#三.inventory 主机清单)
ansible :自动化运维工具,也叫机器管理工具。可以实现批量管理成百上千的多台主机,是应用级别的跨主机编排工具。
ansible的特性:.
1)无客户端agent的存在,不需要在被控制的节点上安装任何客户端应用。
2)通过ssh协议与被控制节点通信
3)基于模块工作的,可以通过模块实现在被控制节点上执行相应的命令操作
4)很多模块具有幂等性,即可实现多次模块操作的状态如果没有发生改变,则不会重复执行
data:image/s3,"s3://crabby-images/72b29/72b29ec978d3d129241076464d41851e46093ead" alt=""
二.部署ansible
准备三台主机,192.168.233.10控制管理端,192.168.233.20被控制端,192.168.233.30被控制端
管理端安装 ansible:
yum install -y epel-release :先安装 epel 源
data:image/s3,"s3://crabby-images/a1b70/a1b70738392426de109544f7c7986ceda01884eb" alt=""
yum install -y ansible
data:image/s3,"s3://crabby-images/2a174/2a17410eee82650fa55461f1aa93ffadfe55a938" alt=""
ansible 目录结构:
data:image/s3,"s3://crabby-images/4721d/4721d4aa096502b27adc3a2f5d50852442fd48fc" alt=""
ansible.cfg:ansible的配置文件,一般无需修改
hosts:ansible的主机清单,用于存储需要管理的远程主机的相关信息
roles/:公共角色目录
管理主机上配置主机清单:
vim hosts:
data:image/s3,"s3://crabby-images/84158/841587f2d2621b7f06fc2b76758f4d6d116d8dbb" alt=""
data:image/s3,"s3://crabby-images/2e0a8/2e0a8707f151a470126f1c109589a8a1d0b71378" alt=""
配置密钥对验证:
ssh-keygen -t rsa -P '' -f ~/.ssh/id_rsa
data:image/s3,"s3://crabby-images/bf461/bf46135d2cb03631f08fe117f6af8e4535780700" alt=""
sshpass -p '123' ssh-copy-id -o StrictHostKeyChecking=no root@192.168.233.20
sshpass -p '123' ssh-copy-id -o StrictHostKeyChecking=no root@192.168.233.30
data:image/s3,"s3://crabby-images/6d3bc/6d3bc3e4c263620fb60bc4f463fcc4bb1b472a8f" alt=""
data:image/s3,"s3://crabby-images/6782c/6782ce2c22bdf5984eff02a76354b69ec5987fbd" alt=""
ansible 命令行模块 :
命令格式:ansible <组名> -m <模块> -a <参数列表>
ansible-doc -l #列出所有已安装的模块,按q退出
data:image/s3,"s3://crabby-images/830c7/830c7747ae5d77e125aad1c364e698336e0cec76" alt=""
1.command 模块
是ansible默认模块,在远程主机执行命令,不支持管道,重定向等shell的特性。
ansible-doc -s command #-s 列出指定模块的描述信息和操作动作
data:image/s3,"s3://crabby-images/bee2c/bee2c1b249a5dd068bce6f5c0e1ebf643db04709" alt=""
指定 ip 执行 date:
ansible 192.168.233.20 -m command -a "date"
data:image/s3,"s3://crabby-images/f16e2/f16e2d3ee671638aefd899628047a9f911b27518" alt=""
指定组执行 date
ansible webservers -m command -a 'date'
ansible dbservers -m command -a 'date'
data:image/s3,"s3://crabby-images/b827f/b827fcc71444685b0d68a2fad4cfa36126ddb921" alt=""
data:image/s3,"s3://crabby-images/450e6/450e652bd47a9cd1324a33ff001ed9911910c363" alt=""
all 代表所有 hosts 主机
ansible all -m command -a 'date'
data:image/s3,"s3://crabby-images/df567/df567b770bcbc2c6c5e50b8cdb266233d4c6ea48" alt=""
如省略 -m 模块,则默认运行:
ansible all -a 'ls /'
data:image/s3,"s3://crabby-images/c60db/c60db3c930165570c3dd4aa0c69c104444104839" alt=""
常用的参数:
chdir:在远程主机上运行命令前提前进入目录
creates:判断指定文件是否存在,如果存在,不执行后面的操作
removes:判断指定文件是否存在,如果存在,执行后面的操作
ansible all -m command -a "chdir=/home ls ./"
ansible dbservers -m command -a "creates=/opt/a touch /opt/a"
ansible dbservers -m command -a "removes=/opt/a touch /opt/b"
data:image/s3,"s3://crabby-images/837f9/837f99f825a16835e73731d8f01794f95ceb7dd8" alt=""
看下30主机/opt下文件:
data:image/s3,"s3://crabby-images/4a88c/4a88cebdd1bde42b7ab71b34032566bcdd422816" alt=""
如果30主机/opt下没有a文件就会执行touch命令:
data:image/s3,"s3://crabby-images/18db1/18db15939d06e29783aea26ff95259e40806abae" alt=""
看下30主机:
data:image/s3,"s3://crabby-images/a5b10/a5b10de64c3cb5e6602f613a657b04fdc7e7feaa" alt=""
如果执行ansible dbservers -m command -a "creates=/opt/a touch /opt/b"这条命令,a文件有了就不会再执行touch命令:
data:image/s3,"s3://crabby-images/211a3/211a3903d7479cd5752c14cb25aabd81d7cc2d07" alt=""
data:image/s3,"s3://crabby-images/7d0d6/7d0d6791350400cfbcc2e91854e83125e5a9ac7e" alt=""
删除a文件:
data:image/s3,"s3://crabby-images/553a6/553a645270004447ea7eafb19518e2d955ce2435" alt=""
data:image/s3,"s3://crabby-images/bffd5/bffd594515ff79d69ae065b4ba09a466c79918a1" alt=""
ansible dbservers -m command -a "removes=/opt/a rm -rf /opt/a"
data:image/s3,"s3://crabby-images/85f87/85f87b4191bd8dc0acaae5edead9fbf7c7d4ba1d" alt=""
data:image/s3,"s3://crabby-images/d1e68/d1e680f0b0fa1d8e0f2eebf0955b0c5b31b19341" alt=""
data:image/s3,"s3://crabby-images/6b11e/6b11ea3133c0e9102b6addfc335fbca738e4a928" alt=""
data:image/s3,"s3://crabby-images/0d1ae/0d1aea2a875046f06340890ba9edcf134939bcc6" alt=""
2.shell 模块
在远程主机执行命令,相当于调用远程主机的shell进程,然后在该shell下打开一个子shell运行命令(支持管道符号等功能)
ansible-doc -s shell :查看操作
data:image/s3,"s3://crabby-images/613ec/613ecf1c9ca79bfe09a1446ed2aa8e619929bf93" alt=""
ansible dbservers -m shell -a 'ifconfig ens33 | awk "NR==2{print $2}"'
data:image/s3,"s3://crabby-images/fd18a/fd18a502041b8bb22a7db0f11e7a3675a0e485fd" alt=""
.
ansible dbservers -m shell -a 'echo aaa >/opt/b'
data:image/s3,"s3://crabby-images/7aa9b/7aa9bd55718b468b1a1cd247275683143435ce2c" alt=""
data:image/s3,"s3://crabby-images/6bc22/6bc225bbceab9d10a7c552899bf575b445259b67" alt=""
3.cron 模块
在远程主机定义任务计划。其中有两种状态(state):present表示添加(可以省略),absent表示移除。
job:任务计划要执行的命令
name:任务计划的名称
user:指定计划任务属于哪个用户,默认是root用户
ansible-doc -s cron
data:image/s3,"s3://crabby-images/2a9d2/2a9d2288de26792d7302133722e839b601f699c4" alt=""
ansible dbservers -m cron -a 'minute="*/1" job="/bin/echo helloworld" name="test crontab"'
data:image/s3,"s3://crabby-images/a984f/a984f0fca213fdfa991fdddb26aa8406d9cacc0b" alt=""
data:image/s3,"s3://crabby-images/16aef/16aef244e9ff2acf39eed8dc476f54084a9e7ef0" alt=""
删除计划:
ansible dbservers -m cron -a 'name="test crontab" state=absent'
4.user 模块
用户管理的模块:
ansible-doc -s user
data:image/s3,"s3://crabby-images/81bdf/81bdf48098dd37cfa5d595a507850c2e7f6f7091" alt=""
常用的参数:
name:用户名,必选参数
state=present|absent:创建账号或者删除账号,present表示创建,absent表示删除
system=yes|no:是否为系统账号
uid:用户uid
group:用户基本组
groups: 用户所属附加组
shell:默认使用的shell
create_home=yse|no: 是否创建家目录
password:用户的密码,建议使用加密后的字符串
remove=yes|no:当state=absent时,是否删除用户的家目录
ansible dbservers -m user -a 'name="test01" ' :创建用户
data:image/s3,"s3://crabby-images/5931b/5931be5b4db87a0ccbe3b2defaba7015db2f2d59" alt=""
data:image/s3,"s3://crabby-images/d754b/d754bd273727b8ee761b541f8ff7de5329e8d33a" alt=""
data:image/s3,"s3://crabby-images/76ae1/76ae12b1cf2d905b9e743ff3138babb34bb9e357" alt=""
ansible dbservers -m user -a 'name="test01" state=absent' :删除用户
data:image/s3,"s3://crabby-images/1141d/1141d4fe647484cdd8e02b0c12d378315c1c0a14" alt=""
data:image/s3,"s3://crabby-images/bf892/bf8928c08b5b80d188baa1827827e575a0d20f48" alt=""
data:image/s3,"s3://crabby-images/c552d/c552d108c5d802cb896f768ae7cf9a4a3d801f6d" alt=""
5.group 模块
用户组管理的模块:ansible-doc -s group
data:image/s3,"s3://crabby-images/55291/552912d80d2349526223331dcce29b9ddf3f31d6" alt=""
创建mysql组:
ansible dbservers -m group -a 'name=mysql gid=306 system=yes'
data:image/s3,"s3://crabby-images/9f6e3/9f6e3a6ba5e3dbf82cc1d057776ed21894316e9a" alt=""
data:image/s3,"s3://crabby-images/ab555/ab55595740472f2db7387f6ebbd4be2cc6665239" alt=""
将test01用户添加到mysql组中:
ansible dbservers -m user -a 'name=test01 uid=306 system=yes group=mysql'
data:image/s3,"s3://crabby-images/96e50/96e504f248ac6d1d9fa5a77222272c0a9b8a0bf2" alt=""
6.copy 模块
用于复制指定主机文件到远程主机的:
ansible-doc -s copy
data:image/s3,"s3://crabby-images/eb0ad/eb0ad0ba2d0bb56c3e84c30cd29fc6e19fe652d2" alt=""
常用的参数:
dest:指出复制文件的目标及位置,使用绝对路径,如果源是目录,指目标也要是目录,如果目标文件已经存在会覆盖原有的内容
src:指出源文件的路径,可以使用相对路径或绝对路径,支持直接指定目录,如果源是目录则目标也要是目录
mode:指出复制时,目标文件的权限
owner:指出复制时,目标文件的属主
group:指出复制时,目标文件的属组
content:指出复制到目标主机上的内容,不能与src一起使用
ansible dbservers -m copy -a 'src=/etc/fstab dest=/opt/fstab.bak owner=root mode=640'
data:image/s3,"s3://crabby-images/a5289/a5289c26d24ad3a2fafb96bb6984a1aad1e535b9" alt=""
data:image/s3,"s3://crabby-images/1715a/1715a4f0b403a37cc8305280e7b2ba7c3aac0e73" alt=""
ansible dbservers -m copy -a 'content="helloworld" dest=/opt/hello.txt'
data:image/s3,"s3://crabby-images/9a47b/9a47b1dc1a2dbe0017bc44921ee1935cc1e709ec" alt=""
data:image/s3,"s3://crabby-images/8c764/8c7642cbf52217cff49918439d99bf29e4102698" alt=""
7.file 模块
设置文件属性:
ansible-doc -s file
data:image/s3,"s3://crabby-images/d3785/d3785ef0b2ecd357a084805035dade5e68818824" alt=""
修改文件的属主属组权限等:
ansible dbservers -m file -a 'owner=test01 group=mysql mode=644 path=/opt/fstab.bak'
data:image/s3,"s3://crabby-images/e390e/e390ed417c8007a225c094f9f9378c641cf5189a" alt=""
data:image/s3,"s3://crabby-images/b85f5/b85f58ed5bdd73330850d540d819befff3ed9631" alt=""
设置/opt/fstab.link为/opt/fstab.bak的链接文件:
ansible dbservers -m file -a 'path=/opt/fstab.link src=/opt/fstab.bak state=link'
data:image/s3,"s3://crabby-images/17c66/17c66d5811cbe409d88387b07343d3c34c6bf4f5" alt=""
data:image/s3,"s3://crabby-images/82a5e/82a5eeb543778f82e005f704e5724ebb5be8953b" alt=""
创建一个文件:
ansible dbservers -m file -a "path=/opt/abc.txt state=touch"
data:image/s3,"s3://crabby-images/39823/39823e49d69ab35baef08a6c2447e281fc40905c" alt=""
data:image/s3,"s3://crabby-images/564ce/564cebd1a2a5da420cc78d22d26fe60c9b4088ad" alt=""
删除一个文件:
ansible dbservers -m file -a "path=/opt/abc.txt state=absent"
8.hostname 模块
用于管理远程主机上的主机名:
ansible dbservers -m hostname -a "name=mysql01":主机名改为mysql01
data:image/s3,"s3://crabby-images/5ffd4/5ffd4f6317647bb5fd6c6ff0ab45924303b58a1f" alt=""
data:image/s3,"s3://crabby-images/86d40/86d40a2484ec171476e619dfb1db2aded5c28dd4" alt=""
9.ping 模块
检测远程主机的连通性:
ansible all -m ping
data:image/s3,"s3://crabby-images/6bb76/6bb76637f84d9656dd7490fc4f2bd268ad34ea7f" alt=""
关闭一台,在ping:
data:image/s3,"s3://crabby-images/f7188/f71886ad2c9323d81e2d566420299ff0237ef530" alt=""
data:image/s3,"s3://crabby-images/b785b/b785beac9df896f345b79e3bd7dd82248565e706" alt=""
10.yum 模块
在远程主机上安装与卸载软件包
ansible-doc -s yum
data:image/s3,"s3://crabby-images/a0e2d/a0e2d5ef62fca296e6ac29c76792013f63452e56" alt=""
ansible dbservers -m yum -a 'name=httpd state=latest':latest表示下载最新的
data:image/s3,"s3://crabby-images/3abe5/3abe56a96cad017cfcd360602d07412e087c2cc7" alt=""
data:image/s3,"s3://crabby-images/07da5/07da5e08b288e0d5bf6de5214116838f150dec2c" alt=""
data:image/s3,"s3://crabby-images/6553d/6553d8ae93922610b2aad0efa0f809290b2e663f" alt=""
卸载服务:
ansible dbservers -m yum -a 'name=httpd state=absent'
data:image/s3,"s3://crabby-images/2b522/2b522fea26e927953eb0e4f619ed5cc811e83f4b" alt=""
data:image/s3,"s3://crabby-images/947ec/947ec124af4c717389811123f35b5d35526a2347" alt=""
11.service/systemd 模块
用于管理远程主机上的管理服务的运行状态
ansible-doc -s service
data:image/s3,"s3://crabby-images/5a739/5a73926ee08da2856a7027ee51024b88282a03ed" alt=""
常用的参数:
name:被管理的服务名称
state=started|stopped|restarted:动作包含启动关闭或者重启
enabled=yes|no:表示是否设置该服务开机自启
runlevel:如果设定了enabled开机自启去,则要定义在哪些运行目标下自启动
查看防火墙运行状态:
ansible dbservers -a 'systemctl status firewalld'
data:image/s3,"s3://crabby-images/fab9c/fab9c9f138e07c69d4dbd7bc5c90c6908d235a99" alt=""
启动服务:
ansible dbservers -m service -a 'name=firewalld enabled=true state=started'
data:image/s3,"s3://crabby-images/fe533/fe53363b6ee95c2b83eeaeef54ea02d28d88fa6c" alt=""
data:image/s3,"s3://crabby-images/bbc5f/bbc5ff1fe244099d7563472945842721aebec059" alt=""
data:image/s3,"s3://crabby-images/fc4cd/fc4cd6133cfc467e8a223ffe0bddff5da562c0e0" alt=""
关闭服务:
ansible dbservers -m systemd -a 'name=firewalld enabled=no state=stopped'
data:image/s3,"s3://crabby-images/ae66d/ae66d37c4ce10d2fc03434e83884ec18516b341d" alt=""
data:image/s3,"s3://crabby-images/2ffb5/2ffb551639cbb89630d6d9cfc3067b1cd16a8d5b" alt=""
12.script 模块
实现远程批量运行本地的 shell 脚本
ansible-doc -s script
data:image/s3,"s3://crabby-images/6afb2/6afb2e123350d2c23841aa05245278c3b93c8de1" alt=""
编写脚本;
data:image/s3,"s3://crabby-images/de6cb/de6cbce59106974f2264b49fcef062cfb8a133aa" alt=""
data:image/s3,"s3://crabby-images/7de7a/7de7a467864bd115b2a1cbea75c19b73c9c238f3" alt=""
data:image/s3,"s3://crabby-images/d49d0/d49d0642e11a1173e0a1806b47f0110f2df2c61b" alt=""
ansible dbservers -m script -a 'test.sh'
data:image/s3,"s3://crabby-images/a7782/a77820977d4142d8e7d0f11bedfa3c5c12c2ede4" alt=""
data:image/s3,"s3://crabby-images/440f4/440f477a1baee5f7a02ca954856234fd711ca55b" alt=""
13. mount 模块
挂载文件系统:
ansible-doc -s mount
data:image/s3,"s3://crabby-images/2ea43/2ea43b3e7cb69c46e203afbb3c295a1afd12ae25" alt=""
常用的参数:
src:定义挂载设备的路径
path:定义挂载到哪个目录,必须指定
fstype:指定挂载文件的系统类型,必须指定,xfs、iso9660、nfs...
opts:定义挂载的参数,defaults、rw、ro...
state:定义挂载的状态,mounted(进行挂载,修改/etc/fstab信息)、absent(永久性卸载,并修改 /etc/fstab信息)、unmounted(临时卸载,不修改/etc/fstab信息)
ansible dbservers -m mount -a 'src=/dev/sr0 path=/mnt state=mounted fstype=xfs'
data:image/s3,"s3://crabby-images/02393/023936da619c3fb16cb7fd80d7071e3688f2ad0c" alt=""
data:image/s3,"s3://crabby-images/f8a84/f8a8433e59bfefe1d8db9e8fdd041626d75ecb22" alt=""
data:image/s3,"s3://crabby-images/2285b/2285b61b01225407f84aa290bc6ca00e1afef56d" alt=""
data:image/s3,"s3://crabby-images/54ef9/54ef930edf65094612a94b0c27c95a687f19417d" alt=""
解挂载:
ansible dbservers -m mount -a "src=/dev/sr0 path=/mnt state=unmounted"
data:image/s3,"s3://crabby-images/d431b/d431b80b54653275a33753080afc4eb66d0eae03" alt=""
data:image/s3,"s3://crabby-images/70374/7037400bef23e657bb36345e66196a0e60c59ffd" alt=""
14. archive 模块
打包压缩
ansible-doc -s archive
data:image/s3,"s3://crabby-images/f9518/f9518220b393a5507396525f214a1ded0efaba6c" alt=""
常用的参数:
path: 必须参数,远程主机上需要被打包压缩的源文件/目录
dest: 打包压缩后的包文件路径(包文件的父目录必须存在);如果包文件已存在,则会被覆盖
format: 指定压缩类型,包括: bz2、gz(默认)、tar、xz、zip
remove=yes|no: 是否删除源文件
ansible dbservers -m archive -a "path=/etc/yum.repos.d/ dest=/opt/repo.zip format=zip"
data:image/s3,"s3://crabby-images/08c21/08c2158d6bbd967bfac5767795f9483129dc22e0" alt=""
data:image/s3,"s3://crabby-images/2c64d/2c64df3c062299f27d49f6bbc4d2a90a07c34afe" alt=""
remove:
data:image/s3,"s3://crabby-images/2bff1/2bff198b7b1df238da4d6836f18a03472654b22b" alt=""
data:image/s3,"s3://crabby-images/da8ac/da8ac974c0df41bbe53534ce74ef39bb36040f02" alt=""
15. unarchive 模块
解包解压缩
ansible-doc -s unarchive
data:image/s3,"s3://crabby-images/c67bf/c67bfa2558cb5dde8889a10fc1c7c6e1fac9396b" alt=""
'常用的参数:
copy:默认为 copy=yes ,拷贝的文件从 ansible 主机复制到远程主机,copy=no 表示在远程主机上寻找源文件解压
src:tar包源路径,可以是 ansible 主机上的路径,也可以是远程主机上的路径,如果是远程主机上的路径,则需设置 copy=no
dest:解压后文件的目标绝对路径
remote_src: 和 copy 功能一样且互斥,设置 remote_src=yes 表示文件在远程主机上,设置为 remote_src=no 表示文件在 ansible 主机上
ansible dbservers -m unarchive -a "src=/opt/repo.zip dest=/tmp/ copy=no"
data:image/s3,"s3://crabby-images/fdd49/fdd498425376cf9c888176258b3fa3560f3f8f6f" alt=""
data:image/s3,"s3://crabby-images/1dc94/1dc9490be12ad5c71ca46ddf74339ae2039771f6" alt=""
16. replace 模块
类似于sed命令,主要也是基于正则进行匹配和替换
ansible-doc -s replace
data:image/s3,"s3://crabby-images/a5fcd/a5fcd9423ed125aa9f778f2a29d5e4af7997184f" alt=""
常用的参数:
path:必须参数,指定要修改的文件
regexp:必须参数,指定一个正则表达式
replace:替换regexp参数匹配到的字符串
backup=yes|no: 修改源文件前创建一个包含时间戳信息的备份文件
before:如果指定,则仅替换/删除此匹配之前的内容,可以和after参数结合使用
after:如果指定,则仅替换/删除此匹配之后的内容,可以和before参数结合使用
owner:修改文件用户名
group:修改文件组名
mode:修改文件权限
vim /opt/a.txt
data:image/s3,"s3://crabby-images/c5cdd/c5cddd62f546300a878df2f044b0ab58165fe7f9" alt=""
data:image/s3,"s3://crabby-images/3f856/3f856d3344c39830e8f64815e42560c4f4929831" alt=""
匹配 333 并修改为 ccc:
ansible dbservers -m replace -a "path=a.txt regexp='33' replace='cc'"
data:image/s3,"s3://crabby-images/ad710/ad71068c118a6b8f977dfe011faf582dca3baaf3" alt=""
data:image/s3,"s3://crabby-images/6f6b0/6f6b0fd8cc35c3f0f679969fcf8d245822df4471" alt=""
匹配到任意一个或多个开头的行增加注释:
ansible dbservers -m replace -a "path=/opt/a.txt regexp='^(.*)' replace='#\1'"
data:image/s3,"s3://crabby-images/326a0/326a06323373fa11727e349f69fab80ef8e049ad" alt=""
data:image/s3,"s3://crabby-images/b4a9b/b4a9b534706cc2e7ed5f5b13418294ce6f49c1d6" alt=""
取消注释:
ansible dbservers -m replace -a "path=/opt/a.txt regexp='^#(.*)' replace='\1'"
data:image/s3,"s3://crabby-images/b4020/b402018728e681a22a0500cda4c304bf03247277" alt=""
data:image/s3,"s3://crabby-images/22757/22757fbcdc608ee7f7bcf2dfe587cfffe02e75fa" alt=""
只给a开头的行加#号:
ansible dbservers -m replace -a "path=/opt/a.txt regexp='^(a.*)' replace='#\1'
data:image/s3,"s3://crabby-images/bf49e/bf49e2002b00b73d76b45128111a80aefb4ad755" alt=""
修改2b中的2为0:
ansible dbservers -m replace -a "path=/opt/a.txt regexp='2' replace='0' after=1a"
data:image/s3,"s3://crabby-images/1d20a/1d20ac7f3252f19141e4e6eb39d4ae7a88e72d86" alt=""
data:image/s3,"s3://crabby-images/470b3/470b32aa91bf9842ff6d325618d254a0b6d9101f" alt=""
17.setup 模块
facts 组件是用来收集被管理节点信息的,使用 setup 模块可以获取这些信息
ansible-doc -s setup
data:image/s3,"s3://crabby-images/32856/32856ffdad4721ea974cacad9d3c575bccfe088b" alt=""
ansible webservers -m setup #获取mysql组主机的facts信息
data:image/s3,"s3://crabby-images/cd74c/cd74c6621b8c8eabd0e6e82e41e7cf3c1657de80" alt=""
ansible dbservers -m setup -a 'filter=*ipv4' #使用filter可以筛选指定的facts信息
data:image/s3,"s3://crabby-images/8c346/8c3460a93570837f0b6953fa999321fe63b342ca" alt=""
三.inventory 主机清单
Inventory支持对主机进行分组,每个组内可以定义多个主机,每个主机都可以定义在任何一个或多个主机组内。
data:image/s3,"s3://crabby-images/71f7b/71f7b6286616ed75ac90127082d733e204518486" alt=""
data:image/s3,"s3://crabby-images/bcf33/bcf33c8f379491b7155d2803ad1b6143e8a8e90a" alt=""
开启40主机,并做ssh免密登录:
data:image/s3,"s3://crabby-images/fa08b/fa08baafc80183956578bda97da291e3f8b2c025" alt=""
ansible dbservers -m command -a 'date'
data:image/s3,"s3://crabby-images/302a8/302a8dcd3de5e6e8fb86fd5f8a226c7d7e276f0e" alt=""
修改40主机的ssh端口号:
data:image/s3,"s3://crabby-images/0bc1a/0bc1a1bc7db9a09ccaea88fc58f48e344fa1a891" alt=""
data:image/s3,"s3://crabby-images/7d9f0/7d9f0dc259cf853aae906ac220381cc84a3f0077" alt=""
data:image/s3,"s3://crabby-images/d4e54/d4e54767bfed0483d5667f74191a98c4d04f0a44" alt=""
测试:
data:image/s3,"s3://crabby-images/e9165/e9165789f733306dcc958c805646c683964d10f9" alt=""
修改配置文件:
data:image/s3,"s3://crabby-images/9c6ca/9c6ca8f46e0350d797881c7111cc7c44ce31e079" alt=""
data:image/s3,"s3://crabby-images/f07fd/f07fd37c450e266caacc21e38b7ce2f1b5f2e630" alt=""
data:image/s3,"s3://crabby-images/b9f93/b9f93e17e7a70337bcf90ddc9bb75e9078a0cf67" alt=""
inventory 中的变量
Inventory变量名 含义
ansible_host ansible连接节点时的IP地址
ansible_port 连接对方的端口号,ssh连接时默认为22
ansible_user 连接对方主机时使用的用户名。不指定时,将使用执行ansible或ansible-playbook命令的用户
ansible_password 连接时的用户的ssh密码,仅在未使用密钥对验证的情况下有效
ansible_ssh_private_key_file 指定密钥认证ssh连接时的私钥文件
ansible_ssh_common_args 提供给ssh、sftp、scp命令的额外参数
ansible_become 允许进行权限提升
ansible_become_method 指定提升权限的方式,例如可使用sudo/su/runas等方式
ansible_become_user 提升为哪个用户的权限,默认提升为root
ansible_become_password 提升为指定用户权限时的密码
设置主机变量:
data:image/s3,"s3://crabby-images/ab792/ab792f4a6ad281f0d64d8cb6896b47e7341b6972" alt=""
data:image/s3,"s3://crabby-images/7b94a/7b94ae3b1e274bbd597dea970e7f829d2c076f0c" alt=""
data:image/s3,"s3://crabby-images/059c8/059c89e8f55f4f37a20913efbe83916daf23ee6f" alt=""
嵌套组:
data:image/s3,"s3://crabby-images/e0812/e0812c5b3d79141f4847e3b7168abc6c6ada1f2c" alt=""
data:image/s3,"s3://crabby-images/2d7d2/2d7d2b5748059cd915934e8273122c4092d08d59" alt=""
data:image/s3,"s3://crabby-images/dfca4/dfca44cb0883b85c4951e472dc5c47390ef99909" alt=""
data:image/s3,"s3://crabby-images/4236d/4236d9d91ff6db071af6748155b6b62871459618" alt=""
data:image/s3,"s3://crabby-images/3c655/3c655ba2bee796d51a33cdd926032a89b971cacd" alt=""