ansible基本概念
ansible作用
1、实现远程连接主机
2、批量配置,批量操作,ansible可以对主机进行组划分,也可以把名下所有的主机进行划分,进行批量的操作。
3、远程自动化运维(脚本------playbook)
ansible是什么
ansible是基于python语言开发的,配置管理和部署应用的工具。批量的配置、部署、管理上百台主机。
ansible只要在一台主机上就可以对其他主机进行操作。
ansible的工作模式
没有固定的客户端这一说法,不是c/s。使用模块来进行工作,ansible的模块有很多,真正在目标主机上执行任务的是模块。
ansible的特性
幂等性,计算机种的概念,在幂等操作中,无论执行多少次,结果都是一样的,多次执行相同的操作,不会产生不同的结果。
在ansible中,如果你的操作是符合幂等性,那么不会对目标主机产生额外的副作用。
ansible的组件
1、lnventory:主机清单,主机组。
2、modules:模块
3、plugins:插件
4、playbooks:剧本(脚本)
ansible的优点
- 部署快,只要能上网,或者有源码包,安装部署很简单。
- 基于yuml格式编写的脚本。
- 同一台服务器上多次执行同一个任务没有任何副作用。
ansible的缺点
- 语法要专门学
- 主机和目标主机必须都是linux,至少有两台服务器,主机和server。
安装ansible
架构
doc1:192.168.254.40,ansible
doc2:192.168.254.41
配置doc1
apt -y install ansible #下载 ansible
设置密钥对
data:image/s3,"s3://crabby-images/8e746/8e7462ff57727e9282d6bfc3dca6eaad514a74c6" alt=""
apt -y install sshpass #下载sshpass
传送密钥对
data:image/s3,"s3://crabby-images/0e714/0e71463b93a423813388a3b42227d88a648986af" alt=""
配置/etc/ansible/hosts文件,用来分主机组
data:image/s3,"s3://crabby-images/ffc83/ffc83d61f81c72e3e70b550919bdd01710780683" alt=""
data:image/s3,"s3://crabby-images/d95a7/d95a75eb3f8a0d49b54c0bccedca5507273b3138" alt=""
补充知识
data:image/s3,"s3://crabby-images/28231/2823155fd45629f523f12dbca2f8431ca89688fe" alt=""
- 表示IP地址192.168.233.10-192.168.233.19
配置文件ansible.cfg
创建两个配置文件ansible.cfg和hosts,具体配置如下
data:image/s3,"s3://crabby-images/93806/93806956764403ed7952286f74120362ee7176c3" alt=""
data:image/s3,"s3://crabby-images/44ac3/44ac3dd3d0235edaa994f74e06a3079a274c292f" alt=""
- host_key_checking = False #禁止使用ssh的密钥检查
- inventory = /etc/ansible/hosts #指定主机清单的文件
- forks = 20 #同时可以对多少主机进行配置,默认是5,可以提高执行的速度
- pipelining = True #减少对ssh会话中的操作,提高性能
- strategy = free #任务会立即对下一个主机并行执行,不用等待其他主机完成
- retry_files_enabled = False #如果任务失败,禁用自动重试的功能
data:image/s3,"s3://crabby-images/9c63e/9c63e3492235b8fc125c9b1bd7d7ae705f452ad0" alt=""
- 所有主机自动使用root用户和123密码
- 所有主机自动使用22端口
有这两个配置文件可以不需要进行设置密钥对,直接添加IP地址到相应的主机组,直接执行命令。
data:image/s3,"s3://crabby-images/d4ecc/d4eccdf7670eae4dd95227f7117cde6e71bdf3a1" alt=""
ansible模块
command模块
默认模块,就是在目标主机执行命令,不支持管道符,也不能使用重定向。
data:image/s3,"s3://crabby-images/89518/895189f0910e41a301cd1ddaba5731f66131c287" alt=""
data:image/s3,"s3://crabby-images/a8a64/a8a64224ccd5f3e6b0375b07a3e48d2d56bad260" alt=""
- ansible:固定开头
- -m:指定模块
- -a:指定参数(指定操作)
- 'date':具体要执行的命令
data:image/s3,"s3://crabby-images/06b64/06b64263d3f3036ed406d306f592d1390e4d1d37" alt=""
data:image/s3,"s3://crabby-images/27997/279973f95de0fd7f5b4e039de4daa2a1c26b1c0a" alt=""
- 无法使用cd,需要使用chdir
判断文件是否存在
data:image/s3,"s3://crabby-images/67e42/67e42d03ae865a1a23a23b7bd9919071949c3055" alt=""
- creates: 判断指定的文件是否存在,如果存在,不执行后续的操作。
- removes:判断指定的文件是否存在,如果存在,执行后面的操作。
shell模块
就是command模块的升级,但是可以使用管道符,可以重定向还可以使用连接符链接多个命令。
data:image/s3,"s3://crabby-images/879b8/879b84f48c05acb88b4afa5145fabcb2e91fa9bb" alt=""
data:image/s3,"s3://crabby-images/1783e/1783e343cd7d87f15bdf731e71273b070cf403db" alt=""
- &&:逻辑且,所有的命令都必须执行成功才算完成
- ;:逻辑或,成功一个即可
data:image/s3,"s3://crabby-images/8ddb6/8ddb6aeff52dbe9a265e5aba00b372c58a895935" alt=""
data:image/s3,"s3://crabby-images/e666f/e666f5ec7f9646e515921b49e4741f3e04cd786b" alt=""
cron模块
-m cron
minute/hour/day/month/weekday:分/时/日/月/周
name:计划任务的名称
job:计划的执行的命令
1、创建定时任务9月1号8.30执行ls /opt命令,定时任务名字是zw1
data:image/s3,"s3://crabby-images/0084e/0084ee13717db53716a5fafdb38c56713f2d7586" alt=""
2、删除定时任务zw1
data:image/s3,"s3://crabby-images/2861f/2861ff26b097f164b8debc7c297b269e1d10e917" alt=""
user和group模块
-m user
-m group
name 用户名或者组名,必有参数
state=present | absent
创建 删除
shell:默认就是/bin/bash
create_home yes | no:替换用户的家目录
remove=yes | no:删除用户时,是否删除家目录
password:创建用户的登录密码
system yes | no:表示该用户是否是系统用户
1、创建用户zw1
data:image/s3,"s3://crabby-images/0c120/0c120380cdbcd036ea7ea5765d4e1ad66fce261f" alt=""
2、修改家目录和删除用户
data:image/s3,"s3://crabby-images/ae1a6/ae1a600cce7d8b9ea11c7f0545e980358014ed5b" alt=""
3、创建组和删除组和user一样
data:image/s3,"s3://crabby-images/32290/3229030c40fcfa06860ddca8a1a36b11ecc0860a" alt=""
copy复制模块
dest:文件复制到目标主机的位置
src:源文件,要复制的文件
mode:修改目标文件权限
owner:文件的所有者
group:文件的所在组
content:复制输出的内容到目标主机,使用content就不能使用src
1、复制本机文件到目标主机目录下
data:image/s3,"s3://crabby-images/8571b/8571ba6a80a2eb20ed55077ecb78f94049142640" alt=""
2、复制内容到目标主机目录下的文件中
data:image/s3,"s3://crabby-images/a2cee/a2cee4b0f4df1ab6ab0f43609398f6d8e9756896" alt=""
3、复制本机目录到目标主机目录
data:image/s3,"s3://crabby-images/509ce/509ce14ee9c9221092c4b606e87008305877d1d2" alt=""
- 如果复制目录,源文件是目录,那么目标的路径也必须是目录才可以复制
file 模块
和copy模块有相似之处,有owner、group、mode。
path:目标主机的文件路径
state:Link做软连接,touch创建,absent删除
1、给目标主机创建文件
data:image/s3,"s3://crabby-images/968ba/968ba6675c45ff2cb5447a8f915ebe028cf9c0a8" alt=""
2、给目标主机创建软连接
data:image/s3,"s3://crabby-images/1863e/1863ee9bc2e13e34a3fd484809f56a8b0559e59b" alt=""
- src:指定创建的文件为软连接
3、给目标主机删除文件
data:image/s3,"s3://crabby-images/45c24/45c24fb57d2bf27ae77ba6bf7f93b6bb2b3b760a" alt=""
hostname模块
设置目标主机的主机名
data:image/s3,"s3://crabby-images/aad78/aad78802273cbf389b6aa285eb9259cf39047fd7" alt=""
ping模块
测试与目标主机连通性
data:image/s3,"s3://crabby-images/26f87/26f87e5a4dce42f20a1fac1c7fb9a29ee09c032e" alt=""
安装/卸载模块apt/yum
给目标主机安装软件
data:image/s3,"s3://crabby-images/0e602/0e6022f988581275cb05789b2bdcf602150c7651" alt=""
给目标主机卸载软件
data:image/s3,"s3://crabby-images/b1781/b1781021146fa547a956b13fe83d479081e018f2" alt=""
service模块
对服务状态继续控制
也可以用command模块或者shell模块完成------------systemctl
name=软件名
enabled=true------开机自启
state=started | stopped | restarted 开停 重启
1、开启目标主机的httpd服务,以及修改访问页和访问
data:image/s3,"s3://crabby-images/a6813/a68135778901c059f38ae07143fd7df8b273f0bf" alt=""
2、开启nginx服务并设置成开机自启
data:image/s3,"s3://crabby-images/a9496/a949698e1de1fc4c4766f324deda9123e67e0eb6" alt=""
iptables模块
1、禁用web1里面主机的80端口
data:image/s3,"s3://crabby-images/eec9f/eec9fa80816d9d91a668173ba8bca5c391448ebe" alt=""
2、删除上面的策略
data:image/s3,"s3://crabby-images/b88b8/b88b8237924496f7b99708e01ae31836f382cf81" alt=""
firewalld模块(centos)
1、目标主机开放80端口(TCP 协议),并将其应用于公共区域,设置为永久生效,并立即应用。
data:image/s3,"s3://crabby-images/b7172/b717206a938efce664ab5d1d2e7f4ed6fb1a89d7" alt=""
2、关闭上面的策略
data:image/s3,"s3://crabby-images/17608/176083e89ca234af23d15926720b74864c59c6e3" alt=""
script模块
指定本地的脚本,然后脚本中的命令在目标主机执行,结果也是输出到目标主机。
data:image/s3,"s3://crabby-images/71647/71647a6e3a8b4ae66cb4927378f01d1056aadbad" alt=""
setup模块
通过facts组件收集节点信息,查看目标主机的配置信息。
1、查看目标主机地址信息
data:image/s3,"s3://crabby-images/b8b14/b8b14bfb97767cf512504fcab3be0fbfb1d23a26" alt=""
2、查看目标主机cpu信息
data:image/s3,"s3://crabby-images/19d9e/19d9e0e1caf56343bec6ea790c39571c7700cf4f" alt=""
查看目标主机内核信息
data:image/s3,"s3://crabby-images/ce46c/ce46c3409a880dfa44e6fb9badc6ca51cf947d8f" alt=""