运维自动化之 ansible

目录

一     常见的自动化运维工具

(一)有哪些常见的 自动化运维工具

(二)为什么后面都变成用 ansible

二     ansible 基本介绍

1, ansible 是什么

2,ansible能干什么

3,ansible 工作原理

4, ansible 三大特性

5,  ansible 具有如下特点

三    ansible 数据流向

四    ansible 环境安装部署

1,实验环境

2, 管理端安装 ansible

五     ansible 命令行模块 语法

1,命令格式

2,查看安装的 模块

3,指定主机/ip /组

六   ansible 命令行模块具体介绍

1,command 模块

1.1  command 模块 常用参数

 1.2 command 模块 演示

2,  shell 模块

2.1 查看shell 模块 参数

2.2 shell 模块  演示

3, cron 模块

3.1 cron 模块 常用参数

3.2 cron 模块 演示

4, user 模块

4.1  user 模块 常用的参数

4.2   user 模块 演示

5 ,  group 模块

5.1 group 模块 常见参数

5.2  group 模块 演示

6, copy 模块

6.1 copy 模块   常用的参数

6.2 copy 模块   演示

7,  file 模块

7.1 file 模块 常见参数

7.2  file 模块  演示

8  hostname 模块

9, ping 模块

10   yum 模块

10.1  yum 模块常见 参数

10.2   yum 模块  演示

11   service/systemd 模块

11.1 service/systemd 模块 常用参数

11.2  service/systemd 模块  演示

12   script 模块

12,1 script 模块  参数

12.2  script 模块  演示

13  setup 模块

13.1 setup 模块 参数

13.2 setup 模块 演示

七  总结


一     常见的自动化运维工具

(一)有哪些常见的 自动化运维工具

1,saltstack

用python语言 C/S 架构 ssh协议支撑

2,Ansible

自动化配置管理和应用部署工具,基于YAML语法。

3,Chef

另一款流行的配置管理工具,支持大规模基础架构自动化。

C/S 架构   都是用的ruby 语言

协议支撑 http     目前生产环境不用

4,Puppet

配置管理系统,用于自动管理服务器配置和部署

C/S 架构   都是用的ruby 语言

协议支撑 http     目前生产环境不用

(二)为什么后面都变成用 ansible

因为ansible不需要装 客户端

协议只有一个ssh

二     ansible 基本介绍

1, ansible 是什么

Ansible是一个基于Python开发的配置管理和应用部署工具,现在也在自动化管理领域大放异彩。它融合了众多老牌运维工具的优点,Pubbet和Saltstack能实现的功能,Ansible基本上都可以实现。
 

2,ansible能干什么

Ansible能批量配置、部署、管理上千台主机。比如以前需要切换到每个主机上执行的一或多个操作,使用Ansible只需在固定的一台Ansible控制节点上去完成所有主机的操作。
 

3,ansible 工作原理

Ansible是基于模块工作的,它只是提供了一种运行框架,它本身没有完成任务的能力,真正执行操作的是Ansible的模块, 比如copy模块用于拷贝文件到远程主机上,service模块用于管理服务的启动、停止、重启等。
 

4, ansible 三大特性

Ansible其中一个比较鲜明的特性是Agentless,即无Agent的存在,它就像普通命令一样,并非C/S软件,也只需在某个作为控制节点的主机上安装一次Ansible即可,通常它基于ssh连接来控制远程主机,远程主机上不需要安装Ansible或其它额外的服务

 使用者在使用时,在服务器终端输入命令或者playbooks,会通过预定好的规则将playbook拆解为play,再组织成ansible可以识别的任务,调用模块和插件,根据主机清单通过SSH将临时文件发给远程的客户端执行并返回结果,执行结束后自动删除

Ansible的另一个比较鲜明的特性是它的绝大多数模块都具备幂等性(idempotence)。所谓幂等性,指的是多次操作或多次执行对系统资源的影响是一致的。比如执行 systemctl stop xxx 命令来停止服务,当发现要停止的目标服务已经处于停止状态, 它什么也不会做,所以多次停止的结果仍然是停止,不会改变结果,它是幂等的,而 systemctl restart xxx 是非幂等的。

Ansible的很多模块在执行时都会先判断目标节点是否要执行任务,所以,可以放心大胆地让Ansible去执行任务,重复执行某个任务绝大多数时候不会产生任何副作用。

5,  ansible 具有如下特点

1、部署简单,只需在主控端部署Ansible环境, 被控端无需做任何操作
2、默认使用SSH协议设备进行管理;
3、主从集中化管理
4、配置简单、功能强大、扩张性强;
5、支持API及自定义模块,可以通过Pyhton轻松扩展
6、通过playbooks 来定制强大的配置、状态管理
7、对云计算平台、大数据都有很好的支持
 

三    ansible 数据流向

四    ansible 环境安装部署

1,实验环境

管理端: 192.168.217.77        ansible                    
被管理端: 192.168.217.55                                
被管理端: 192.168.217.66                 

2, 管理端安装 ansible

先安装 epel 源

         

安装ansible

 ansible 目录结构

配置主机清单

[webservers]            #配置组名
192.168.10.17            #组里包含的被管理的主机IP地址或主机名(主机名需要先修改/etc/hosts文件)

配置密钥对验证

让ssh 免交互(不需要输yes)

五     ansible 命令行模块 语法

1,命令格式

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

2,查看安装的 模块

ansible-doc -l                #列出所有已安装的模块,按q退出

3,指定主机/ip /组

ansible 192.168.10.14 -m command -a 'date'        #指定 ip 执行 date
ansible webservers -m command -a 'date'            #指定组执行 date
ansible webservers -m command -a 'date'            #指定组执行 date
ansible dbservers -m command -a 'date'       
ansible all -m command -a 'date'                #all 代表所有 hosts 主机
ansible all -a 'ls /'                            #如省略 -m 模块,则默认运行 command 模块

六   ansible 命令行模块具体介绍

1,command 模块

在远程主机执行命令,不支持管道,重定向等shell的特性

1.1  command 模块 常用参数

chdir:在远程主机上运行命令前提前进入目录
creates:判断指定文件是否存在,如果存在,不执行后面的操作
removes:判断指定文件是否存在,如果存在,执行后面的操作

 1.2 command 模块 演示

wyq01组   主机显示时间

chdir 相当于cd   cd 到家目录 并ls

2,  shell 模块

在远程主机执行命令,相当于调用远程主机的shell进程,然后在该shell下打开一个子shell运行命令(支持管道符号等功能)

2.1 查看shell 模块 参数

ansible-doc -s shell

2.2 shell 模块  演示

更改  用户test  的密码

提取 ip 地址

3, cron 模块

在远程主机定义任务计划。其中有两种状态(state):present表示添加(可以省略),absent表示移除

3.1 cron 模块 常用参数

minute/hour/day/month/weekday:分/时/日/月/周
job:任务计划要执行的命令
name:任务计划的名称
 

3.2 cron 模块 演示

每5分钟 执行一次   执行echo helloworld   计划任务的名字是  test crontab

查看 所有计划任务

移除计划任务  假如该计划任务没有取名字,name=None即可

4, user 模块

用户管理的模块

4.1  user 模块 常用的参数

name:用户名,必选参数
state=present|absent:创建账号或者删除账号,present表示创建,absent表示删除
system=yes|no:是否为系统账号
uid:用户uid
group:用户基本组
shell:默认使用的shell
move_home=yse|no:如果设置的家目录已经存在,是否将已经存在的家目录进行移动
password:用户的密码,建议使用加密后的字符串
comment:用户的注释信息
remove=yes|no:当state=absent时,是否删除用户的家目录
 

4.2   user 模块 演示

创建用户test01

查看是否 创建成功

删除用户test01

5 ,  group 模块

用户组管理的模块

5.1 group 模块 常见参数

5.2  group 模块 演示

创建mysql组

查看是否 创建成功

将test01用户添加到mysql组中

看 用户是否创建成功

查看 用户的 组

6, copy 模块

用于复制指定主机文件到远程主机的

6.1 copy 模块   常用的参数

dest:指出复制文件的目标及位置,使用绝对路径,如果是源目录,指目标也要是目录,如果目标文件已经存在会覆盖原有的内容
src:指出源文件的路径,可以使用相对路径或绝对路径,支持直接指定目录,如果源是目录则目标也要是目录
mode:指出复制时,目标文件的权限 
owner:指出复制时,目标文件的属主
group:指出复制时,目标文件的属组
content:指出复制到目标主机上的内容,不能与src一起使用

6.2 copy 模块   演示

将ansible 机器的  /etc/fstab  拷贝到  wyq01 主机  下的/opt   定属主 和权限

查看拷贝的  结果

将helloworld写入/opt/hello.txt文件中

查看是否   写入成功

7,  file 模块

设置文件属性

7.1 file 模块 常见参数

7.2  file 模块  演示

修改文件的属主属组权限等

设置/opt/fstab.link为/opt/fstab.bak的链接文件

创建一个文件

删除一个文件

8  hostname 模块

用于管理远程主机上的主机名

9, ping 模块

检测远程主机的连通性

10   yum 模块

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

10.1  yum 模块常见 参数

ansible-doc -s yum

10.2   yum 模块  演示

安装服务

卸载服务

11   service/systemd 模块

11.1 service/systemd 模块 常用参数

name:被管理的服务名称
state=started|stopped|restarted:动作包含启动关闭或者重启
enabled=yes|no:表示是否设置该服务开机自启
runlevel:如果设定了enabled开机自启去,则要定义在哪些运行目标下自启动
 

11.2  service/systemd 模块  演示

查看web服务器httpd运行状态

启动httpd服务

12   script 模块

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

12,1 script 模块  参数

12.2  script 模块  演示

ansible 机器    写脚本

加执行  权限

执行脚本

验证 脚本是否运行

13  setup 模块

facts 组件是用来收集被管理节点信息的,使用 setup 模块可以获取这些信息

13.1 setup 模块 参数

13.2 setup 模块 演示

获取mysql组主机的facts信息

使用filter可以筛选指定的facts信息

七  总结

ansibe 机制

ansible:核心组件 核心程序

hostInventory:记录由ansible管理的主机信息(包括端口、IP、密码等)

playbook:"剧本"

YAML格式文件,多个任务定义在一个文件中,定义主机需要哪些模块来完成的功能

core modules: 核心模块 主要操作是通过调用核心模块来管理任务

customodlues:自动定义模块,来完成核心无无法完成的功能支持多个语言

connectionPlugins:连接插件ansible和HOST通信使用

ansible模块

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

ansible-doc -l列出所有已安装的模块 按q退出

ansible-doc -s 模块名指导模块使用方法

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux网络—PXE高效批量网络装机

目录 一、部署PXE远程安装服务 1、搭建PXE远程安装服务器 1&#xff09;安装并启用 TFTP 服务 2&#xff09;安装并启用 DHCP 服务 3&#xff09;准备 Linux 内核、初始化镜像文件 4&#xff09;准备 PXE 引导程序 5&#xff09;安装FTP服务&#xff0c;准备CentOS 7 安…

OpenCV 入门(一) —— OpenCV 基础

OpenCV 入门系列&#xff1a; OpenCV 入门&#xff08;一&#xff09;—— OpenCV 基础 OpenCV 入门&#xff08;二&#xff09;—— 车牌定位 OpenCV 入门&#xff08;三&#xff09;—— 车牌筛选 OpenCV 入门&#xff08;四&#xff09;—— 车牌号识别 OpenCV 入门&#xf…

Springboot框架web开发实用功能-02

在些模块中汇总了一些web开发常用的配置和功能。 涉及的模块 springboot-common-config&#xff0c; 端口号&#xff1a;17000 Springboot框架web开发常用功能 Restful接口定义 查询参数 Data public class QueryParam {private String key;private String value; }Control…

MATLAB实现杜拉德公式和凯夫公式的计算固液混合料浆临界流速

MATLAB实现杜拉德公式和凯夫公式的计算固液混合料浆临界流速: 杜拉德公式是用来计算非均质固液混合料浆在输送管中的临界速度的公式&#xff0c;具体形式为&#xff1a; uL FL (2gD / (ρ0 - ρ1))^(1/2) 其中&#xff1a; uL&#xff1a;表示料浆的临界速度&#xff0c;…

Hbase 常用shell操作

目录 1、创建表 1.1、启动HBase Shell 1.2、创建表 1.3、查看表 1.4、删除表 2、插入数据 2.1、put命令 3、查看数据 3.1、get命令 3.2、查询数据中文显示 4、更新数据 4.1、使用put来更新数据 5、删除数据 5.1、delete命令 5.2、删除指定列的数据 5.3、delete…

Pycharm debug 运行报错 (RuntimeError: cannot release un-acquired lock)

问题描述&#xff1a; 最近再跑一个 flask应用&#xff0c;Pycharm 运行没问题&#xff0c;debug断点启动时报错 如下&#xff1a; 解决方案&#xff1a; 在环境变量中增加 GEVENT_SUPPORTTrue 启动成功&#xff01;

libcity笔记:添加新模型(以RNN.py为例)

创建的新模型应该继承AbstractModel或AbstractTrafficStateModel 交通状态预测任务——>继承 AbstractTrafficStateModel类轨迹位置预测任务——>继承AbstractModel类 1 AbstractTrafficStateModel 2 RNN 2.1 构造函数 2.2 predict 2.3 calculate_loss

博客系统项目测试报告

文章目录 一.报告概要二.测试环境三.手工测试用例四.编写测试用例五.自动化测试Selenium测试项目主要特点 一.报告概要 项目概要 本项目是一个全功能的个人博客系统&#xff0c;旨在提供一个用户友好、功能全面的平台&#xff0c;允许用户注册、登录、浏览博客、查看详细内容、…

Mac跑llama.cpp过程中遇到的问题

原repo 在华为手机上安装termux、下载库&#xff1a;顺利在电脑上安装Android NDK&#xff1a;先下载Android Studio&#xff0c;再在里面下载Android SDK 安装Android Studio时&#xff0c;SDK的某些组件总是下载不成功。后来关了梯子、改了hosts&#xff0c;重新安装就成功了…

Golang | Leetcode Golang题解之第73题矩阵置零

题目&#xff1a; 题解&#xff1a; func setZeroes(matrix [][]int) {n, m : len(matrix), len(matrix[0])col0 : falsefor _, r : range matrix {if r[0] 0 {col0 true}for j : 1; j < m; j {if r[j] 0 {r[0] 0matrix[0][j] 0}}}for i : n - 1; i > 0; i-- {for …

Go实现树莓派控制舵机

公式说明 毫秒&#xff08;ms&#xff09;是时间的单位&#xff0c;赫兹&#xff08;Hz&#xff09;是频率的单位&#xff0c;而DutyMax通常是一个PWM&#xff08;脉冲宽度调制&#xff09;信号中表示最大占空比的值。以下是它们之间的关系和一些相关公式&#xff1a; 频率&…

【华为】路由策略小实验

【华为】软考中级-路由策略实验 实验需求拓扑配置AR1AR2需求1需求2 AR3 检验 实验需求 1、让 R3 可以学到R1的 192.168.10.0/24和192.168.20.0/24的 路由&#xff0c;不能学到192.168.30.0/24。 2、让 R1可以学到 R3 的 172.16.20.0/24和172.16.30.0/24的路由&#xff0c;不能…

opencv图像处理详细讲(二)

联通组件分析 联通组件定义&#xff1a;像素值相同&#xff0c;通过四邻域或者八邻域相互连通的像素块。 换句话说&#xff0c;就是使用四邻域或八邻域的连通性&#xff0c;遍历图像的像素&#xff0c;并确定像素值相同并且连通的像素块&#xff0c;将它们标记为一个联通组件 两…

虚拟机VM VirtualBox安装openEuler+UKUI的安装和卸载_2024

虚拟机VM VirtualBox安装openEuler ps. 建议先看最后的其他 下载openEuler openEuler官网下载 一般来说标准版就够用了 使用虚拟机VM VirtualBox安装openEuler 新建虚拟机 修改用户名密码&#xff0c;建议修改&#xff0c;虽然之后还可以通过命令行修改&#xff08;注意密…

pyecharts绘制世界动态轨迹图(v0.5.X与v1.X版本对比)

一、问题引入 pyecharts官网&#xff1a;https://pyecharts.org/#/zh-cn/intro 在使用Geo或者GeoLines绘制动态轨迹图时&#xff0c;如果所选地区是中国的省份或者城市&#xff0c;是能够匹配到对应的经纬度并且正常绘制的&#xff1b;如果所选地区涉及到其他国家或者国外城市&…

Docker-harbor

一、搭建本地私有仓库 1.1 下载Registry镜像 1.2 添加本地私有仓库配置 1.3 重启服务并运行Registry容器 1.4.容器的操作 1.4.1 拉取Nginx镜像并为镜像打标签 1.4.2 上传到私有仓库 1.4.3 列出私有仓库所有镜像 1.4.4 列出私有仓库的镜像的所有标签 1.4.5 先删除原有…

Anaconda删除虚拟环境目录pkgs和envs|conda瘦身

这个文件夹里面是专门放不同环境中的包的&#xff0c;只是没有区分环境&#xff0c;都混在一起了&#xff0c; 一般在想要删除一个虚拟环境&#xff0c;除了在命令行中输入conda remove -n your_env_name(虚拟环境名称) --all 然后在envs中删除虚拟环境的文件夹&#xff0c; 还…

企业微信hook接口协议,ipad协议http,客户群发送任务,获取要发送的客户群列表

客户群发送任务&#xff0c;获取要发送的客户群列表 参数名必选类型说明uuid是String每个实例的唯一标识&#xff0c;根据uuid操作具体企业微信 请求示例 {"uuid": "1688853790533324","id":1101292747044333637, //群发任务id"keyword…

【Unity】如何获得TMP Button下的text内容

【背景】 unity项目中使用了TMP命名空间的Button UI组件。脚本中需要获得Button下Text的内容,但是发现用TextMeshPro仍然无法获得button下的text对象。 【分析】 Hierarchy结构上看明确Button下是有Text组件的: 括号里是TMP,所以理论上用TextMeshPro类型去FindComponent…

navicat 连接 阿里云 RDS mysql 数据库

首先上官方教程连接 下面是我的实操记录 1、先输入正确的账号、密码 2、再加上数据库名称