Bootstrap

Ansible

概述

介绍

ansible是一种自动化运维工具,基于paramiko开发,并基于模块化工作。ansible本身没有批量部署的能力,真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。

ansible基于Python语言开发,由Paramiko和PyYAML两个关键模块构建,集合了众多运维工具的优点,实现批量系统配置、批量程序部署、批量运行命令等功能。

ansible不需要在远程主机上安装client/agents,它基于ssh来和远程主机进行通讯的。

特点

部署简单, 只需要在管理端部署ansible环境, 被管理端只需SSH和Python环境即可(no agents)

无服务端, 管理端不需要启动服务程序, 直接运行命令即可(no server)

基于模块工作, 可使用任意语言开发模块(modules in any languages)

利用剧本编写来实现自动化, 基于yaml语法编写playbook(playbook)

默认使用SSH(Secure Shell)协议对设备进行管理(ssh by default)

模块幂等, 定义的任务已存在则不会做什么事情, 即同一台服务器多次执行同一个playbook是安全的

目录

  • 配置文件: /etc/ansible/

  • 执行文件: /usr/bin/

  • lib依赖库: /usr/lib/python2.7/site-packages/ansible/

  • help文件: /usr/lib/python2.7/site-packages/ansible

架构

Ansible:ansible核心

Host Inventory:主机清单配置,记录由ansible管理的主机信息,包括IP、端口、密码等(/etc/ansible/hosts)

Core Modules:ansible自带模块

Custom Modules:用户可扩展模块

Playbooks:定义ansible任务的剧本,可以将多个任务定义在一个playbook中,由ansible自动执行.

Plugins:通过插件实现记录日志、发送邮件等功能

Connection Plugins:ansible基于连接插件连接到远程主机,默认使用ssh

离线部署

模块安装

依次安装

依赖

#yum -y install python-devel openssl-devel libffi-devel libyaml-devel gcc c++ gcc-c++

setuptools

#unzip setuptools-45.0.0.zip
#cd setuptools-45.0.0
#python setup.py install

pycrypto

#tar xzvf xxx
#cd xxx
#python setup.py install

PyYAML

#tar xzvf xxx
#cd xxx
#python setup.py install

MarkupSafe

#tar xzvf xxx
#cd xxx
#python setup.py install

Jinja2

#tar xzvf xxx
#cd xxx
#python setup.py install

ecdsa

#tar xzvf xxx
#cd xxx
#python setup.py install

simplejson

#tar xzvf xxx
#cd xxx
#python setup.py install

pycparser

#tar xzvf xxx
#cd xxx
#python setup.py install

cffi

#tar xzvf xxx
#cd xxx
#python setup.py install

ipaddress

#tar xzvf xxx
#cd xxx
#python setup.py install

six

#tar xxx
#cd xxx
#python setup.py install

asn1crypto

#tar xzvf xxx
#cd xxx
#python setup.py install

idna

#tar -xzf xxx
#cd xxx
#python setup.py install

pyasn1

#tar xxx
#cd xxx
#python setup.py install

PyNaCl

#tar xzvf xxx
#cd xxx
#python setup.py install

cryptography

#tar xzvf xxx
#cd xxx
#python setup.py install

bcrypt

#tar xzvf xxx
#cd xxx
#python setup.py install

paramiko

#tar xzvf xxx
#cd xxx
#python setup.py install

ansible

#tar xzvf xxx
#cd xxx
#python setup.py install

rpm安装

1,找一台能上网的主机下载rpm包

#yumdownloader ansible python-netaddr --resolve  --destdir=/hdfs/packages/ansible/

2,将下载好的rpm包放置主机B,执行以下命令安装ansible

#rpm -ivh ./*.rpm --force --nodeps

集群免密

1,生成密钥文件

#ssh-keygen
id_rsa : 生成的私钥文件
id_rsa.pub :生成的公钥文件
know_hosts : 已知的主机公钥清单

2,传密钥文件

#ssh-copy-id  -i ${IP}

或者将 `主控端` 的公钥文件(id_rsa.pub)写入 `被控端` 的 `authorized_keys` 文件(如没有,新建该文件)

配置文件

主目录:/etc/ansible

ansible.cfg:是ansible执行需求的全局性、默认的配置文件

hosts:默认的主机资产清单文件

ansible.cfg

[defaults] #全局变量
#定义hosts文件路径,支持相对路径
inventory = /hdfs/project/ansible/hosts
#定义扩展库路径
#library = /usr/share/ansible
#并发连接数,默认为5
forks = 10
#设置默认执行命令的用户
sudo_user = root
#指定连接被管节点的管理端口,默认为22端口,建议修改,能够更加安全
remote_port = 22
#设置是否检查SSH主机的密钥,值为True/False。关闭后第一次连接不会提示配置实例
host_key_checking = False
#设置SSH连接的超时时间,单位为秒
timeout = 60
#指定一个存储ansible日志的文件(默认不记录日志)
log_path = /hdfs/project/ansible/ansible.log

hosts

[test] #组名
192.168.2.102 #IP
test ansible_ssh_port=22 ansible_ssh_host=192.168.2.102 #别名

参数
ansible_ssh_host #指定主机别名的真实 IP
ansible_ssh_port #指定主机的 ssh 端口
ansible_ssh_user #指定主机的登录用户
ansible_sudo_pass #主机的 sudo 密码

命令参数

-v:输出详细信息(可以使用多个v)
-i PATH:指定hosts文件位置
-f NUM :指定开启的进程数(默认为5)
-m MOULE :指定module的名称(默认为command)
-m DIRECTORY:指定module的目录来加载module,默认是/usr/share/ansible
-a MODULE_ARGS:指定module模块的参数
-k:提示输入ssh的密码,而不是使用基于ssh的密钥认证
-u USERNAME:指定移动端的执行用户
-C:测试此命令执行会改变什么内容,不会真正的去执行
-b:sudo操作,配合-K 使用;(ansible test -utest -K -m shell -a "cp /root/test.txt /root/test.txt_1" -b)

测试

#ansible test  -m  ping

多个主机组用 :隔开,test:sdp

#ansible  test:sdp -m  ping

所有主机是用 all

#ansible  all  -m  ping

常用模块

shell

默认ansible使用的module 是 command, 这个模块并不支持 shell 变量和管道等,若想使用shell 来执行模块,请使用-m 参数指定 shell 模块,但是值得注意的是普通的命令执行模块是通过python的ssh执行

#ansible test -m shell -a 'echo $PATH'

copy

实现主控端向目标主机拷贝文件,类似于scp的功能

#ansible test -m copy -a 'src=/hdfs/project/ansible/hosts  dest=/hdfs/project/'
src=/hdfs/project/ansible/hosts #主控端文件
dest=/hdfs/project/ #目标主机路径

yum

apt、yum模块分别用于管理ubuntu系列和redhat系列系统软件包

#ansible test -m yum -a 'name=httpdstate=present'
state=present #安装
state=latest #更新至最新版
state=absent #卸载

service

#ansible test -m service -a 'name=httpdstate=started'
state=started #启动
state=restarted #重启
state=stopped #关闭

command

默认模块,用于运行系统命令,比如echohello。不支持shell变量和管道。

playbook

核心组件

tasks:任务
variables:变量
templates:模板
handlers:处理器
roles:角色

xxx.yml yml格式结尾文件

示例文件

- hosts: test                                                   #对应hosts文件主机组或者主机ip
  remote_user: root                                             #执行用户
  vars:
    httpd_port: 80                                              #定义变量。字母数字下划线组成,只能以字母开头,多个多行

  tasks:                                                        #定义任务
#  - name: 复制文件                                              #定义单个任务
#    copy: src=/hdfs/project/ansible/sysctl.conf  dest=/etc/     #设定使用的的模块以及模块命令参数 yum,参照模块使用规则
#    register: shell_result                                      #定义变量存储返回的结果,一个name下只能存在一个register-debug,且置于name结尾段
#  - debug: var=shell_result.stdout_lines verbosity=0            #debug模块显示输出的结果
#
#  - name: sysctl 生效
#    shell: "sysctl -p"
#    register: shell_result                                      #定义变量存储返回的结果,一个name下只能存在一个register-debug,且置于name结尾段
#  - debug: var=shell_result.stdout_lines verbosity=0            #debug模块显示输出的结果

  - name: 关闭防火墙
    service:
      name: firewalld
      state: stopped
      enabled: no

  - name: setenforce 0
    shell: "setenforce 0"
    register: shell_result                                      #定义变量存储返回的结果,一个name下只能存在一个register-debug,且置于name结尾段
  - debug: var=shell_result.stdout_lines verbosity=0            #debug模块显示输出的结果

  - name: sed 替换
    shell: "sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config"
    ignore_errors: True                                         #忽略错误
    register: shell_result                                      #定义变量存储返回的结果,一个name下只能存在一个register-debug,且置于name结尾段
  - debug: var=shell_result.stdout_lines verbosity=0            #debug模块显示输出的结果

执行命令

#ansible-playbook  test.yml

shell脚本

- hosts: test
  remote_user: root

  tasks:                                                        #定义任务
  - name: 复制文件                                              #定义单个任务
    copy: src=/hdfs/project/ansible/test.sh  dest=/hdfs/project/        #设定使用的的模块以及模块命令参数 yum,参照模块使用规则
    register: shell_result                                      #定义变量存储返回的结果,一个name下只能存在一个register-debug,且置于name结尾段
  - debug: var=shell_result.stdout_lines verbosity=0            #debug模块显示输出的结果

  - name: 执行脚本
    shell: "cd /hdfs/project && sh test.sh"
    register: shell_result                                      #定义变量存储返回的结果,一个name下只能存在一个register-debug,且置于name结尾段
  - debug: var=shell_result.stdout_lines verbosity=0            #debug模块显示输出的结果

;