Ansible安装与模块管理
发表于:2024-11-20 作者:千家信息网编辑
千家信息网最后更新 2024年11月20日,Ansible简介Ansible可以同时管理Redhat系的Linux,Debian系的Linux,以及Windows主机。管理节点只在执行脚本时与远程主机连接,没有特别的同步机制,所以断电等异常一般
千家信息网最后更新 2024年11月20日Ansible安装与模块管理
Ansible简介
- Ansible可以同时管理Redhat系的Linux,Debian系的Linux,以及Windows主机。管理节点只在执行脚本时与远程主机连接,没有特别的同步机制,所以断电等异常一般不会影响ansbile。
Ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。Ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,Ansible只是提供一种框架。主要包括:
1、连接插件connection plugins:负责和被监控端实现通信;
2、host inventory:指定操作的主机,是一个配置文件里面定义监控的主机;
3、各种模块核心模块、command模块、自定义模块;
4、借助于插件完成记录日志邮件等功能;
5、playbook:剧本执行多个任务时,非必需可以让节点一次性运行多个任务。- Ansible的架构:连接其他主机默认使用ssh协议
Ansible环境安装部署
服务器角色 | IP地址 |
---|---|
Ansible管理端 | 192.168.142.120 |
Ansible被管理端01 | 192.168.142.121 |
Ansible被管理端02 | 192.168.142.122 |
- 安装epel源
yum install -y epel-release
- 安装Ansible服务
yum install ansible -y
- 查看Ansible版本
ansible --version
- 安装tree服务
yum install tree -y
- 树状结构展示文件夹
tree /etc/ansible/
/etc/ansible/├── ansible.cfg #ansible的配置文件├── hosts #ansible的主仓库,用于存储需要管理的远程主机的相关信息└── roles
- 切换Ansible工作目录下
cd /etc/ansible
- 配置主机清单
vim hosts[webserver]192.168.142.121[mysql]192.168.142.122
- 配置密钥对验证
ssh-keygen -t rsa
- 秘钥对传送
ssh-copy-id root@192.168.142.121ssh-copy-id root@192.168.142.122
Ansible命令行模块
- command模块
命令格式:
ansible [主机] [-m 模块] [-a args]
#列出所有已安装的模块 注:按q退出ansible-doc -l#-s列出yum模块描述信息和操作动作ansible-doc -s yum
- 查看对方系统时间
#指定ip执行dateansible 192.168.142.121 -m command -a 'date'#指定分类执行dateansible webserver -m command -a 'date'#免交互执行dateansible mysql -m command -a 'date' #所有hosts主机执行date命令ansible all -m command -a 'date'#如果不加-m模块,则默认运行command模块ansible all -a 'ls /'
- cron模块
两种状态(state):present表示添加(可以省略),absent表示移除
#查看cron模块信息ansible-doc -s cron#创建计划性任务ansible webserver -m cron -a 'minute="*/1" job="/bin/echo heihei" name="test cron job"'#查看计划性任务ansible webserver -a 'crontab -l'#移除计划任务,假如该计划任务没有取名字,name=None即可ansible webserver -m cron -a 'name="test cron job" state=absent'
- user模块
user模块是请求的是useradd, userdel, usermod三个指令
#查看user模块信息ansible-doc -s user#创建用户test01ansible mysql -m user -a 'name="test01"'#查看用户信息ansible mysql -m command -a 'tail /etc/passwd'#删除用户test01ansible mysql -m user -a 'name="test01" state=absent'
- group模块
group模块请求的是groupadd, groupdel, groupmod 三个指令
#查看group模块信息ansible-doc -s group#创建组ansible mysql -m group -a 'name=mysql gid=306 system=yes'ansible mysql -a 'tail /etc/group'#创建用户并添加到组ansible mysql -m user -a 'name=test01 uid=306 system=yes group=mysql'#查看用户信息ansible mysql -a 'tail /etc/passwd'ansible mysql -a 'id test01'
- copy模块
#查看copy模块信息ansible-doc -s copy#复制文件ansible mysql -m copy -a 'src=/etc/fstab dest=/opt/fstab.back owner=root mode=640'#查看opt目录ansible mysql -a 'ls -l /opt'#查看fstab.back文件ansible mysql -a 'cat /opt/fstab.back'#将hello heihei!写入/opt/fstab.backansible mysql -m copy -a 'content="hello heihei!"dest=/opt/fstab.back'#再查看fstab.back文件ansible mysql -a 'cat /opt/fstab.back'
- file模块
#查看file模块信息ansible-doc -s file#创建用户ansible mysql -m user -a 'name=mysql system=yes'#创建组ansible mysql -m user -a 'name=mysql system=yes'#修改文件的属主属组权限等ansible mysql -m file -a 'owner=mysql group=mysql mode=644 path=/opt/fstab.back'#设置/opt/fstab.link为/opt/fstab.back的链接文件ansible mysql -m file -a 'path=/opt/fstab.link src=/opt/fstab.back state=link'#删除一个文件ansible mysql -m file -a "path=/opt/fstab.back state=absent" #创建一个文件ansible mysql -m file -a "path=/opt/test state=touch"
- ping模块
#查看ping模块信息ansible-doc -s ping#测试被管理主机是否在线 ansible all -m ping- service模块 #查看service模块信息ansible-doc -s service#安装httpd服务yum install -y httpd#查看web服务器httpd运行状态ansible webserver -a 'systemctl status httpd' #启动httpd服务ansible webserver -m service -a 'enabled=true name=httpd state=started'#查看是否开启systemctl status httpd
- shell模块
#查看shell模块信息ansible-doc -s shell#创建用户使用无交互模式给用户设置密码ansible mysql -m shell -a 'echo abc123|passwd --stdin mysql'
- script模块
#查看script模块信息ansible-doc -s script#循环脚本vim test.sh#!/bin/bashecho "hello ansible from script"> /opt/script.txt#赋予执行权限chmod +x test.sh#执行脚本ansible mysql -m script -a 'test.sh'#在其他主机上进行查看cat /opt/script.txt
- yum模块
#查看yum模块信息ansible-doc -s yum#yum安装zshansible mysql -m yum -a 'name=zsh'rpm -q zsh#卸载zshansible mysql -m yum -a 'name=zsh state=absent'rpm -q zsh
- setup模块
#查看setup模块信息ansible-doc -s setup#获取mysql组主机的facts信息ansible mysql -m setup
模块
信息
主机
文件
用户
管理
任务
服务
运行
配置
命令
脚本
三个
功能
多个
工具
指令
插件
服务器
权限
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
牧原软件开发岗怎么样
服务器网络环境搭建
求生之路服务器修改人数
戴尔那款笔记本适合软件开发
找回历史服务器
中国电影海外票房数据库
数据库为什么要创建
长沙竟网智赢网络技术公司
服务器搭建的网站怎么访问
怎么应对网络安全
中兴软件开发哪个方向好点
金税盘怎样从数据库读取
上海涂胶机点胶软件开发
怎么搭建服务器远程访问
中国香港开源软件开发需求
有数据库的股票
新天科技智慧互联网
是服务器的服服的图片
延庆区网络技术诚信服务
英语教学课件软件开发
江苏软件开发资费
安卓上的数据库是什么
做软件开发的美女多吗
dns服务器怎么改
生物实验室网络安全对固件的优化
进销存软件开发
中国网络安全漏洞法
hcip网络安全认证
移动软件开发工程师就业
数据库技术主要用于