Ansible架构:

一.部署主机清单 前期环境准备:
管理端:
192.168.60.128
被管理端:
client1:192.168.60.129
client2:192.168.60.131
1.1 所有被管理端配置ssh密钥 (1.免密登陆 2.允许root远程登陆) 脚本如下:
bash
#!/bin/bash
# 检查 sshpass 是否已安装
if ! command -v sshpass &> /dev/null; then
echo "请先安装 sshpass 工具!"
exit 1
fi
# 固定的 IP 地址列表
ip_list="192.168.60.129 192.168.60.131"
# 检查并生成 SSH 密钥
if [ ! -f ~/.ssh/id_rsa ]; then
echo '----------------'
echo '1. 创建 key'
echo '----------------'
if ! ssh-keygen -f ~/.ssh/id_rsa -t rsa -P ''; then
echo "生成 SSH 密钥失败!"
exit 1
fi
else
echo "SSH 密钥已存在,跳过生成步骤。"
fi
echo '----------------'
echo '2. 分发 key'
echo '----------------'
for ip in $ip_list; do
echo "----------------"
echo "分发 key 到 $ip"
echo "----------------"
if sshpass -p2004129 ssh-copy-id -i ~/.ssh/id_rsa.pub -o StrictHostKeyChecking=no root@$ip; then
echo "分发公钥到 $ip 成功!"
else
echo "分发公钥到 $ip 失败!"
fi
done
运行效果:

1.2 控制端安装ansible
2.1安装 EPEL 源:sudo dnf install epel-release
sudo dnf install ansible
ansible --version
ok~~~~~~~~~~~~~~~~~~~~~~~~~~~

3.安装完成之后 配置主机清单~ 配置文件地址:/etc/ansible/hosts
Server1\] 为组名 将.129 和.131分配在一个组\~\~\~\~\~\~\~\~\~\~  4.测试使用: 测试1 # ansible Server1 -m ping //测试主机是否通\~\~\~\~\~\~\~\~ 出现绿色就说明通了\~\~\~\~\~\~ 测试2 # ansible Server1 -m command - a 'hostname' // -m 指定模块 -a 执行的命令 command命令执行模块  测试3 #ansible Server1 -m shell -a 'ip addr \| grep inet' **注意command不能识别管道!!!!!!**  #### **1.3 ansible 核心配置文件:** 就最前面这两个 ansible.cfg # ansible核心配置文件  hosts #主机清单 如何设置子组(就是将多个组 合并在一个组) 在host文件下这样写: \[data:children\] // children关键字 组名 组名 \~n  测试一下看 # ansible data -m ping  测试所有主机是否ping通 # ansible all -m ping  **ansibel核心模块**  如何查询命令帮助: ansible-doc -s command ansible官方文档:[Ansible Documentation](https://docs.ansible.com/ "Ansible Documentation")  模块使用: ## **二.命令脚本相关模块** **1.command** 支持简单的命令 不支持管道符号!!!! 默认模块 不写 也是他 ansible all -m command -a '命令' **2.shell模块** 支持 一些特殊的符号! ansible all -m shell -a 'ip a s ens160 \| grep inet'  **3.script模块 传输**脚本到被管理端 并执行 3.1比如我们在管理端写一个安装nmap软件脚本 脚本内容 名称:  执行命令:ansible all -m script -a '/home/test/script-ans/nmapins.sh'  看一下被控端受否安装(直接在管理端测试nmap这个工具) ansible all -m shell -a 'nmap localhost'  ## 二.文件相关模块  #### 2.1创建目录和文件  目录:ansible all -m file -a 'path=/home/ansible-test state=directory'  文件:ansible all -m file -a 'path=/home/ansible-test/hello.txt state=touch'  #### 2.2创建软连接 ansible all -m file -a 'src=/home/ansible-test/hello.txt path=/home/test/hello.txt.soft state=link'  看看是否成功:ansible all -a 'ls -l /home/test'  删除(都是加一个参数就可以 state=ansent) 删除一个文件:ansible all -m file -a 'path=/home/ansible-test/hello.txt state=absent' 注意是:state=absent 不是 state:absent  #### 案例:创建一个txt文件 所有者是:root 组:root 权限:755 ansible all -m file -a 'path=/tmp/xxw.txt state=touch group=root owner=root'  ## 三. 文件传输copy模块  ansible all -m copy -a 'src=/home/test/400.txt dest=/home/'  如果当遇到同名的文件 可以备份一下:添加参数:**backup=yes** ansible all -m copy -a 'src=/home/test/400.txt dest=/home/ backup=yes' 执行后备份路径为:  备份了原先的内容:  ## 四.服务管理模块 涉及到命令:systemctl 主要就是 服务启动 关闭 开机自/不启动。。。。 #### 1.模块名:systemctld  #### 2.案例: firewalld ##### 2.1关闭 ansible all -m systemd -a 'name=firewalld enabled=no state=stopped'  查看是否关闭: ansible all -a 'systemctl status firewalld' 注意这不是报错 服务已经关闭 注意看!!!!!  ##### 2.2开启 ansible all -m systemd -a 'name=firewalld enabled=yes state=started'  查看是否开启: ansible all -a 'systemctl status firewalld'  ## 五.磁盘挂载模块 \& 定时任务模块  ##### 1.mount 挂载nfs [NFS搭建指南](https://blog.csdn.net/weixin_47830774/article/details/146312194?spm=1001.2014.3001.5501 "NFS搭建指南") mount模块参数  1.1挂载nfs 1.2卸载nfs挂载 ansible all -m mount -a 'fstype=nfs src="192.168.60.129:/nfs-test" path=/mnt/nfs-gx129 state=absent'  ## 六.用户管理模块 user ##### 6.1参数:  ##### 6.2案例: **创建用户xxw** **普通命令**  ansible: ansible all -m user -a 'name=xxw uid=8888 shell=/bin/bash home=/home/xxw create_home=yes state=present'  **创建虚拟用户test1(不创建家目录 \&\& 命令解释器/sbin/nologin 指定uid=2004)** **普通命令: useradd -u2004 -s /sbin/nologin -M test1** **ansible:** ansible all -m user -a 'user=test2 uid=10086 shell=/sbin/nologin create_home=no state=present' 