Ansible自动化部署工具|各个模块的使用

news2024/11/26 16:40:27

Ansible自动化部署工具|各个模块的使用

  • 一、自动化运维工具—Ansible
  • 二、安装Ansible
    • 查询webserver组中主机的日期
  • 三 Ansible常用模块
    • (1) ansible命令行模块
    • (2) command模块
    • (3) shell模块
    • (4) cron模块
    • (5) user模块
    • (6) grup模块
    • (7) copy模块
    • (8) file模块
    • (9) ping模块
    • (10) service/systemd模块
    • (11) Shell模块
    • (12)script模块
    • (13)yum模块
    • (14)setup模块
    • (15) hostname模块
  • 四、inventory主机清单
    • 4.1 inventory介绍
    • 4.2 inventory中的变量
    • 4.3 主机变量
    • 4.4 组变量
    • 4.5 嵌套组

一、自动化运维工具—Ansible

1、运维工具特点
Ansible 与 Saltstack 均是基于 Python 语言开发,Ansible 只需要在一台普通的服务器上运行即可,不需要在客户端服务器上安装客户端。因为 Ansible 是基于 SSH 远程管理,而Linux服务器大都离不开SSH,所以Ansible不需要为配置工作添加额外的支持。

Ansible 安装使用非常简单,而且基于上千个插件和模块实现各种软件、平台、版本的管理,支持虚拟容器多层级的部署。很多读者在使用 Ansible 工具时,认为 Ansible比 Saltstatck 执行效率慢,其实不是软件本身慢,是由于 SSH 服务慢,可以优化 SSH 连接速度及使用 Ansible 加速模块,满足企业上万台服务器的维护和管理。

2、Ansible运维工具原理
Ansible分为控制端和被控制端,主要是基于SSH协议去管理客户端,被控制端是不需要安装agent插件的Ansible会读取控制端的host文件 ,根据文件中定义的IP列表信息,调取本地的各个模块对被控端机器实现批量、并发的配置管理和维护,如果任务比较复杂可以写成PlayBook剧本进行分发管理。

自动运维管理工具优点

轻量级,更新时,只需要在操作机上进行一次更新即可;
采用 SSH 协议;
不需要去客户端安装 agent;
批量任务执行可以写成脚本,而且不用分发到远程就可以执行;
使用 python 编写的,维护更简单;
支持 sudo 普通用户命令;
去中心化管理。
3、Ansible自动化运维工具流程
(1)加载自己的配置文件,默认/etc/ansible/ansible.cfg
(2)查找对应的主机配置文件,找到要执行的主机或组
(3)加载自己对应的模块文件,如command yum ping
(4)通过ansible将模块命令生成对应临时py文件(pyhton),并将该文件传输至远程服务器上
(5)对应执行用户的家目录的.ansible/tmp/xxx/xxxx.py文件
(6)给文件+执行权限
(7)执行并返回结果,删除临时文件,sleep 0 退出

二、安装Ansible

管理端Ansible:192.168.10.10

被管理端:192.168.10.20
         192.168.10.30

部署Ansible自动化运维工具
yum install  -y epel-release 
#安装epel-release
yum install -y  ansible
#安装ansible
#配置文件位置:/etc/ansible/ansible
#hosts文件位置:/etc/ansible/hosts
vim /etc/ansible/hosts
#编辑hosts文件添加被管理的机器,内容如下
[webservers]
192.168.10.20
192.168.10.30
#[webservers]为一个组,组内2个服务器,添加完毕保存退出
ssh-keygen
#生成公钥,输入命令输入4个回车即可
cd ~/.ssh
sshpass -p '123123' ssh-copy-id root@192.168.10.20
sshpass -p '123123' ssh-copy-id root@192.168.10.30
#进入生成的公钥路径将公钥传输给备管理的服务器,传输需要输入每台备管理服务的root密码
ansible ansible-doc  -l 
#安装完毕,此命令可以查看有哪些ansible模块,按q退出

请添加图片描述
请添加图片描述
请添加图片描述请添加图片描述

查询webserver组中主机的日期

ansible all -m command -a 'date'          #查询所有
ansible dbservers -m command -a 'date'
ansible webservers -m command -a 'date'

请添加图片描述

三 Ansible常用模块

(1) ansible命令行模块

命令格式:ansible <组名>/ip -m <模块> -a<参数列表>

ansible-doc -s 模块

-s列出指定模块的描述信息和操作动作

(2) command模块

#此模块不能使用管道符和重定向,指定模块默认为commend模块

举例:ansible  webservers   -m   command   -a  'date'

#调用command模块在192.168.10.10服务器上执行ls命令,若不指定则默认为command模块
在这里插入图片描述

(3) shell模块

#用远程主机的shell进程,打开一个子shell进行命令操作,支持管道符和重定向

举例:ansible webservers -m shell -a 'ifconfig ens33 |awk "NR==2{print \$2}"'
ansible all -m shell -a 'ifconfig ens33 |awk "NR==2{print \$2}"'

#提取webservers组中的所有ip地址,注意双引号不识别变量所以要加转义符
请添加图片描述

(4) cron模块

#远程主机定义计划任务,2种状态present(添加)和absent(移除),默认为present。

常用参数:minute/hour/day/month/weekday:分/时/日/月/周

job:任务计划要执行的命令

name:任务计划的名称

举例:ansible  webservers -m cron  -a 'name=crontest hour="*/12"  day="*/1" job="/usr/bin/echo   cron test "   ' 

  ansible webservers -m cron -a "name=crontest  state=absent"

请添加图片描述
请添加图片描述

(5) user模块

#用户管理模块

常用参数:name:用户名;shell:用户默认shell;uid:指定用户uid;group:指定用户基本组

         state:账户状态present增加/absent删除;system:是否为系统用户yes/no;

         move_home:yes/no若创建用户的家目录存在是否移动;

        remove:yes/no当state=absent时是否删除家目录;

        passwd:指定用户的密码;comment:用户的注释信息

举例:

 ansible webservers -m user -a 'name="crontest"  uid="10086"  group="root"'

 ansible webservers -m user -a 'name=crontest    state=absent  remove=yes'

在这里插入图片描述

(6) grup模块

#用户组模块

常用参数: name:组名称 gid:组id system:是否为系统组

(7) copy模块

#复制文件或输出内容到被控制服务器上

常用参数:

mode:指出复制时,目标文件的权限

owner:指出复制时,目标文件的属主(对面无此组或此主会报错)

group:指出复制时,目标文件的属组

dest=‘路径’:目标文件路径

src=‘路径’:源文件路径

content=‘字符串内容’:将字符串内容复制到到目标文件中,等于重定向即覆盖,不能与src同用

举例:  ansible dbservers -m copy -a 'src=/etc/fstab dest=/opt/fstab.bak'
       ansible dbservers -a 'cat /opt/fstab.bak'
       ansible webservers -m copy   -a 'content="123456"  dest=/opt/a.txt'
       ansible webservers -a 'cat /opt/a.txt'
 

请添加图片描述
请添加图片描述

(8) file模块

文件属性管理模块

常用参数:owner:文件的属主;group:文件属组;mode:文件权限;path:文件路径

                   指定的属主和属组不存在会报错
举例:  
ansible dbservers -m user -a 'name=dbservers system=yes'
ansible dbservers -m file -a 'owner=dbservers group=dbservers mode=600 path=/opt/fstab.txt'

创建一个boa的文件,并添加软连接
ansible dbservers -m copy -a 'content="boa is good student" dest=/opt/boa.txt'
![请添加图片描述](https://img-blog.csdnimg.cn/e30dde2532eb4df2871d2f64e57b899e.png)

ansible dbservers -m file -a 'src=/opt/boa.txt path=/opt/boa.txt.link state=link'
ansible dbservers -a 'ls -l /opt'

请添加图片描述
请添加图片描述

(9) ping模块

检测ansible与被控端的网络连通性

举例:

ansible  webservers  -m ping 
 ansible all -m ping

在这里插入图片描述

(10) service/systemd模块

用于管理远程主机上的管理服务的运行状态
在192.168.10.20192.168.10.30上安装httpd
ansible dbservers -a 'systemctl status httpd'
ansible dbservers -m service -a 'enabled=true name=httpd state=started'
回到dbservers192.168.10.30主机验证
systemctl status  httpd
systemctl is-enabled httpd

请添加图片描述
请添加图片描述

(11) Shell模块

在远程主机执行命令,相当于调用远程主机的shell进程,然后再该shell下打开一个子shell运行命令

ansible dbservers -m user -a 'name=boa'
ansible dbservers -m shell -a 'echo 123123 | passwd --stdin boa'

请添加图片描述

(12)script模块

实现远程批量运行本地的shell脚本

ansible服务器:
vim  /opt/test.sh
#编写/下的test.sh脚本内容如下
#!/bin/bash
echo  "this is test" >/opt/script.txt
chmod +x /opt/test.sh
ansible webservers -m script -a "/test.sh"
ansible webservers -a 'cat /opt/script.txt'

请添加图片描述

(13)yum模块

在远程主机上yum安装与卸载软件包

常用参数:name:指定要安装卸载的软件;state=present/absent,默认persent添加,absent卸载

举例:ansible   webservers  -m  yum  -a  "name=httpd"

请添加图片描述

(14)setup模块

setup 模块可以获取这些信息 facts 组件收集d 被管理节点信息

参数:filter 过滤可配合正则表达式。

ansible webservers -m setup -a 'filter=*ipv4'
ansible dbservers -m setup   #查看所有信息

在这里插入图片描述

(15) hostname模块

修改被控制端的主机名

参数:name:指定被控端的主机名

举例:
ansible  webservers -m hostname -a "name=ansible"
ansible dbservers -m hostname -a "name=mysql01"
 

在这里插入图片描述

四、inventory主机清单

4.1 inventory介绍

hosts配置文件位置:/etc/ansible/hosts

Inventory支持对主机进行分组,每个组内可以定义多个主机,每个主机都可以定义在任何一个或多个主机组内。

4.2 inventory中的变量

ansible_host ansible连接节点是的IP地址。
ansible_port 连接对方的端口号,ssh连接时默认为22。
ansible_user 连接对方主机时使用的主机名,将使用执行ansible或ansible-playbook命令的用户。
nsible_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_becom_password 提升为指定用户权限时的密码。

4.3 主机变量

[webservers]
192.168.10.20 ansible_port=22  ansible_user=root  ansible_password=abs123

4.4 组变量

[webservers:vars]  #表示为webservers组内所有主机自定义变量
ansible_user=root
ansible_password=abc123

[all:vars]          #表示为所有组内的所有主机自定义变量
ansible_port=22

4.5 嵌套组

[nginx]
192.168.10.10
192.168.10.20
192.168.10.30

[apahce]
192.168.10.1[0:3]

[webs:children]  #表示为webs主机组中包含了nginx和apache组内所有主机
apache
nginx

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/475374.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

内网穿透NPS和宝塔Nginx配合使用,开启SSL访问本地局域网网络

并非为了教学&#xff0c;仅供自己记录&#xff0c;方便下次用。所以内容不会刻意花时间写的很细节详细。 1. 服务器NPS配置 NPS install安装后&#xff0c;配置文件会在其他位置&#xff0c;通过是 /etc/nps/nps.conf目录。 找到进行修改&#xff0c;主要修改的是http_proxy_p…

【flask】三种路由和各自的比较配置文件所有的字母必须大写if __name__的作用核心对象循环引用的几种解决方式--难Flask的经典错误

三种路由 方法1&#xff1a;装饰器 python C#, java 都可以用这种方式 from flask import Flask app Flask(__name__)app.route(/hello) def hello():return Hello world!app.run(debugTrue)方法2: 注册路由 php python from flask import Flask app Flask(__name__)//app…

【以太坊 Solidity】管理员读写权限/访问控制/角色控制

摘要 在 Solidity 语言的多继承中&#xff0c;若多个合约共同继承一个父合约&#xff0c;则这多个合约 共享 父合约中的变量和函数。 1.测试的智能合约 合约继承路线如下&#xff1a; #mermaid-svg-DtimeTjOch5CJh50 {font-family:"trebuchet ms",verdana,arial,s…

应用,auto,内联函数

6.引用&#xff1a; //指针 int main() {int a 0;int& b a;int& c b;int& d c;cout << &a << endl;cout << &b << endl;cout << &c << endl;cout << &d << endl;b;d;cout << a <<…

WEB攻防通用漏洞跨域CORS资源JSONP回调域名接管劫持

目录 一、同源策略&#xff08;SOC&#xff09; 二、跨域资源&#xff08;COSP&#xff09; 三、回调跨域&#xff08;JSOP&#xff09; 四、CORS资源跨域-敏感页面原码获取 五、JSONP 回调跨域-某牙个人信息泄露 六、子域名劫持接管 一、同源策略&#xff08;SOC&#x…

C#手麻系统源码, 基于前端Winform+后端WCF +sqlserver 开发

手麻系统源码&#xff0c;自动生成电子单据 基于C# 前端框架&#xff1a;Winform后端框架&#xff1a;WCF 数据库&#xff1a;sqlserver 开发的手术室麻醉临床信息系统源码&#xff0c;应用于医院手术室、麻醉科室的计算机软件系统。该系统针对整个围术期&#xff0c;对病人…

Buffer Pool介绍

Buffer Pool基本概念 Buffer Pool&#xff1a;缓冲池&#xff0c;简称BP。其作用是用来缓存表数据与索引数据&#xff0c;减少磁盘IO操作&#xff0c;提升效率 Buffer Pool由 缓存数据页(Page) 和 对缓存数据页进行描述的控制块 组成, 控制块中存储着对应缓存页的所属的 表空…

English Learning - L3 综合练习 1 VOA-Color 2023.04.26 周三

English Learning - L3 综合练习 1 VOA-Color 2023.04.26 周三 主题整体听一遍精听句子 1扩展 way of doing | way to do sth 句子 2扩展 Expression扩展 base 句子 3句子 4扩展 red-hot 句子 5句子 6扩展 fiery 句子 7句子 8句子 9句子 10句子 11扩展 born 句子 12句子 13句子…

Haar特征和级联分类器目标检测介绍及应用

文章目录 Haar特征和级联分类器目标检测介绍及应用1. Haar特征2. 级联分类器3. 实现步骤4.尝试训练自己的级联分类器4. 应用示例 Haar特征和级联分类器目标检测介绍及应用 Haar特征和级联分类器是一种经典的目标检测算法&#xff0c;适用于检测物体在图像中的位置、大小和姿态…

卷积神经网络算法解读

神经网络算法解读 机器学习流程&#xff1a; 数据获取特征工程建立模型评估与应用 图像数据是一个矩阵300 * 100 * 3 线性函数分类方法&#xff1a;分类&#xff08;wxb线性回归&#xff09; 损失函数&#xff1a;预测值与实际值之间的差异值 softmax分类器&#xff1a; 神…

(Python)Jupyter Notebook无法运行代码,且提示error和自动保存失败时如何操作?无法链接内核?

目录 一、报错情形 1、运行代码时跳转下一行&#xff0c;无法执行代码。 2、在修改文件名是提示失败&#xff0c;出现“error”字样。 二、深层原因 三、解决方案 四.建议使用原环境 Anaconda的Jupyter Notebook作为优秀的网页编辑器&#xff0c;非常适用于编写Python程序…

ubuntu16.04升级到20.04后报错 By not providing “FindEigen.cmake“

编译问题&#xff1a; CMake Error at modules/perception/lidar/CMakeLists.txt:14 (find_package): By not providing "FindEigen.cmake" in CMAKE_MODULE_PATH this project has asked CMake to find a package configuration file provided by "Eigen&…

黑马Redis入门到实战(基础篇)

Redis基础篇 Redis的类型和常见命令以及客户端使用 目录 1 .初识Redis 1 .1 .认识NoSQL 1 .1 .1 .结构化与非结构化 1 .1 .2 .关联和非关联 1 .1 .3 .查询方式 1 .1 .4 .事务 1 .1 .5 .总结 1 .2 .认识Redis 1 .3 .安装Redis 1 .3 .1 .依赖库 1 .3 .2 .上传安装包并解压 1 .3 .…

音视频八股文(8)-- h264 AnnexB三层结构

NALU(Network Abstract Layer Unit) ⾳视频编码在流媒体和⽹络领域占有重要地位&#xff1b;流媒体编解码流程⼤致如下图所示&#xff1a; H264简介 H.264从1999年开始&#xff0c;到2003年形成草案&#xff0c;最后在2007年定稿有待核实。在ITU的标准⾥称为H.264&#xff0c…

使用QtInstallerFramework制作安装包总结

一、linux下使用QtInstallerFramework制作安装包 4.0.1版本的QtInstallerFramework-linux-x64.run在linux中运行报错&#xff1a; libdbus-1.so.3 no version information availabe 换成3.0.4版本的就好了&#xff1a;https://download.qt.io/official_releases/qt-installer-…

GEE:MODIS计算遥感指数(NDVI、BSI、NDSI、EVI、LSWI、SIPI、EBI等)

作者:_养乐多_ 本文将介绍如何使用Google Earth Engine(GEE)进行遥感影像分析,具体地,使用MODIS数据集计算和可视化几种植被指数,以评估植被生长的状况,或者作为随机森林分类器训练需要的特征变量。 主要包括,NDVI、BSI、NDSI、EVI、LSWI、SIPI、EBI等。 NDVI(Normal…

【PCIE体系结构六】TLP路由

&#x1f449;个人主页&#xff1a;highman110 &#x1f449;作者简介&#xff1a;一名硬件工程师&#xff0c;持续学习&#xff0c;不断记录&#xff0c;保持思考&#xff0c;输出干货内容 参考书籍&#xff1a;PCI_Express体系结构导读 目录 TLP路由 地址路由 ID路由 隐式路…

介绍一款idea神级插件【Bito-ChatGPT】而且免费!

什么是Bito&#xff1f; Bito是一款在IntelliJ IDEA编辑器中的插件&#xff0c;Bito插件是由ChatGPT团队开发的&#xff0c;它是ChatGPT团队为了提高开发效率而开发的一款工具。ChatGPT团队是一支专注于自然语言处理技术的团队&#xff0c;他们开发了一款基于GPT的自然语言处理…

云原生CAx软件: HTTP基础知识汇总

随着云原生(Cloud Native)的兴起&#xff0c;面向服务架构(Service-Oriented Architecture&#xff0c;SOA)、微服务(Microservice)、容器(Container)等相关概念与技术正在逐渐影响CAx(CAD/CAE/CAM)软件的架构设计与开发。 在云原生CAx软件中&#xff0c;首先需要把系统按照功…

vue3表单输入绑定

初识表单输入绑定 vue3可以帮助我们将vue定义的变量绑定到html表单元素上&#xff0c;并且监听到html表单元素修改值时&#xff0c;会将对应的vue定义的变量修改。 <!-- 将vue3定义的text绑定给inut元素, 当input元素发生input输入事件时, 将修改vue3定义的text --> <…