【Ansible自动化运维】一、初步了解,开启自动化运维之旅

news2025/4/24 1:16:50

        在当今数字化时代,随着企业 IT 基础设施规模的不断扩大,传统的手工运维方式逐渐显得力不从心。自动化运维技术应运而生,其中 Ansible 凭借其简洁易用、功能强大的特点,成为众多运维工程师和开发人员的首选工具。本篇文章将从基础概念到简单的实际操作,让你快速上手自动化运维!

一、Ansible 是什么​

Ansible 是一个基于 Python 开发的自动化运维工具,它的设计理念是简单、高效、无代理。与其他一些自动化工具不同,Ansible 不需要在被管理的目标主机上安装额外的代理软件,这大大降低了部署和维护的复杂性。通过 SSH 协议,Ansible 可以直接与目标主机进行通信,执行各种管理任务,如配置管理、软件部署、任务编排等。​

Ansible 在自动化运维领域有着广泛的应用场景。例如,在一个拥有大量服务器的云计算环境中,使用 Ansible 可以快速实现所有服务器的统一配置,包括操作系统初始化、软件安装、安全设置等。对于开发团队来说,Ansible 可以帮助他们自动化应用的部署流程,确保开发、测试和生产环境的一致性。

二、安装与环境搭建​

2.1 在 Linux 系统上安装 Ansible​

大多数 Linux 发行版都可以通过包管理器轻松安装 Ansible。以 CentOS 为例,执行以下命令:

# 更新系统软件包
sudo yum update -y
# 安装Ansible
sudo yum install ansible -y

在 Ubuntu 系统上,安装命令如下:

# 更新系统软件包
sudo apt update
# 安装Ansible
sudo apt install ansible -y

2.2 在 Windows 系统上安装 Ansible(通过 WSL)​

如果你的 Windows 系统安装了适用于 Linux 的 Windows 子系统(WSL),也可以在 WSL 环境中安装 Ansible。首先,打开 Windows 应用商店,搜索并安装你喜欢的 Linux 发行版,如 Ubuntu。安装完成后,打开 WSL 终端,按照上述 Linux 系统的安装步骤进行安装。​

2.3 配置 Ansible 环境​

Ansible 的主要配置文件是ansible.cfg,通常位于/etc/ansible/目录下。虽然 Ansible 在安装后有默认配置,但根据实际需求,我们可能需要对其进行一些修改。例如,修改inventory参数,指定主机清单文件的路径。主机清单文件用于定义 Ansible 要管理的目标主机。默认情况下,Ansible 使用/etc/ansible/hosts作为主机清单文件。

[defaults]
# 指定主机清单文件路径
inventory = /etc/ansible/hosts

2.4 主机清单配置​

主机清单文件/etc/ansible/hosts用于列出 Ansible 要管理的所有目标主机。可以按组对主机进行分类,方便批量操作。例如,我们有一组 Web 服务器和一组数据库服务器,在hosts文件中可以这样配置(组名的合理编写更加有助于我们后期对节点的控制和修改):

[web_servers]
web1.example.com
web2.example.com

[db_servers]
db1.example.com
db2.example.com

你还可以为每个主机指定连接参数,如 SSH 端口、用户名等。例如:

[web_servers]
web1.example.com ansible_port=22 ansible_user=ubuntu
web2.example.com ansible_port=22 ansible_user=ubuntu

[db_servers]
db1.example.com ansible_port=22 ansible_user=centos
db2.example.com ansible_port=22 ansible_user=centos

三、Ansible 核心组件解析​

3.1 连接插件​

连接插件负责 Ansible 与目标主机之间的通信。默认情况下,Ansible 使用 SSH 连接插件,通过 SSH 协议与目标主机建立连接。这也是 Ansible 无需在目标主机安装代理的原因之一。除了 SSH,Ansible 还支持其他连接方式,如local(用于在本地主机执行任务)、docker(用于在 Docker 容器中执行任务)等。​

3.2 主机清单​

如前文所述,主机清单是 Ansible 管理目标主机的核心组件。通过主机清单,Ansible 可以知道要对哪些主机执行任务,并且可以按组对主机进行分类管理,大大提高了管理效率。​

3.3 模块​

模块是 Ansible 执行具体任务的工具。Ansible 内置了大量丰富的模块,涵盖了系统管理、软件安装、网络配置等各个方面。例如,ping模块用于检查目标主机的连通性,yum模块用于在 CentOS 等系统上安装软件包,apt模块用于在 Ubuntu 等系统上安装软件包。​

我们可以通过命令行直接调用模块。例如,使用ping模块检查web1.example.com的连通性:

ansible web1.example.com -m ping

上述命令中,ansible是 Ansible 的命令行工具,web1.example.com是目标主机(也可以是IP地址),-m参数指定要使用的模块为ping。

3.4 Playbook​

Playbook 是 Ansible 的核心组件之一,它是一个由 YAML 语言编写的文件,用于定义一系列的任务和执行这些任务的顺序。Playbook 可以理解为一个剧本,Ansible 按照剧本中的步骤依次在目标主机上执行任务。通过 Playbook,我们可以实现复杂的自动化流程,如应用的完整部署过程。

四、第一个 Ansible 任务​

现在,我们来尝试执行第一个 Ansible 任务,使用ping模块检查目标主机的连通性。假设我们的主机清单文件/etc/ansible/hosts中已经配置了web1.example.com主机。​

执行以下命令:

ansible web1.example.com -m ping

执行结果如下:

web1.example.com | SUCCESS => {
    "changed": false,
    "ping": "pong"
}

结果说明:​

  • web1.example.com:目标主机名。​
  • SUCCESS:表示任务执行成功。​
  • "changed": false:表示该任务没有对目标主机进行任何修改,只是检查连通性。​
  • "ping": "pong":这是ping模块返回的结果,证明目标主机可达。

 接下来,我们使用shell模块在目标主机上执行一个简单的命令,如查看当前目录下的文件列表。命令如下:

ansible web1.example.com -m shell -a "ls -l"

上述命令中,-a参数用于传递模块的参数,这里传递给shell模块的参数是要在目标主机上执行的命令ls -l。​

执行结果类似如下:

web1.example.com | CHANGED | rc=0 >>
total 0
-rw-r--r-- 1 ubuntu ubuntu 0 Apr  8 10:00 file1.txt
-rw-r--r-- 1 ubuntu ubuntu 0 Apr  8 10:01 file2.txt

结果说明:​

  • CHANGED:表示任务执行后目标主机的状态发生了改变(这里执行了一个命令,虽然只是查看文件列表,但也算状态改变)。​
  • rc=0:表示命令执行成功,返回码为 0。​
  • >>后面的内容是命令在目标主机上的执行结果,即当前目录下的文件列表。

通过以上简单的示例,你已经初步体验了 Ansible 的使用流程。从安装配置到执行简单任务,Ansible 展现出了其简洁易用的特点。随着对 Ansible 的深入学习,你将发现它在自动化运维领域的强大功能,能够帮助你轻松应对各种复杂的运维场景。

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

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

相关文章

条件概率、概率乘法公式、全概率公式和贝叶斯 (Bayes) 公式

定义 设 P ( A ) > 0 P(A) > 0 P(A)>0,若在随机事件 A A A发生的条件下随机事件 B B B发生的概率记作 P ( B ∣ A ) P(B|A) P(B∣A),定义 P ( B ∣ A ) P ( A B ) P ( A ) P(B|A) \frac{P(AB)}{P(A)} P(B∣A)P(A)P(AB)​ 则称 P ( B ∣ A ) …

kotlin,Android,jetpack compose,日期时间设置

AI生成,调试出来学习,这些小组件会用了,就可以组合一个大点的程序了。 package com.example.mydatetimeimport android.app.AlertDialog import android.os.Bundle import androidx.activity.ComponentActivity import androidx.activity.co…

ASP.NET图书馆借阅系统(源码+lw+部署文档+讲解),源码可白嫖!

摘要 近些年来,随着科技的飞速发展,互联网的普及逐渐延伸到各行各业中,给人们生活带来了十分的便利,图书馆借阅系统利用计算机网络实现信息化管理,使图书信息、图书借阅、归还的管理发展和服务水平有显著提升。 本文拟…

vi/vim常用快捷键

那么今天我们继续昨天没有介绍完的vi编辑器,来看看常用的一些快捷键,方便我们对文件的编辑. 1.拷贝当前行yy,拷贝当前行向下的5行5yy,并粘贴(输入p) 2.删除当前行dd,删除当前行向下的5行5d 3.在文件中查找某个单词[命令模式/关键字,回车查找,输入n就是查找下一个] ⭐️&…

opencv无法设置禁用RGB转换问题

树莓派连接摄像头,摄像头输出格式为YUYV(YUV422)。 通过执行 v4l2-ctl --list-formats --device/dev/video0 可以看的具体的摄像头的数据格式。 使用opencv获取视频流,通过cap.set(cv2.CAP_PROP_CONVERT_RGB, 0)设置禁用自动转换RGB格式,但是打印输出…

MCP+Blender创建电力塔

MCP(Model Context Protocol)与Blender的结合是当前AI与3D建模领域的热门技术,它通过协议化的方式让Claude等AI模型直接控制Blender,实现自动化3D建模。 1. 功能与原理 • 核心能力:用户通过自然语言指令(…

Selenium自动化:玩转浏览器,搞定动态页面爬取

嘿,各位爬虫爱好者和自动化达人们!是不是经常遇到这种情况:信心满满地写好爬虫,requests一把梭,结果抓下来的HTML里,想要的数据空空如也?定睛一看,原来数据是靠JavaScript动态加载出…

QAI AppBuilder 快速上手(8): 图像修复应用实例2

LaMa-Dilated模型旨在通过扩张卷积技术实现高效的图像擦除和修复。该模型采用先进的卷积神经网络架构,能够处理复杂的图像输入,并填补图像中的缺失部分,使修复后的图像更加自然和逼真。LaMa-Dilated不仅在图像编辑领域表现出色,还…

【计网】作业4

一. 单选题(共22题,64分) 1. (单选题)主机甲采用停止-等待协议向主机乙发送数据,数据传输速率是4kb/s,单向传播时延为30ms,忽略确认帧的发送时延。当信道利用率等于80%时,数据帧的长度为&#…

MPDrive:利用基于标记的提示学习提高自动驾驶的空间理解能力

25年4月来自南方科技大学、百度、英国 KCL和琶洲实验室(广东 AI 和数字经济实验室)的论文“MPDrive: Improving Spatial Understanding with Marker-Based Prompt Learning for Autonomous Driving”。 自动驾驶视觉问答(AD-VQA)…

【学习笔记】HTTP和HTTPS的核心区别及工作原理

一、基础概念 HTTP(超文本传输协议):明文传输数据,默认端口80,容易被窃听或篡改。 HTTPS(HTTP SSL/TLS):通过加密传输数据,默认端口443,保障安全性。 二、…

【STL】list介绍(附与vector的比较)

文章目录 1.关于list2.使用2.1 list的构造2.2 list 迭代器的使用2.3 list 容量操作2.3.1 size()2.3.2 empty()2.3.3 resize() 2.4 list 元素访问2.4.1 front()2.4.2 back() 2.5 list 修改操作2.5.1 push_front()2.5.2 pop_front()2.5.3 push_back()2.5.4 pop_back()2.5.5 inser…

Ansible:roles角色

文章目录 Roles角色Ansible Roles目录编排Roles各目录作用创建 roleplaybook调用角色调用角色方法1:调用角色方法2:调用角色方法3: roles 中 tags 使用实战案例 Roles角色 角色是ansible自1.2版本引入的新特性,用于层次性、结构化…

找不到导入的项目“xxx\QtMsBuild\Qt.props”。请确认 Import 声明“$(QtMsBuild)\Qt.props”中计算结果为

系列文章目录 文章目录 系列文章目录前言一、问题原因 前言 新建的项目visual studio2022 使用Qt vs tools 找不到导入的项目“E:\osgEarth\DigitalSimulationPlatform\DigitalSimulationPlatform\QtMsBuild\Qt.props”。 请确认 Import 声明“$(QtMsBuild)\Qt.props”中计算结…

2025 年福建交安安全员考试:结合本省交通特点备考​

福建地处东南沿海,交通建设具有独特特点,这对交安安全员考试备考意义重大。在桥梁建设方面,由于面临复杂的海洋环境,桥梁的防腐、防台风等安全措施成为重点。考生在学习桥梁施工安全知识时,要特别关注福建本地跨海大桥…

UE5 蓝图里的声音

文章目录 支持的格式设置循环播放在场景中放置音频设置音频的衰减与不衰减在UI动画中播放声音使用蓝图节点播放声音按钮本身就可以播放声音 支持的格式 支持:WAV 不支持:MP3 设置循环播放 双击音频,打开音频设置,勾选Looping …

「合诚」携手企企通共建新材料和健康产业采购数智化新生态

在科技革命与产业变革深度融合的时代背景下,新材料与健康产业正迎来数字化、智能化的快速发展。 技术突破与消费升级的双重驱动,推动着行业不断创新,同时也对企业的供应链管理提出了更高要求。 1、合诚:聚焦新材料与健康产业&am…

java+postgresql+swagger-多表关联insert操作(七)

入参为json,然后根据需要对多张表进行操作: 入参格式: [{"custstoreName":"swagger-测试经销商01","customerName":"swagger-测试客户01","propertyNo":"swaggertest01",&quo…

Git版本管理系列:(一)使用Git管理单分支

目录 基础概念介绍仓库的创建创建隐藏目录添加代码到暂存区提交代码到仓库提交记录查询比较差异标签文件删除版本回退总结 Git‌ 是一个分布式版本控制系统(DVCS),用于跟踪文件的变更并协调多人协作开发‌,由 Linus Torvalds 于 2…

mapbox基础,加载ESRI OpenStreetMap开放街景标准风格矢量图

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.1 ☘️mapboxgl.Map style属性二、🍀加载ESRI OpenStreetMap开放街景标准风…