全网最全的Ansible中常用模块讲解

news2024/12/23 17:45:04

目录

前言

一、ansible实现管理的方式

二、Ad-Hoc执行方式中如何获得帮助

三、ansible命令运行方式及常用参数

四、ansible的基本颜色代表信

五、ansible中的常用模块

1、command

2、shell

3、script 

4、copy 

5、fetch

6、file

7、 unarchive

8、archive

9、hostname

10、cron

11、yum_repository

12、dnf

13、service

14、firewalld

15、user

16、group

17、lineinfile

18、replace

19、setup

20、debug

总结


前言

本章内容主要讲解ansible中常用模块,ansible实现管理的方式、ansible命令运行方式及常用参数、ansible中的常用模块中的command、shell、script、copy、fetch、file、unarchive、archive、hostname、cron、dnf、service、firewalld、user、group、lineinfile、replace、setup、debug模块,每一个模块各自的作用。

什么是模块?

ls本身是一个命令,如果把ansible看做是一个系统的话,ls就是一个模块,模块就是别人开发好集成好的东西

一、ansible实现管理的方式

Ad-Hoc           ##利用ansible命令直接完成管理,主要用于临时命令使用场景
playbook         ##ansible脚本,主要用于大型项目场景,需要前期的规划

命令在执行时有直接执行,ansible也有直接执行的方式Ad-Hoc 

也可以写脚本,在ansible中的脚本叫做playbook 

这就是playbooks的执行方式,类似于shell中的脚本 

二、Ad-Hoc执行方式中如何获得帮助

ansible-doc         ##显示模块帮助的指令        q退出


#格式
ansible-doc [参数] [模块...]


#常用参数
-l          ##列出可用模块
-s         ##显示指定模块的playbook片段

不加s是帮助 

三、ansible命令运行方式及常用参数

#格式:
ansible 清单 -m 模块 -a 模块参数


#常用参数
#--version                                ##显示版本
#-m module                             ##指定模块,默认为command模块
#-v                                           ##详细过程 -vv -vvv更详细过程
#--list                                       ##显示主机列表,也可以用--list-hosts
#-k                                           ##提示输入ssh连接密码,默认key认证
#-C                                          ##预执行检测
#-T                                           ##执行命令的超时时间,默认10s
#-u                                           ##指定远程执行的用户
#-b                                           ##执行sudo切换身份操作
#--become-user=USERNAME  ##指定sudo的用户
#-K                                            ##提示输入sudo密码

-v显示详细信息

-vv比详细信息更详细的信息

-vvv是最详细的了

--list

-k

-C 

-T 

-u

-b 

--become-user=USERNAME,指定sudo的用户 

-K 

四、ansible的基本颜色代表信

绿色                 ##执行成功但为对远程主机做任何改变
黄色                 ##执行成功并对远程主机做改变
红色                 ##执行失败

不是绝对的

五、ansible中的常用模块

1、command

#功能: 在远程主机执行命令,此模块为默认模块


#常用参数
chdir                 ##执行命令前先进入到指定目录
cmd                  ##运行命令指定        现在已经不加了,加了可能会报错
creates             ##如果文件存在将不运行
removes           ##如果文件存在在将运行
free_form          ##在远程主机中执行的命令,此参数不需要加


注意
Linux中的很多通配符在command模块中不支持 

鼻祖级的模块,在远程主机中运行shell命令的

不支持通配符

2、shell

#功能:
#和command功能类似


#常用参数
chdir                 ##执行命令前先进入到指定目录
cmd                  ##运行命令指定
creates             ##如果文件存在将不运行
removes            ##如果文件存在在将运行
free_form          ##在远程主机中执行的命令,此参数不需要加
executable         ##指定执行环境,默认为sh

可以使用通配符

chdir

executable

3、script 

#功能:
在ansible主机中写好的脚本在受控主机中执行


#实例
vim /mnt/westos.sh
#!/bin/bash
echo $HOSTNAME
ansible all -m script -a "/mnt/westos.sh" -k

已经没有东西了

4、copy 

#功能
从ansible主机复制文件到受控主机


#常用参数
src                                 ##源文件
dest                               ##目的地文件
owner                            ##指定目的地文件所有人
group                             ##指定目的地文件所有组
mode                             ##指定目的地文件权限
backup=yes                   ##当受控主机中存在文件时备份原文件
content                          ##指定文本内容直接在受控主机中生成文件

复制成功

content

会把已经有的文件覆盖掉

backup=yes 已经有的文件需要备份

5、fetch

 #功能
从受控主机把文件复制到ansible主机,但不支持目录


#常用参数
src                 ##受控主机的源文件
dest               ##本机目录
flat                 ##基本名称功能

flat 

如果我不想要这个目录的名字

6、file

无论是copy还是fetch都是通过源来控制,如果我们希望通过属性来控制,就可以用file 

#功能
设置文件的属性


#常用参数

path                          ##指定文件名称
state                         ##指定操作状态
                                 ##touch 建立
                                 ##absent 删除
                                 ##directory 递归
                                 ##link 建立软链接
                                 #hard 建立硬链接
mode                        ##设定权限
owner                       ##设定文件用户
group                        ##设定文件组
src                            ##源文件
dest                          ##目标文件
recurse=yes             ##递归更改

建立文件时指定方式

建立成功 

建立目录时指定方式

建立成功 

建立文件时指定是链接

软链接

硬链接

mode 设定权限 

针对文件

针对于目录

创建一个file文件

想修改目录连带目录中文件的权限

7、 unarchive

#功能
解压缩


#常用参数
copy                                 ##默认为yes 从ansible主机复制文件到受控主机
                                         ##设定为no 从受控主机中寻找src源文件
remote_src                       ##功能同copy且相反
                                         ##设定为yes 表示包在受控主机
                                         ##设定为no表示包在ansible主机
src                                    ##包路径,可以使ansible主机也可以使受控主机
dest                                  ##受控主机目录
mode                                ##加压后文件权限 <copy=yes>

mode参数必须和copy参数配合使用

8、archive

#作用
压缩


#常用参数
path                                 ##打包目录名称
dest                                 ##声称打包文件名称
format                              ##打包格式
owner                              ##指定文件所属人
mode                               ##指定文件权限

9、hostname

#作用
管理主机名称,主机名修改模块


#常用参数
name                                ##指定主机名称#实例

修改主机名

  

10、cron

#作用
计划任务,设定定时任务

#常用参数
minute                                 ##分钟
hour                                     ##小时
day                                      ##天
month                                  ##月
weekday                              ##周
name                                   ##任务名称
job                                       ##任务脚本或命令
disabled                               ##yes 禁用计划任务
                                            ##no 启动计划任务
state                                    ##absent 删除计划任务

查看

disable注释

state=absent删除

 

11、yum_repository

#作用
配置系统软件仓库源文件


#常用参数
name                                    ##指定仓库名称
baseurl                                 ##指定源路径
description                            ##指定仓库描述
file                                         ##指定仓库文件名称
enabled                                 ##仓库是否启用
gpgcheck                              ##仓库是否检测gpgkey
state                                      ##默认值present 建立
                                              #absent 为删除

查看当前目录下文件

ansible all -m shell -a 'ls /etc/yum.repos.d'

添加AppStream

ansible all -m yum_repository -a 'name=AppStream file=westos baseurl=http://192.168.1.10/rhel8.6/AppStream gpgcheck=no description="AppStream" enabled=yes state=present'

注意:file=xxx时不要跟.repo的后缀,他会自动补全

添加BaseOS

ansible all -m yum_repository -a 'name=BaseOS file=westos baseurl=http://192.168.1.10/rhel8.6/BaseOS gpgcheck=no description="BaseOS" enabled=yes state=present'

取消添加

ansible all -m yum_repository -a 'name=BaseOS file=westos state=absent'

12、dnf

#作用
管理系统中的dnf仓库及管理软件


#常用参数
name                                       ##指定包
state                                        ##指定动作
                                                #present 安装
                                                #latest 更新
                                                #absent 删除
list                                            ##列出指定信息
                                                # httpd
                                                # installed
                                                # all
                                                # available
disable_gpg_check                 #禁用gpgkey检测
enablerepo                              ##指定安装包来源disablerepo ##禁用安装包来源

安装

卸载

同时卸载掉依赖性

不检测gpg

13、service

#作用
管理系统服务状态


#常用参数
name                                         ##指定服务名称
state                                          ##指定对服务的动作
                                                  #started
                                                  #stoped
                                                  #restarted
                                                  #reloaded
enabled                                     ##设定服务开机是否启动
                                                  #yes开启启动

                                                  #no开机不启动

启动服务httpd,并且开机自启

ansible all -m service -a 'name=httpd state=started enable=yes'

14、firewalld

#作用

设置火墙

#常用参数
zone                                          ##火墙的域
service                                       ##服务名称
permanent                                 ##永久生效
state
       enabled                               ##允许
       disabled                              ##拒绝
immediate                                  ##立即生效

现在不能访问因为火墙没有设定

设定火墙

 

15、user

#作用
模块可以帮助我们管理远程主机上的用户,比如创建用户、修改用户、删除用户、为用户创建密钥对等操作


#常用参数
name                                         ##必须参数,用于指定要操作的用户名称。
group                                         ##指定用户所在的基本组。
gourps                                        ##指定用户所在的附加组。
append                                       ##指定添加附加组默认值为no
shell                                           ##指定用户的默认 shell。
uid                                              ##指定用户的 uid 号。
comment                                    ##指定用户的注释信息。
state                                           ##用于指定用户是否存在于远程主机
                                                   #present 建立
                                                   #absent 删除
remove                                       ##当删除用户是删除用户家目录,默认值为nopassword ##此参数用于指定用户的密码,但密码为明文。
                                                    ##可以用openssl password -6 '密码'生成加密字符
generate_ssh_key                       ##生成sshkey

用户建立

改用户密码

填写到下面密码的部分

使用passwd -6 得到 一个加密字符串,设定给密码

更改附加组

增加附加组 

删除用户 作用相当于userdel -r

16、group

#作用
group 模块可以帮助我们管理远程主机上的组


#常用参数
name                                         ##用于指定要操作的组名称。
state                                          ##用于指定组的状态
                                                  #present 建立
                                                  #absent 删除
gid                                             ##用于指定组的gid。

创建

更改 

删除 

  

17、lineinfile

path                                         ##指定要操作的文件。
line                                          ##指定文本内容。 "|+" 表示格式化输入
regexp                                     ##使用正则表达式匹配对应的行当替换文本时
                                                ##如果有多行文本都能被匹配
                                                ##则只有最后面被匹配到的那行文本才会被替换
                                                ##当删除文本时,如果有多行文本都能被匹配
                                                ##这么这些行都会被删除。
state                                        ##当想要删除对应的文本时需要将state参数的值设置为absent
                                                #state的默认值为present。
backrefs                                   ##当内容无匹配规则时不对文件做任何更改,默认值为no
                                                 ##向后引用regexp变量信息
insertafter                                 ##借助insertafter参数可以将文本插入到“指定的行”之后
                                                 ##insertafter参数的值可以设置为EOF或者正则表达式
insertbefore                              ##借助insertbefore参数可以将文本插入到“指定的行”之前
                                                 #insertbefore参数的值可以设置为BOF或者正则表达式
backup                                      ##是否在修改文件之前对文件进行备份。
create                                        ##当要操作的文件并不存在时,是否创建对应的文件。

当文件不存在的时候自动建立文件

还想继续往文件中写内容,没有匹配的就会自动写在后面

替换关键字 只替换符合条件的最后一行内容

删除 会删除符合条件的所有行

无匹配规则时会把内容添加到最后一行

向后引用regexp的变量 比方说我们要替换,替换的内容是一个变量

h开头后4个字符 w开头后5个字符 向后引用为1 backrefs=no时就不向后引用了

在什么之前加和在什么之后加

18、replace

#作用
replace 模块可以根据我们指定的正则表达式替换文件中的字符串,文件中所有被匹配到的字符串都会被替换


#常用参数
path                                         ##指定要操作的文件
regexp                                     ##指定一个正则表达式
                                                #文件中与正则匹配的字符串将会被替换。
replace                                    ##指定最终要替换成的字符串。
backup                                     ##是否在修改文件之前对文件进行备份,最好设置为yes。

查看替换的内容

查看备份

19、setup

#作用
setup模块用于收集远程主机的一些基本信息


#常用参数
filter                                         ##用于进行条件过滤。如果设置,仅返回匹配过滤条件的信息

20、debug

#作用
调试模块,用于在调试中输出信息


#常用参数:
msg:                                       ##调试输出的消息
var:                                           ##将某个任务执行的输出作为变量传递给debug模块
                                                 ##debug会直接将其打印输出
verbosity:                               ##debug的级别(默认是0级,全部显示)

如果显示的内容是变量需要使用var来显示 

debug类似于echo命令

总结

这一章节的内容主要是 Ansible中的常用模块,内容非常多,希望大家可以多加练习。

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

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

相关文章

Python基础1

1. 注释 单行注释&#xff1a;以#开头。一般建议注释和内容用空格隔开。 多行注释&#xff1a;以一对三个双引号括起来的内容是注释。“““示例注释”””。 2. 数据类型 验证数据类型的方法&#xff1a;type&#xff08;被查看类型的数据&#xff09;。 注意&#xff1a;…

< 每日小技巧:N个很棒的 Vue 开发技巧, 持续记录ing >

每日小技巧&#xff1a;6 个很棒的 Vue 开发技巧&#x1f449; ① Watch 妙用> watch的高级使用> 一个监听器触发多个方法> watch 监听多个变量&#x1f449; ② 自定义事件 $emit() 和 事件参数 $event&#x1f449; ③ 监听组件生命周期常规写法hook写法&#x1f44…

扫码过磅+车牌识别,内蒙古蒙维过磅实现信息化管理

扫码过磅、车牌识别、对接SAP ERP系统设计思路&#xff1a; 无人值守系统升级改造包括车牌自动识别系统、信息化&#xff08;扫码等方式&#xff09;管理系统、智能自动控制系统等实现信息无纸化传递。远程监管地点设于公司东磅房&#xff0c;可以实现远程监测监控画面、称重过…

前端之HTML

一、概念1.页面组成结构&#xff1a;HTML&#xff08;Hyper Text Markup Language--超文本标记语言&#xff09;页面原始和内容 表现&#xff1a;CSS网页原始的外观和位置等页面样式&#xff08;如颜色、大小等&#xff09; 行为&#xff1a;JavaScript网页模型的定义与交互&am…

【仓库管理】搭建 Maven 私服之一--Nexus仓库(Repository)管理软件

文章目录Nexus是什么Nexus下载和安装1. 进入 Nexus 2.x 下载页面&#xff0c;根据本机操作系统&#xff0c;选择对应的版本进行下载&#xff0c;如下图所示。2. 将下载 Nexus 安装包解压到本地磁盘&#xff0c;可获得 nexus-2.14.20-02 和 sonatype-work 2 个目录&#xff0c;如…

Python3,2分钟掌握Doscoart库,你也能成为艺术家。

2行代码绘制水彩画1、引言2、 代码实战2.1 模块介绍2.2 模块安装2.3 代码示例2.3.1 创建默认图片2.3.2 设置参数创建图片2.3.3 查看设置参数2.3.4 查看配置2.3.5 保存配置2.3.6 加载配置2.3.7 导出配置文件2.3.7 生成Python代码2.3.8 调用文档3、总结1、引言 小屌丝&#xff1…

分布式新闻项目实战 - 11.定时计算热点文章(xxl-Job)

男人过了四十&#xff0c;千万要少说话&#xff0c;拉长脸&#xff0c;闭紧嘴&#xff0c;买件立领风衣&#xff0c;浓个眉大个眼&#xff0c;一直走&#xff0c;不要往两边看&#xff0c;还能再混几十年。 —— 冯唐 系列文章目录 项目搭建App登录及网关App文章自媒体平台&am…

DQL 数据查询语言(单表查询)

导入数据 登录mysql数据库管理系统 mysql -uroot -pXXX查看有哪些数据库 show databases; (这个不是SQL语句&#xff0c;属于MySQL的命令。)创建属于我们自己的数据库 create database db1; (这个不是SQL语句&#xff0c;属于MySQL的命令。)使用bjpowernode数据 use db1; …

带你了解达人营销的概况

现在&#xff0c;达人营销的格局在不断变化。社交媒体平台想方设法希望吸引更多用户。如果普通用户的内容能够实现爆炸性传播&#xff0c;他们就可以成为冉冉升起的新星。企业需要尽一切努力保持受众的兴趣&#xff0c;所以现如今许多品牌正在转向达人营销工具。当你拥有了许多…

面试篇——计算机网络面试核心问题汇总

前言 前言&#xff1a;总结前后端岗位面试中计算机网络部分常见的面试题。 文章目录前言一、OSI七层模型1、物理层2、数据链路层3、网络层4、传输层5、会话层6、表示层7、应用层8、网络数据处理的整个流程二、TCP/IP 四层模型三、TCP的三次握手1、TCP简介2、三次握手1&#xff…

预训练机制(3)~GPT、BERT

目录 1. BERT、GPT 核心思想 1.1 word2vec和ELMo区别 2 GPT​编辑 3. Bert 3.1 Bert集大成者 extension&#xff1a;单向编码--双向编码区别 3.2 Bert和GPT、EMLo区别 3.3 Bert Architecture 3.3.1 explanation&#xff1a;是否参数多、数据量大&#xff0c;是否过拟…

天干地支蓝桥杯国赛

题目 分析 蓝桥杯国赛2020简单模拟题&#xff0c;你敢信&#xff0c;就是弄两个字符串数组。重点在于知道0000年是从哪个天干和地支开始的。 代码 #include <iostream> using namespace std;int year;int main() {cin >> year;string tiangan[10] {"geng&…

rip路由协议

目录 1.rip路由协议介绍 2.版本 3.工作原理 4.缺点 5.RIP配置 1.rip路由协议介绍 RIP---路由信息协议/矢量路由选择协议&#xff08;Routing Information Protocol&#xff09;是基于距离矢量路由协议&#xff0c;最大的特点是利用跳数来最为计量的标准&#xff08;最多支…

【roLabelImg】windows下旋转框标注软件安装、使用、rolabelimg打包成exe

主要参考&#xff1a; roLabelImg安装、使用、数据格式roLabelImg在Win10系统下打包成exe - 问雪的文章 - 知乎 一、安装 1.1 直接下载exe运行 劝大家直接去下别人编译好的吧&#xff0c;本来是训练模型标记的&#xff0c;结果搞了半天去了解这个软件了&#xff0c;哎~ 我…

数仓实战 - 滴滴出行

项目大致流程&#xff1a; 1、项目业务背景 1.1 目的 本案例将某出行打车的日志数据来进行数据分析&#xff0c;例如&#xff1a;我们需要统计某一天订单量是多少、预约订单与非预约订单的占比是多少、不同时段订单占比等 数据海量 – 大数据 hive比MySQL慢很多 1.2 项目架…

【K6】使用InfluxDB和Grafana图像化展示k6.io的测试数据

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录前言一&#xff1a;什么是K6二&#xff1a;K6的安装三&#xff1a;脚本准备四&#xff1a;执行脚本五&#xff1a;结果分析六、输出结果总结前言 ●&#x1f9d1;个人…

(考研湖科大教书匠计算机网络)第四章网络层-第六节4:边界网关协议BGP的基本工作原理

获取pdf&#xff1a;密码7281专栏目录首页&#xff1a;【专栏必读】考研湖科大教书匠计算机网络笔记导航 文章目录一&#xff1a;不同自治系统交流需要考虑的问题二&#xff1a;边界网关协议BGP概述三&#xff1a;BGP-4种的四种报文本节对应视频如下 【计算机网络微课堂&#x…

告警修复难?Zabbix+ChatGPT,轻松化解大胆尝试!

感谢本文作者小谈谈&#xff01; ○ 基于 Zabbix 能力&#xff0c;我们将告警发给了 ChatGPT&#xff0c;并通过企业微信内部应用的方式给出告警信息和修复建议。效果如下图&#xff1a; 摘 要 ChatGPT 是最近很火的 AI 智能机器人程序&#xff0c;2 个月活跃用户突破 1 亿&a…

java对象内存结构分析与大小计算

java对象内存结构Java对象保存在堆中时&#xff0c;由三部分组成&#xff1a;对象头&#xff08;object header&#xff09;&#xff1a;包括了关于堆对象的布局、类型、GC状态、同步状态和标识哈希码的基本信息。所有java对象都有一个共同的对象头格实例数据&#xff08;Insta…

55个软件测试工具,正在做测试的你get到了吗

网络“黑色星期五”威胁&#xff0c;安全漏洞&#xff0c;网上银行盗窃&#xff0c;系统停机时间&#xff0c;以及许多这样的恶梦让全球的企业忧心忡忡难以入眠。确保性能具有加载的安全性和增强的经验是这个领域每个有能力的玩家所必备的。 我们为你提供了一个丰富的软件测试…