Ansible基础

简介

ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。

核心组件
核心组件.png

  1. Ansible:核心程序
  2. Modules:包括Ansible自带的核心模块及自定义模块
  3. Plugins:完成模块功能的补充,包括连接插件、邮箱插件
  4. Playbooks:剧本;定义Ansible多任务配置文件,由Ansible自动执行
  5. Inventory:定义Ansible管理主机的清单
  6. Connection Plugins:负责和被监控端实现通信

特性

  1. 不需要在被管控主机上安装任何客户端
  2. 无服务器端,使用时直接运行命令即可
  3. 基于模块工作,可使用任意语言开发模块
  4. 使用yaml语言定制剧本playbook
  5. 基于SSH工作
  6. 可实现多级指挥
  7. 幂等性:一种操作重复多次结果相同

安装和配置

  • pip安装
  • 二进制
  • yum安装
[root@node1 ~]# rpm -qa | grep ansible
ansible-2.4.2.0-2.el7.noarch
[root@node1 ~]# ssh-keygen -P ""
[root@node1 ~]# ssh-copy-id -l /root/.ssh/id_rsa.pub root@node2

常用命令集

[root@node1 ~]# rpm -ql ansible | grep bin
/usr/bin/ansible
/usr/bin/ansible-config
/usr/bin/ansible-connection
/usr/bin/ansible-console
/usr/bin/ansible-doc
/usr/bin/ansible-galaxy
/usr/bin/ansible-inventory
/usr/bin/ansible-playbook
/usr/bin/ansible-pull
/usr/bin/ansible-vault
  • ansible:临时命令执行工具,常用于临时命令的执行
  • ansible-doc:Ansible模块功能查看工具
  • ansible-playbook:Ansible定制自动化的任务集编排工具
    [root@node1 ~]# rpm -ql ansible | grep etc
    /etc/ansible
    /etc/ansible/ansible.cfg
    /etc/ansible/hosts
    /etc/ansible/roles
  • ansible.cfg:主配置文件
  • hosts:主机清单
  • roles:角色目录

配置文件

[defaults]

# some basic default values...

#inventory      = /etc/ansible/hosts 主机列表配置文件
#library        = /usr/share/my_modules/ 库文件存放位置
#module_utils   = /usr/share/my_module_utils/ 
#remote_tmp     = ~/.ansible/tmp 生成的临时py命令文件存放在远程主机的目录
#local_tmp      = ~/.ansible/tmp 本机的临时命令执行目录
#forks          = 5 默认的并发数
#poll_interval  = 15 默认的线程池
#sudo_user      = root 默认sudo用户
#ask_sudo_pass = True
#ask_pass      = True
#transport      = smart
#remote_port    = 22
#module_lang    = C
#module_set_locale = False

主机清单的定义方式:
1.直接指明主机地址或主机名
2.定义一个主机组,调用的时候指定该组即可

  • 一般情况下我们的主配置文件保持默认就行!

命令说明

非全部!
[root@node1 ~]# ansible --help 
Usage: ansible <host-pattern> [options]
Define and run a single task 'playbook' against a set of hosts
Options:
    -a MODULE_ARGS, --args=MODULE_ARGS
    -C, --check
    -e EXTRA_VARS, --extra-vars=EXTRA_VARS
    -f FORKS, --forks=FORKS
    -i INVENTORY
    --list-hosts
    -m MODULE_NAME
    -M MODULE_PATH, --module-path=MODULE_PATH
    --syntax-check

Ansible命令执行过程:

  • 加载自己的配置文件 默认/etc/ansible/ansible.cfg
  • 加载自己对应的模块文件,如command
  • 通过ansible将模块或命令生成对应的临时py文件,并将该文件传输至远程服务器的
  • 对应执行用户的家目录的.ansible/tmp/XXX/XXX.PY文件。
  • 给文件+x执行
  • 执行并返回结果 删除临时py文件,sleep 0 退出

持续更新ing

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,366评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,521评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,689评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,925评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,942评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,727评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,447评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,349评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,820评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,990评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,127评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,812评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,471评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,017评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,142评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,388评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,066评论 2 355

推荐阅读更多精彩内容

  • ansible 系统架构 ansible简介ansible是新出现的自动化运维工具,ansible是一个配置管理和...
    运维阿文阅读 9,602评论 1 52
  • ansible 是一个轻量级的IT自动化工具,集合了众多运维工具(puppet、cfengine、chef、fun...
    我是浪子宕桑旺波阅读 9,239评论 0 1
  • 简介 ansible是一个简单的it自动化工具,可以实现批量进行系统配置,软件部署和运行命令等功能。基于pytho...
    clickdiff阅读 733评论 0 1
  • 一、ansible简介 1、ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(pu...
    任总阅读 2,700评论 0 0
  • 一、ansible基础 1、介绍 ansible是一个自动化运维工具,基于Python开发,集合了众多运维工具(p...
    姜饼人_9e7b阅读 4,558评论 0 1