1. 程式人生 > >Ansible實現批量管理伺服器

Ansible實現批量管理伺服器

Ansible介紹:

a. ansible是一個基於Python開發的自動化運維工具
b. ansible是一個基於ssh協議實現遠端管理的工具
c. ansible軟體可以實現多種批量管理操作(批量系統配置、批量軟體部署、批量檔案拷貝、批量執行命令)
saltstack puppet (都是類似軟體)

批量管理服務特徵介紹.

客戶端不需要啟動任何服務,服務端不需要任何的配置.

Server端安裝(管理端): yum -y install ansible.

ansible客戶端(受控端):沒有客戶端軟體安裝.

部署安裝流程(ansible自動化批量管理伺服器部署流程)CentOS6.9環境:

a.管理主機: 10.0.0.61 m01

受控主機:

10.0.0.41 backup(備份主機)

10.0.0.31 nfs01(nfs伺服器)

Ansible軟體自動化部署條件:

b.建議基於ssh金鑰方式建立遠端連線.

@1.ssh-keygen 建立金鑰對(管理主機上) ssh-keygen -t dsa

@2.分發公鑰檔案(管理主機進行分發)

ssh-copy-id -i /root/.ssh/id_dsa.pub 172.16.1.31

ssh-copy-id -i /root/.ssh/id_dsa.pub 172.16.1.41

ssh-copy-id -i /root/.ssh/id_dsa.pub 172.16.1.51

@3.檢查是否可以進行基於金鑰遠端管理;

  ssh ip uptime (ssh [email protected])

 免互動進行建立金鑰對和 免互動進行金鑰分發.

>/root/.ssh/known_hosts 追加輸出重定向, 清空 known_hosts 已連線主機列表.

ssh-keygen -t dsa (建立金鑰,需要進行人為干預)

ssh-keygen -t dsa -f /root/.ssh/id_rsa

-N/-P -N ""/-P""

 免互動實現金鑰的建立到指定的目錄下:   ssh-keygen -t dsa -f /root/.ssh/id_dsa -N ""

man ssh ssh-keygen

ssh-keygen - authentication key generation, management and conversion

需要安裝sshpass 軟體 yum -y install sshpass

 

 

免互動進行金鑰分發.

sshpass -p123456 ssh-copy-id -i /root/.ssh/id_dsa.pub 172.16.1.31

sshpass -p123456 ssh-copy-id -i /root/.ssh/id_dsa.pub "-o StrictHostKeyChecking=no 172.16.1.31"

批量建立金鑰對和批量分發金鑰指令碼:

#!/bin/bash

rm -f /root/.ssh/id*

ssh-keygen -t dsa -f /root/.ssh/id_dsa -N ""

for ip in 31 41 51 8

do

sshpass -p123456 ssh-copy-id -i /root/.ssh/id_dsa.pub "-o StrictHostKeyChecking=no $ip"

done

重新分發之前 cd /root/.ssh .

[[email protected] .ssh]# rm -f authorized_keys

刪除之後再在管理主機上執行免金鑰分發檔案.

ssh -o StrictHostKeyChecking 引數,實現免互動認證

 

基於ssh口令方式建立遠端連線(也可以)

 

 通過對vim /usr/bin/ssh-copy-id 修改這個檔案的埠,可以更改遠端SSH的埠

{ eval "$GET_ID" ; } | ssh  -p 52113 $1 "exec sh -c 'cd; umask 077; test -d .ssh || mkdir .ssh ; cat >> .s
sh/authorized_keys && (test -x /sbin/restorecon && /sbin/restorecon .ssh .ssh/authorized_keys >/
dev/null 2>&1 || true)'" || exit 1

c. ansible 軟體下載安裝

yum -y install ansible  服務端安裝軟體(ansible)

yum -y install libselinux-python 受控主機需要安裝這個軟體 

需要修改ansible.cfg  檔案

d.ansible軟體應用過程.

ansible-doc -l  檢視ansible的模組