」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > Ansible 入門 - 初學者指南:日復一日的 DevOps 工具系列

Ansible 入門 - 初學者指南:日復一日的 DevOps 工具系列

發佈於2024-11-08
瀏覽:198

Getting Started with Ansible - The Beginner’s Guide : Day of days DevOps Tools Series

欢迎来到我们的“50 天 50 个 DevOps 工具”系列的第 30 天!今天,我们将探索 Ansible,它是 DevOps 工具包中最重要的工具之一。本博客将向您介绍 Ansible 的基础知识,分解其关键组件并向您展示如何从简单的示例开始。我们会让事情简单明了,使其成为初学者的完美起点。

什么是 Ansible?

Ansible 是一种开源自动化工具,可简化配置管理、应用程序部署和编排等任务。它的设计简单但功能强大,可让您自动执行重复性任务并更有效地管理您的基础设施。

主要特点:

Agentless: Ansible 不需要在远程系统上安装任何代理,这减少了开销。
人类可读的 YAML Playbooks: Ansible 使用 YAML(Yet Another Markup Language)编写 Playbook,易于阅读和编写。
幂等:您可以多次运行同一个剧本,而不必担心意外的更改。

为什么使用 Ansible?

无代理架构:由于 Ansible 是无代理的,因此无需在客户端系统上安装任何额外的软件,从而减少开销和潜在的安全风险。

简单语法: Ansible 使用 YAML 作为它的 playbook,它易于阅读和编写,甚至对于自动化新手来说也很容易使用。

幂等性: Ansible 确保无论当前状态如何都能实现所需的状态。这意味着多次运行剧本不会导致问题或重复操作。

广泛的社区支持: Ansible 拥有庞大而活跃的社区,拥有丰富的角色、模块和剧本,可以重用和定制以满足您的需求。

可扩展性:无论是管理几台服务器还是数千台服务器,Ansible 都可以很好地扩展,使其适合各种规模的组织。

Ansible 的核心组件

Inventory: 这是 Ansible 管理的主机(服务器)列表。库存可以是静态的(在文件中定义)或动态的(由脚本生成)。

模块: 模块是 Ansible 的主力。它们在远程主机上执行,以执行安装包、复制文件或管理服务等任务。

Playbooks: Playbooks 是 Ansible 的配置、部署和编排语言。它们用 YAML 编写,描述了要在主机上执行的一系列任务。

角色:角色允许您将剧本分解为可重用的组件,从而更轻松地管理和组织大型项目。

变量: 变量用于存储可在整个剧本中重复使用的值。它们提供了灵活性,允许您自定义剧本而无需硬编码值。

处理程序: 处理程序是特殊任务,仅在被其他任务触发时运行。它们通常用于重新启动服务之类的事情。

设置 Ansible

让我们从在控制节点上安装 Ansible 开始。安装过程很简单,并且根据您的操作系统略有不同。

在 Ubuntu/Debian 上安装 Ansible

sudo apt update
sudo apt install ansible -y

在 CentOS/RHEL 上安装 Ansible

sudo yum install epel-release -y
sudo yum install ansible -y

验证安装
安装后,您可以通过运行以下命令来验证 Ansible 是否已正确安装:

ansible --version

编写你的第一本 Ansible 手册

让我们创建一个简单的剧本来在远程服务器上安装 Nginx。我们将从定义库存开始。

第 1 步:创建库存文件
创建一个名为hosts的文件:

[webservers]
34.42.111.35
34.42.111.66

此清单文件定义了一个名为 webservers 的组,其中包含两个服务器。

第 2 步:编写剧本
接下来,我们将编写一个剧本来在这些服务器上安装和启动 Nginx。

创建名为 nginx_setup.yml 的文件:

---
- name: Install Nginx on web servers
  hosts: webservers
  become: yes

  tasks:
    - name: Install Nginx
      apt:
        name: nginx
        state: present

    - name: Start Nginx service
      service:
        name: nginx
        state: started
        enabled: true

了解剧本

名称: 剧本或任务功能的人类可读描述。
hosts: 指定应运行 playbook 的主机组(来自清单)。
become: 指示 Ansible 应该使用提升的权限(如 sudo)。
tasks: 列出 Ansible 将执行的步骤。在这里,我们正在安装 Nginx 并确保该服务在启动时启动并启用。

第 3 步:运行 Playbook
要执行剧本,请运行以下命令:

ansible-playbook -i hosts nginx_setup.yml

此命令告诉 Ansible 在主机清单文件中定义的主机上运行 nginx_setup.yml 中的任务。

现实场景:自动化软件包安装

考虑一个场景,您需要在多个服务器上安装一组软件包。手动执行此操作非常耗时且容易出错。使用 Ansible,您可以轻松地自动执行此任务。

这是一个安装多个软件包的简单手册:

---
- name: Install essential packages
  hosts: all
  become: yes

  tasks:
    - name: Install packages
      apt:
        name:
          - git
          - curl
          - htop
        state: present

在此剧本中,Ansible 在清单中列出的所有服务器上安装 git、curl 和 htop。 apt 模块确保每个软件包都已安装。

现实生活示例:简化用户管理

假设您需要在多个服务器上创建一个新用户并将它们分配给特定的组。在每台服务器上手动执行此任务将非常乏味。有了 Ansible,一切变得轻而易举。

具体操作方法如下:

---
- name: Create a new user
  hosts: all
  become: yes

  tasks:
    - name: Create user "devuser"
      user:
        name: devuser
        state: present
        groups: sudo

此剧本在所有托管服务器上创建一个新用户 devuser 并将它们添加到 sudo 组。

使用 Ansible 的好处

一致性: Ansible 确保您的系统配置一致,降低配置漂移的风险。
效率:自动化重复性任务可以腾出时间来处理更关键的工作。
可扩展性:无论是管理少量服务器还是数千台服务器,Ansible 都可以轻松扩展。
灵活性: Ansible 的模块化方法允许您根据需要自定义和扩展其功能。

结论

Ansible 是一款功能强大且易于使用的工具,可以极大地简化基础设施的管理。只需几行代码,您就可以自动执行复杂的任务,确保整个环境的一致性和可靠性。无论您是设置服务器、部署应用程序还是管理配置,Ansible 都可以帮助您更高效地完成工作。

明天,我们将深入探讨更高级的 Ansible 主题,探索可以将您的自动化提升到新水平的功能。敬请关注!

请务必在 LinkedIn 上关注我以获取最新更新: Shiivam Agnihotri

版本聲明 本文轉載於:https://dev.to/shivam_agnihotri/getting-started-with-ansible-the-beginners-guide-day-30-of-50-days-devops-tools-series-1iae?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • WebAssembly:您不知道自己需要的超能力
    WebAssembly:您不知道自己需要的超能力
    如果你在开发圈里潜伏了足够长的时间,你可能听说过关于 WebAssembly(或 Wasm,因为开发者喜欢缩写词,就像我喜欢的那样)咖啡)。 它曾经被誉为“下一件大事”,这是一款闪亮的新工具,承诺将您的浏览器从一个不起眼的文档查看器转变为一个成熟的超级英雄。好吧,WebAssembly 已经存在几年...
    程式設計 發佈於2024-11-08
  • 實施訂單處理系統:建立基礎部分
    實施訂單處理系統:建立基礎部分
    1. Introduction and Goals Welcome to the first part of our comprehensive blog series on implementing a sophisticated order processing system ...
    程式設計 發佈於2024-11-08
  • 理解 JavaScript 數組迭代方法
    理解 JavaScript 數組迭代方法
    我最近遇到一個面試問題,要求使用不同的方法來迭代 JavaScript 陣列物件。提示最初看起來很簡單,因為我需要提供一些範例程式碼片段。然而,這個問題引起了我的興趣,所以我決定更深入地研究每種方法,不僅探索如何使用它們,而且探索何時以及為何選擇一種方法而不是另一種方法。 在本文中,我將引導您了解...
    程式設計 發佈於2024-11-08
  • 如何在 Galera 叢集節點上設定 MariaDB/MySQL Exporter 以進行 Prometheus 監控
    如何在 Galera 叢集節點上設定 MariaDB/MySQL Exporter 以進行 Prometheus 監控
    社群開發者您好! ? 在這篇文章中,我將引導您完成在 Galera Cluster 節點上設定 MariaDB/MySQL Exporter 以使用 Prometheus 進行監控所採取的步驟。就我而言,我在具有三個節點的雲端伺服器供應商上運行 MariaDB Galera Cluster,並使用...
    程式設計 發佈於2024-11-08
  • 示範疼痛
    示範疼痛
    我想講述一件每次我需要做的事情時都困擾我的事情。它正在準備演示。一般來說,當我嘗試使用 Viktor Lidholt 的 slick_slides 來準備簡報時,我會在 PowerPoint 中準備簡報。  如何放置不同大小的圖像,如何選擇字體,使用什麼顏色,如何放置程式碼,如何突出顯示它,所有這些...
    程式設計 發佈於2024-11-08
  • 請求 Iris 的正文限制中間件
    請求 Iris 的正文限制中間件
    概述 Iris Body Limit 中間件是一個強大的工具,用於控制 Iris Web 應用程式中傳入請求正文的大小。透過設定請求正文的大小限制,您可以防止用戶端發送過大的負載,否則可能會壓垮您的伺服器或導致拒絕服務 (DoS) 攻擊。此中間件對於處理檔案上傳、JSON 有效負載...
    程式設計 發佈於2024-11-08
  • 如何在 cookie 中儲存 PHP 陣列以及安全性和序列化的最佳實踐是什麼?
    如何在 cookie 中儲存 PHP 陣列以及安全性和序列化的最佳實踐是什麼?
    在 Cookie 中儲存 PHP 陣列在 PHP 中,可以將陣列儲存在 Cookie 中,以便在後續請求時輕鬆檢索。然而,考慮安全隱患並使用正確的序列化技術至關重要。 序列化選項要將陣列轉換為cookie 相容格式,您可以選擇以下方法:JSONsetcookie('your_cookie_name'...
    程式設計 發佈於2024-11-08
  • 如何設定VS Code調試工作目錄?
    如何設定VS Code調試工作目錄?
    設定VS Code 中偵錯的工作目錄在Visual Studio Code (VS Code) 中偵錯Python 程式時,它通常很有用指定腳本應在其中執行的工作目錄。這允許您使用與程式碼所在的特定目錄相關的檔案和資源。 要將工作目錄動態設定為目前開啟的Python 檔案的目錄,請修改launch....
    程式設計 發佈於2024-11-08
  • 嬰兒學步學習 Laravel
    嬰兒學步學習 Laravel
    歡迎回來,開發者! ✨ 在Laravel 之旅的這一章中(請記住,我在撰寫這些文章時正在學習,因此這將是您能找到的最現實的教程系列之一!),我們將深入研究我們的Laravel 專案。我們將探索專案結構,熟悉遷移,並以最簡單的方式分解 MVC 架構。 ?今天的議程:...
    程式設計 發佈於2024-11-08
  • 如何動態包含具有不受控制的「document.write()」內容的腳本?
    如何動態包含具有不受控制的「document.write()」內容的腳本?
    動態新增具有不受控制的來源內容的腳本標記當內容來自於控制項外部時,建立具有外部來源的腳本標記可能會帶來挑戰包括使用document.write() 的程式碼。如前所述,僅在 中附加 script 標記無法支援此類內容。 要解決此問題,請考慮以下解決方案:使用 document.create 新建一...
    程式設計 發佈於2024-11-08
  • 在 JavaScript 中如何有效地確定一個數字是否為素數?
    在 JavaScript 中如何有效地確定一個數字是否為素數?
    在 JavaScript 中高效驗證素數在電腦程式設計中,決定給定數字是否是質數是一項基本任務。質數是大於 1 的正整數,除了 1 和它本身之外沒有正因數。 檢查素數的一種流行方法涉及埃拉托斯特尼篩法。然而,出於效能考慮,可以採用更有效的方法,如以下 JavaScript 實作所示:let inpu...
    程式設計 發佈於2024-11-08
  • 為什麼 Lambda 表達式需要最終局部變數而不是實例變數?
    為什麼 Lambda 表達式需要最終局部變數而不是實例變數?
    Lambda 表達式與變數作用域:為什麼Local ≠ Instance在Java 中使用lambda 表達式時,一個常見的困惑點是為什麼局部變數需要終結,而實例變數需要終結不要。本文旨在闡明這種差異背後的根本原因。 局部變數:最終性指令在 lambda 表達式中,局部變數必須標記為 Final 以...
    程式設計 發佈於2024-11-08
  • CKA 全程課程日 為什麼要使用 Kubernetes?
    CKA 全程課程日 為什麼要使用 Kubernetes?
    那么,您可能已经使用 Docker 容器有一段时间了,对吧?我知道旋转第一个容器的兴奋感就像魔法一样,但随后现实袭来。您开始注意到大规模管理容器很快就会成为物流噩梦。就在那时,Kubernetes(K8s)像经验丰富的项目经理一样进入房间,准备接管并简化一切。 在这篇文章中,我们将探讨独立容器面临的...
    程式設計 發佈於2024-11-08
  • 簡要封裝範例
    簡要封裝範例
    書包: 這個範例會建立一個名為 bookpack 的包,其中包含一個用於管理書籍資料庫的簡單類別。 圖書類別: 它有私有屬性 title、author 和 pubDate(標題、作者和出版日期)。 構造方法初始化屬性。 show() 方法顯示書籍詳細資料。 BookDemo類別: 建立一個包...
    程式設計 發佈於2024-11-08
  • 適用於 AWS 雲端的簡單 SaaS 的技術堆疊
    適用於 AWS 雲端的簡單 SaaS 的技術堆疊
    介绍 注1:这里是托管的交互式演示:demo.saasconstruct.com 注 2:我每个 SaaS 设置的每月账单为 3-5 美元,其中大部分是 CI/CD 成本。 注3:模板在这里:saasconstruct.com。 我在 AWS 上完成了多个 AI PoC 和 MVP...
    程式設計 發佈於2024-11-08

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3