自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

初步利用Ansible實(shí)現(xiàn)批量服務(wù)器自動(dòng)化管理

開發(fā) 開發(fā)工具
Ansible以其簡單、高效、無agent成為廣泛使用的自動(dòng)化工具, 可以應(yīng)用于配置管理、應(yīng)用部署、任務(wù)調(diào)度等。

Ansible介紹

Ansible是一款開源的自動(dòng)化運(yùn)維工具, 在2012年由Michael DeHaan創(chuàng)建, 現(xiàn)在由Red Hat維護(hù)。Ansible是基于Python開發(fā)的,采用YAML語言編寫自動(dòng)化腳本playbook, 可以在Linux、Unix等系統(tǒng)上運(yùn)行, 通過SSH協(xié)議管理節(jié)點(diǎn), 無需在被管理節(jié)點(diǎn)安裝agent。Ansible以其簡單、高效、無agent成為廣泛使用的自動(dòng)化工具, 可以應(yīng)用于配置管理、應(yīng)用部署、任務(wù)調(diào)度等。

Ansible能夠自動(dòng)管理遠(yuǎn)程系統(tǒng)和控制它們的期望狀態(tài), 一個(gè)基礎(chǔ)Ansible環(huán)境主要包含三大組件:

  • 控制節(jié)點(diǎn) - 安裝有Ansible的系統(tǒng)。我們可以在控制節(jié)點(diǎn)上運(yùn)行Ansible命令,如ansible或ansible-inventory。
  • 管理節(jié)點(diǎn) - Ansible控制的遠(yuǎn)程系統(tǒng)或主機(jī)。
  • 清單 - 在邏輯上組織起來的受控節(jié)點(diǎn)列表。在控制節(jié)點(diǎn)上創(chuàng)建清單,用來描述Ansible管理的主機(jī)部署。

架構(gòu)如下:

Ansible安裝和配置

在我實(shí)驗(yàn)的環(huán)境中, 我分配了四臺(tái)虛擬機(jī),IP地址分別為:192.168.201.202 -205, 其中192.168.201.202是主控端, 需要在該機(jī)器上安裝Ansible; 另外從203-205的三臺(tái)機(jī)器為受控端, 接收從202發(fā)來的指令。這里我安裝的Linux系統(tǒng)為ubuntu 22.04.3 LTS版本,直接輸入以下命令安裝:

# apt install ansible

安裝完成后輸入命令: ansible --version查看版本號(hào),如圖:

接下來需要配置管理hosts, 在目標(biāo)目錄新建一個(gè)名為hosts的清單文件:/etc/ansible/hosts, 注意:如果/etc/下沒有ansible目錄,需要手動(dòng)新建一個(gè)。

編輯hosts文件,輸入以下格式內(nèi)容,如圖:

在標(biāo)簽名稱下的三個(gè)IP地址是我的另外三臺(tái)虛擬機(jī),它們將接收ansible的統(tǒng)一管理。保存退出。

在命令行輸入命令:

# ansible all --list-hosts

該命令將驗(yàn)證清單中的主機(jī), 返回信息如下:

在控制節(jié)點(diǎn)192.168.201.202中, 我們需要生成一個(gè)SSH的密鑰對,輸入以下命令:

# ssh-keygen -t rsa

中間提示一律按回車鍵即可, 結(jié)束后將在~/.ssh目錄下生成id_rsa和id_rsa.pub兩個(gè)密鑰文件,我們要將公鑰id_rsa.pub文件發(fā)送到三臺(tái)虛擬機(jī)上(192.168.201.203-205), 分別輸入以下命令:

# ssh-copy-id root@192.168.201.203
# ssh-copy-id root@192.168.201.204
# ssh-copy-id root@192.168.201.205

執(zhí)行結(jié)果如下:

接下來我們輸入以下命令進(jìn)行免密碼登錄驗(yàn)證:

此時(shí), 我們可以輸入以下命令進(jìn)行批量主機(jī)管理測試:

# ansible all -m ping

返回結(jié)果如下:

可以看到, 三臺(tái)受管理的主機(jī)已經(jīng)全部Ping通。

創(chuàng)建清單

通過清單文件, Ansible可以通過單個(gè)命令管理大量主機(jī), 且可以通過減少需要指定的命令行選項(xiàng)數(shù)量來幫助我們更有效地使用Ansible,例如:清單通常包含SSH用戶, 因此在運(yùn)行Ansible命令時(shí)可以不需要包含-u參數(shù)來指定用戶名。

在任意目錄創(chuàng)建一個(gè)名為inventory.yaml的文件, 這里我把清單文件建在目錄: /home/inventory.yaml, 內(nèi)容如下:

下面輸入命令進(jìn)行驗(yàn)證:

# ansible-inventory -i inventory.yaml --list

注意一下 -i 參數(shù)后面的yaml文件路徑, 我這里是cd到y(tǒng)aml文件的當(dāng)前目錄了, 所以直接跟的文件名, 在實(shí)際應(yīng)用過程中需要根據(jù)情況進(jìn)行全路徑和相對路徑的選擇。

該命令執(zhí)行返回結(jié)果如下:

接下來對清單中的受管節(jié)點(diǎn)執(zhí)行Ping操作, 執(zhí)行命令:

# ansible virtualmachines -m ping -i inventory.yaml

返回結(jié)果如下:

創(chuàng)建劇本(playbook)

劇本是Ansible用來部署和配置受管節(jié)點(diǎn)的自動(dòng)化藍(lán)圖,使用YAML格式編寫。

下面先解釋一下劇本的基本元素:

  • Play - 按順序排列的任務(wù)列表,與inventory中受管節(jié)點(diǎn)對應(yīng)映射。
  • 任務(wù)(task) - 定義Ansible要執(zhí)行的一個(gè)或多個(gè)模塊操作的列表。
  • 模塊:Ansible在受管節(jié)點(diǎn)上運(yùn)行的代碼單元或二進(jìn)制文件。Ansible的模塊按集合組織,每個(gè)模塊有一個(gè)完全限定的集合名稱(Fully Qualified Collection Name, FQCN)。

在上面的操作中,我們使用了ansible命令來ping清單中的主機(jī)。現(xiàn)在創(chuàng)建一個(gè)playbook,它不僅可以ping主機(jī),還可以打印“Hello world”消息。

繼續(xù)在/home目錄下創(chuàng)建一個(gè)名為playbook.yaml的文件, 輸入以下內(nèi)容:

在該配置文件中, 我們定義了一個(gè)劇本的名稱、定義了hosts名稱和具體的任務(wù)(tasks), 其中任務(wù)項(xiàng)這里包含兩個(gè): Ping主機(jī)和打印消息。

接下來我們看看劇本效果如何, 輸入以下命令:

# ansible-playbook -i inventory.yaml playbook.yaml

返回結(jié)果如下:

從結(jié)果來看,一切都OK, 成功執(zhí)行了我們的劇本并對三個(gè)目標(biāo)主機(jī)進(jìn)行了Ping。

責(zé)任編輯:趙寧寧 來源: 二進(jìn)制空間安全
相關(guān)推薦

2017-09-15 14:10:01

系統(tǒng)運(yùn)維服務(wù)器

2013-10-25 09:18:56

StarCluster服務(wù)器集群管理自動(dòng)化Amazon云

2017-03-14 11:17:06

自動(dòng)化系統(tǒng)服務(wù)器文檔

2021-11-01 10:26:08

傳感器農(nóng)業(yè)自動(dòng)化物聯(lián)網(wǎng)

2025-02-17 09:10:00

Ansible服務(wù)器日志

2018-08-31 09:55:38

Ansible網(wǎng)絡(luò)自動(dòng)化

2011-09-29 10:58:51

rBuilderLinux

2015-10-21 15:08:25

電纜自動(dòng)化

2011-05-24 10:12:53

VPSCrontab

2017-12-17 21:58:18

2024-01-10 17:24:00

2021-08-05 17:40:05

XpanesLinux服務(wù)器

2010-09-27 09:13:36

Visual Stud

2020-03-18 09:23:24

Python數(shù)據(jù)SQL

2011-05-10 14:35:07

TivoliIT服務(wù)管理整合

2009-04-16 17:14:52

2021-10-14 09:55:28

AnsibleanacronLinux

2021-11-10 09:00:00

工具Chef開發(fā)

2024-04-30 08:00:00

人工智能自動(dòng)化文件處理

2017-11-20 08:35:32

虛擬服務(wù)器自動(dòng)化
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)