CentOS 6.5 Ansible详细部署

一、ansible介绍

1、简介

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

(1)、连接插件connection plugins:负责和被监控端实现通信;

(2)、host inventory:指定操作的主机,是一个配置文件里面定义监控的主机;

(3)、各种模块核心模块、command模块、自定义模块;

(4)、借助于插件完成记录日志邮件等功能;

(5)、playbook:剧本执行多个任务时,非必需可以让节点一次性运行多个任务。


2、基础架构

3、特性

(1)、no agents:不需要在被管控主机上安装任何客户端;

(2)、no server:无服务器端,使用时直接运行命令即可;

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

(4)、yaml,not code:使用yaml语言定制剧本playbook;

(5)、ssh by default:基于SSH工作;

(6)、strong multi-tier solution:可实现多级指挥。

4、优点
(1)、轻量级,无需在客户端安装agent,更新时,只需在操作机上进行一次更新即可;
(2)、批量任务执行可以写成脚本,而且不用分发到远程就可以执行;
(3)、使用python编写,维护更简单,ruby语法过于复杂;
(4)、支持sudo。

5、任务执行流程

二、Ansible基础安装与配置

1、安装ansible

为了快速部署,我们这里不使用编译安装,我们使用epel源里面的rpm包

# yum install ansible

2、配置hosts文件

# vim /etc/ansible/hosts

我们可以看到有好多事例,我们可以注释掉他们,或者删掉他们,我们这里注释掉他们,在vim模式下

:%s/^\([^[:space:]#]\)/#\1/g

然后添加我们需要操作的主机,假设我就管理这两台主机。

[webserver]
10.0.0.16
10.0.0.13

3、配置主机无密钥登录

# ssh-copy-id -i ~/.ssh/id_rsa.pub 10.0.0.16

[email protected]‘s password: 
Now try logging into the machine, with "ssh ‘10.0.0.16‘", and check in:
  .ssh/authorized_keys
to make sure we haven‘t added extra keys that you weren‘t expecting.

三、案例测试

ansible <host-pattern> [-f forks] [-m module_name] [-a args]

1、对所管辖的主机进行Ping操作

# ansible all -m ping

10.0.0.13 | success >> {
    "changed": false, 
    "ping": "pong"
}

10.0.0.16 | success >> {
    "changed": false, 
    "ping": "pong"
}

2、查看两台主机的时间

# ansible all -a ‘date‘

10.0.0.16 | success | rc=0 >>
Tue Nov 17 15:57:16 CST 2015

10.0.0.13 | success | rc=0 >>
Tue Nov 17 15:57:17 CST 2015

注:完整命令是ansible all -m command -a ‘date‘,-m command默认可以省略

3、复制文件

命令ansible-doc -l可以查看很多可以操作的模块,具体查看某个模块操作用ansible-doc -s module,例如ansible-doc -s copy

# ansible webserver -m copy -a "src=/root/cmdline-jmxclient-0.10.3.jar dest=/root"

10.0.0.13 | success >> {
    "changed": true, 
    "checksum": "98650e89f3c174b68971098618c2126b6cc1ab8b", 
    "dest": "/root/cmdline-jmxclient-0.10.3.jar", 
    "gid": 0, 
    "group": "root", 
    "md5sum": "ea665f2c562fc6aca3578cae46520b6d", 
    "mode": "0644", 
    "owner": "root", 
    "size": 20124, 
    "src": "/root/.ansible/tmp/ansible-tmp-1447747792.14-265823444157691/source", 
    "state": "file", 
    "uid": 0
}

10.0.0.16 | success >> {
    "changed": true, 
    "checksum": "98650e89f3c174b68971098618c2126b6cc1ab8b", 
    "dest": "/root/cmdline-jmxclient-0.10.3.jar", 
    "gid": 0, 
    "group": "root", 
    "md5sum": "ea665f2c562fc6aca3578cae46520b6d", 
    "mode": "0644", 
    "owner": "root", 
    "size": 20124, 
    "src": "/root/.ansible/tmp/ansible-tmp-1447747792.15-265197722191280/source", 
    "state": "file", 
    "uid": 0
}
时间: 2024-08-23 10:39:09

CentOS 6.5 Ansible详细部署的相关文章

自动化运维工具Ansible详细部署 (转载)

自动化运维工具Ansible详细部署 标签:ansible 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://sofar.blog.51cto.com/353572/1579894 ========================================================================================== 一.基础介绍 ===========================

自动化运维工具Ansible详细部署

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://sofar.blog.51cto.com/353572/1579894 ========================================================================================== 一.基础介绍 =========================================================

centos7源码编译安装Ansible详细部署

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

ansible自动部署 zabbix-agent 的模块

ansible自动部署 zabbix-agent 模块  的准备阶段 ansible所在的服务端可以免密钥登录所被部署的机器称为客户端. 免密钥的做法 服务端 ssh-keygen  一路回车生成密钥对 ssh-copy-id 指定IP 将公钥发给指定的ip 即可 ssh-copy-id 192.168.1.18 下面红色是代表文件或目录  黑色字体代表是内容 使用了 roles 方法  整体的目录结构是 /etc/ansible/zabbix-agent.yml [[email protect

Ansible 批量部署平台

Ansible 介绍以及基本命令 Ansible 简介:Ansible 和目前市面上一些其他的项目管理工具有很大的不同,它的设计初衷就是为了更方便.快捷的进行配置管理.它易于安装和实用,语法也非常简单易学.可以使用 Ansible 将平常复杂的配置工作变得简单.更加标准化和更容易控制.Ansible 只需要在一台普通的服务器上运行即可,不需要在被管控的服务器上安装客户端,因为它是基于 SSH 的.Linux 服务器离不开 SSH,所以 Ansible 不需要为配置工作添加额外的支持,可通过命令行

在Linux(CentOS)上安装MySql详细记录

前记:  毕业两年了,前两天换了份工作,由以前的传统行业跳到了互联网行业.之前的公司一直在用WinServer2003+Tomcat+SqlServer/Oracle这套部署环境.对于Linux+Tomcat(或其他容器)+Mysql这套之前没用用过.所以利用这周末的我在阿里云上49元搞了个linux(centos 64位)的服务器. 刚开始先装了JDK1.6,安装了Tomcat6.0.这过程中没有遇到太大的问题, 小问题也google一下就解决了.而周六晚上开始安装Mysql,于是到今天下午为

CloudStack+XenServer详细部署方案创建高级网络资源域

CloudStack+XenServer详细部署方案(5):创建高级网络资源域 本文将根据设计文档结合和之前创建的XenServer 资源池, 介绍CloudStack高级网络资源域的创建过程. Step1. 选择高级网络模式, 单击下一步.   Step2. 配置域信息. 域名称: shenzone DNS: 10.1.1.11 Hypervisor 类型: XenServer 网络域: shenzone.com 来宾网络CIDR: 192.168.100.0/24 公共: 是   注: 此处

实战:ansible自动化部署nginx+keepalived+mysql负载均衡集群

一.目的 使用ansible自动化部署nginx+keepalived+mysql负载均衡集群. 二.拓扑规划 三.详细步骤 1.环境的搭建 (1).安装ansible,同时配置私钥免密码进行通信 [[email protected] ~]# ssh-keygen  -t rsa #-t表示使用的加密类型,其中rsa1表示version1版本,rsa.dsa.ecdsa的加密对于的是version2版本 Generating public/private rsa key pair. #这里询问你

Centos6.5利用RubyGems的fpm制作zabbix_agent的rpm包,并使用ansible批量部署

一. 搭建rpm包制作环境 安装gcc [[email protected] ~]# yum install gcc 安装make [[email protected] ~]# yum install make 安装ruby源(ruby版本必须要在1.9.3以上,centos自带的是1.8的版本,需要自己编译安装) [[email protected] ~]# yum install ruby rubygems ruby-devel 查看ruby源 [[email protected] ~]#