当前位置: 首页 > news >正文

Ansible:远程自动化运维

Ansible:远程自动化运维

Ansible

是基于python开发的配置管理和应用部署工具。也是自动化运维的重要工具。可以批量配置,部署,管理上千台主机。只需要固定在一台主机配置ansible就可以完成其他主机的操作

操纵模式

1.1 模块化操作,命令行执行

1.2 playbook,剧本,也是把命令行脚本化,脚本的格式yaml格式

幂等性

ansible特性:幂等性

幂等性:多次操作或者是多次执行,对系统的影响不会发生变化,无论执行对多少次结果都是一样的

ansible什么都不会做

四大组件

1.1 Inventory(主机清单):主机组,必须要声明管理主机的地址或者其他配置,不声明ansible无法对目标主机进行操作

1.2 modules(模块):学习核心。ansible的功能是靠模块来实现的

1.3 插件

1.4 playbooks(剧本):脚本(复用)

安装及模块

语法:命令行

192.168.100.12 ansible

192.168.100.13 被管理端

192.168.100.14 被管理端

同时
systemctl stop firewalld
setenforce 0
df -htest2
yum -y install epel-release
yum -y install ansible
cd /etc/ansible
vim hosts
20 取消注释[web]
23 192.168.100.13
33 [xy102]
37 192.168.100.14
wq!ssh-keygen -t rsa
# 一路回车sshpass -p '123' ssh-copy-id root@192.168.100.13sshpass -p '123' ssh-copy-id root@192.168.100.14ansible-doc -l  # 列出ansible所有已安装的模块(支持的模块)
q   # 退出

模块和语法

第一个模块:command

基础模块,也是ansible的默认模块,不支持管道符和重定向操作,执行一般的linux命令

ansible <组名/ip地址> -m 指定模块,不加-m,默认使用command,-a <参数或者命令>ansible 192.168.100.13 -m command -a "date"
yes  # 报错再执行sshpass -p '123' ssh-copy-id root@192.168.100.13ansible 192.168.100.14 -m command -a "date"
yes  # 报错再执行sshpass -p '123' ssh-copy-id root@192.168.100.14# 集群执行
ansible [web] -m command -a "date"# host里面所有都执行
ansible all -m command -a "date"需要交互的、动态查看、解压都不可以、静态可以--幂等性

常用参数:

chdir:在目标主机提前进入目录,然后执行指令

ansible 192.168.100.13 -a "chdir=/home ls ./"
# 先进入home再执行./(./可不加),chdir相当于cd切换目录

creates:判断文件是否存在,如果存在就不执行后面的指令

test3
touch 123test2
ansible 192.168.100.13 -a "creates=/opt/123 ls /opt"
# 会告诉你存在,不执行后面操作

removes:判断文件是否存在,如果存在,执行指令

ansible 192.168.100.13 -a "removes=/opt/123 ls /opt"

解压

ansible 192.168.100.13 -a "tar -xf /opt/nginx-1.22.tar.gz -C /opt"ansible 192.168.100.13 -a "chdir=/opt tar -xf nginx-1.22.tar.gz "

第二个模块:shell模块

支持管道符和重定向,也可以用逻辑表达式 &&且 ;逻辑或

ansible 192.168.100.14 -a “useradd test" ansible 192.168.100.14 -m shell -a "echo 123456 | passwd --stdin test"ansbile 192.168.100.14 -m shell -a "echo 123 > /opt/123"ansible 192.168.100.14 -m shell -a "cat /opt/123"

多个命令连在一块

ansible 192.168.100.14 -m shell -a "touch /opt/123.txt && echo 123 > /opt/123.txt && cat /opt/123.txt"
# 会有警告的提示

目标主机创建一个脚本,在脚本中写#!/bin/bash ifconfig 然后运行脚本,在一条命令完成

ansible 192.168.100.14 -m shell -a 'echo -e "#!/bin/bash\nifconfig" > /opt/test.sh && sh /opt/test.sh'

第三个模块:cron模块

定时任务模块 minute/hour/day/mouth/weekday 分/时/日/月/周

ansible 192.168.100.13 -m cron -a 'minute=30 hour=8 day=* job="ls /opt"'
# job=表示定时任务执行的命令ansible 192.168.100.13 -a 'crontab -l'  # 查看创建的定时任务ansible 192.168.100.13 -m cron -a 'minute=30 hour=8 day=3 month=9 job="ls /opt" name="test"'

删除定时任务

ansible 192.168.100.13 -m cron -a 'name="test" state=absent'ansible 192.168.100.13 -m cron -a 'name="None" state=absent'
# 会将None全部删除,所以在创建定时任务的时候一定要指定名字

第四个模块:user模块

用户管理模块

第一个参数:name(必选参数)
state=present|absent present 创建  absent 删除
system=yes|no  创建用户时,是否为系统账号,no是普通用户,yes是程序用户
uid:指定用户的uid
group:指定用户组
shell:默认系统用户不加(/bin/bash)
create_home=yes|no  不是默认的家目录/home。/opt/test1家目录,create_home=yes创键,no就是不创建
password:用户添加密码
remove=yes|no  state=absent删除用户,删除用户时是否删除家目录
ansible 192.168.100.13 -m user -a 'name=xy102 system=no'ansible 192.168.100.13 -m user -a 'name=xy77 uid=900 shell=/sbin/nologin system=yes'ansible 192.168.100.13 -m user -a 'name=xy77 home=/opt/xy77 create_home=yes password=123456'删除
ansible 192.168.100.13 -m user -a 'name=xy77 state=absent'ansible 192.168.100.13 -m user -a 'name=xy77 remove=yes state=absent'

第五个模块:copy模块

copy复制模块,把指定主机的文件复制到目标主机

cd /opt
touch xy102.txt
echo 123 > xy102.txt
ansible 192.168.100.14 -m copy -a 'src=/opt/xy102.txt dest=/opt/'

src表示源文件

dest目标主机的保存路径

mode复制文件时 表示权限

owner文件的所有者 属主

group文件所在组 属组

content指定复制的内容,就不能用src

ansible 192.168.100.14 -m copy -a 'src=/opt/xy102.txt dest=/opt/ mode=640'ansible 192.168.100.14 -m copy -a 'src=/opt/xy102.txt dest=/opt/ mode=640 owner=dn group=dn'
# 这个用户在目标主机必须提前存在
ansible 192.168.100.14 -m copy -a 'content="黑神话:悟空,真好玩" dest=/opt/houzi.txt mode=777 owner=dn group=dn'# 远程把houzi.txt改成 孙悟空.txt
(1)使用command模块
ansible 192.168.100.14 -a 'mv /opt/houzi.txt /opt/孙悟空.txt'(2)使用shell模块
ansible 192.168.100.14 -m shell -a 'mv /opt/孙悟空.txt /opt/猪八戒.txt'

第六个模块:file模块

设置文件属性

mode owner group state=touch|absent touche创建 absent删除

ansible 192.168.100.13 -m file -a 'path=/opt/abc.txt state=touch mode=777 owner=dn group=dn'
ansible 192.168.100.13 -m file -a 'path=/opt/abc.txt.link src=/opt/abc.txt state=link'删除
ansible 192.168.100.13 -m file -a 'path=/opt/abc.txt.link state=absent'

第七个模块:hostname模块

设置远程主机的主机名

ansible 192.168.100.13 -m hostname -a "name=nginx1"
su 刷新

第八个模块:ping模块

看success表示成功

ansible all -m ping

第九个模块:yum模块

yum模块只能安装和卸载软件

ansible 192.168.100.13 -m yum -a 'name=httpd'  # 安装ansible 192.168.100.13 -m yum -a 'name=httpd state=absent' # 卸载

第十个模块:server模块

管理模块,用来管理目标主机软件的运行状态

name 服务名称

state=started|stopped|restarted

enabled=true 开机自启

runlevel=40 运行级别 如果设置了开机自启,就需要声明运行级别

ansible 192.168.100.13 -m yum -a 'name=nginx'  # 安装软件ansible 192.168.100.13 -m service -a 'name=nginx enabled=true state=started runlevel=60'  # 管理

1、安装nginx

2、开启nginx、开机自启

3、访问nginx,访问内容是this is nginx1

ansible 192.168.100.13 -m shell -a 'echo "this is nginx1" > /usr/share/nginx/html/index.html && curl 192.168.100.13'   # 访问nginx,访问内容是this is nginx1

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • EmguCV学习笔记 VB.Net 6.1 边缘检测
  • 深入探讨 C++ 中的 `constexpr` 函数及其限制
  • UE5.4 - 编辑器页面和概念术语
  • 达梦数据库表结构导出到 Excel 教程
  • 【hot100篇-python刷题记录】【字母异位词分组】
  • 基于YOLOv8的船舶目标检测与分割(ONNX模型)
  • ASP.NET Core 6.0 传统鉴权配置
  • Docker 推送镜像到私有仓库【真实案例】
  • 【Oracle19c】手工数据统计信息并导入dmp数据
  • LeetCode128.最长连续序列
  • select模型实现TCP聊天室
  • 聚星文社推文软件
  • Qt/QML学习-ScrollView
  • 【TS】函数重载的作用
  • 超简单亿图图示安装教程/快速入门指南及快捷键大全
  • 《Java编程思想》读书笔记-对象导论
  • 《深入 React 技术栈》
  • css的样式优先级
  • CSS居中完全指南——构建CSS居中决策树
  • Fabric架构演变之路
  • Go 语言编译器的 //go: 详解
  • mysql 5.6 原生Online DDL解析
  • PhantomJS 安装
  • spring + angular 实现导出excel
  • webgl (原生)基础入门指南【一】
  • 彻底搞懂浏览器Event-loop
  • 聊聊directory traversal attack
  • 码农张的Bug人生 - 见面之礼
  • 什么软件可以提取视频中的音频制作成手机铃声
  • 手机端车牌号码键盘的vue组件
  • 微信如何实现自动跳转到用其他浏览器打开指定页面下载APP
  • 微信小程序设置上一页数据
  • 以太坊客户端Geth命令参数详解
  • 阿里云重庆大学大数据训练营落地分享
  • 微龛半导体获数千万Pre-A轮融资,投资方为国中创投 ...
  • ​​​【收录 Hello 算法】9.4 小结
  • ​插件化DPI在商用WIFI中的价值
  • ​创新驱动,边缘计算领袖:亚马逊云科技海外服务器服务再进化
  • ​总结MySQL 的一些知识点:MySQL 选择数据库​
  • #Linux(make工具和makefile文件以及makefile语法)
  • $.each()与$(selector).each()
  • (13)Latex:基于ΤΕΧ的自动排版系统——写论文必备
  • (2)(2.4) TerraRanger Tower/Tower EVO(360度)
  • (2)关于RabbitMq 的 Topic Exchange 主题交换机
  • (Charles)如何抓取手机http的报文
  • (iPhone/iPad开发)在UIWebView中自定义菜单栏
  • (ZT) 理解系统底层的概念是多么重要(by趋势科技邹飞)
  • (二)什么是Vite——Vite 和 Webpack 区别(冷启动)
  • (附源码)springboot青少年公共卫生教育平台 毕业设计 643214
  • (论文阅读31/100)Stacked hourglass networks for human pose estimation
  • (三)SvelteKit教程:layout 文件
  • (一)VirtualBox安装增强功能
  • (转载)在C#用WM_COPYDATA消息来实现两个进程之间传递数据
  • .cn根服务器被攻击之后
  • .net core 控制台应用程序读取配置文件app.config