Ansible
常见错误 http://afewbug.com/article/26
官方文档 http://docs.ansible.com/ansible/
安装配置 http://sofar.blog.51cto.com/353572/1579894

目录
一、介绍
二、yum安装
三、Ansible配置
四、模块
五、playbook
六、实战演练--用Ansible实现LANMP的安装

注意:以下实验环境均为关闭selinux和清空防火墙配置,需要把/etc/my.cnf 改为/etc/my.cnf.bak

一、介绍
特性
(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:可实现多级指挥。

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

二、yum安装

yum install -y epel-release
yum install -y ansible

附注:编译安装参考上述链接

三、Ansible配置
(1)SSH免密钥登陆设置具体参考SSH密钥登陆

http://www.cnblogs.com/ImJerryChan/p/6002508.html

(2)ansible配置
主机组配置参考:

# vi  /etc/ansible/hosts
# 在里面增加如下配置增加
[testhost]
127.0.0.1
192.168.75.135

配置解析:
在/etc/ansible/hosts文件里指定被监控的主机
其中testhost为自定义的主机组名。
下面两个ip为组内的机器ip。

(3)简单测试

ansible 192.168.75.135 -m command -a 'w'   或者
ansible testhost -m command -a 'w'

如果结果为如下配置,则配置成功

附注:
错误: "msg": "Aborting, target uses selinux but python bindings (libselinux-python) aren't installed!"
解决办法: yum install -y libselinux-python

四、模块
五、playbook
这两个部分过两天再补充吧,毕竟现在还没学完呢,路还很长

六、实战演练--用Ansible实现LANMP的安装

(这个也属于一个未完成版,因为在写这篇文章的时候还在敲其余部分的代码,因此这一两天内补上吧,MySQL部分实验没问题)
(一)Mysql

cd /etc/ansible
mkdir mysql_install
mkdir -p mysql_install/roles/{common,delete,install}/{handlers,files,meta,tasks,templates,vars} cd mysql_install/roles
//安装前准备
vi ./common/tasks/main.yml
- name: Install initialization require software
yum: name={{ item }} state=installed
with_item:
- gcc
//安装过程
vi ./install/vars/main.yml
mysql_user: mysql
mysql_port:
mysql_data_dir: /data/mysql
mysql_version: 5.5. ls ./install/templates
/etc/init.d/my.cnf /etc/init.d/mysqld
分别为配置文件以及启动文件,也就是要拷贝进去 ls ./install/files
mysql-5.5..tar.gz
data_mysql.tar.gz
同上,一个小建议就是打包的时候最好到文件/目录所在处再打包,否则如果前面跟了目录的话,会把目录也打包进来的 vi ./install/tasks/copy.yml
- name: Copy MySQL Software To Redhat client
copy: src=mysql-{{ mysql_version }}.tar.gz dest=/usr/local/src/mysql-{{ mysql_version }}.tar.gz owner=root group=root
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >=
- name: Uncompression MySQL Software To Redhat Client
shell: tar zxf /usr/local/src/mysql-{{ mysql_version }}.tar.gz -C /usr/local/
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >=
- name: Copy Data_Dir To Redhat client
copy: src=data_mysql.tar.gz dest=/usr/local/src/data_mysql.tar.gz owner=root group=root
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >=
- name: Uncompression Data_Dir To Redhat Client
shell: tar zxf /usr/local/src/data_mysql.tar.gz -C /
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >=
- name: Copy MySQL Start Script To Redhat Client
template: src=mysqld dest=/etc/init.d/mysqld owner=root group=root mode=
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >=
- name: Copy MySQL Config To Redhat Client
template: src=my.cnf dest=/etc/init.d/my.cnf
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >= vi ./install/tasks/install.yml
- name: Create MySQL User In Redhat Client
user: name={{ mysql_user }} state=present createhome=no shell=/sbin/nologin
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >=
- name: Start MySQL Service In Redhat Client
service: name=mysqld state=started#
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >=
- name: Add Boot Start MySQL Service In Redhat Client
shell: chkconfig --level mysqld on
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >= vi ./install/tasks/delete.yml
- name: Delete MySQL compression Software In Redhat Client
shell: rm -rf /usr/local/src/mysql-{{ mysql_version }}.tar.gz
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >= vi ./install/tasks/main.yml
- include: copy.yml
- include: install.yml
- include: delete.yml
//卸载过程
vi ./delete/vars/main.yml
mysql_user: mysql
mysql_port:
mysql_data_dir: /data/mysql
mysql_version: 5.5.-linux2.-x86_64 vi ./delete/tasks/delete.yml
- name: Stop MySQL Service
shell: ps -ef|grep mysql|grep -v grep|awk '{print $2}'|xargs kill - >>/dev/null >&
ignore_errors: yes
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >=
- name: Delete MySQL Boot Start Script
shell: chkconfig --del mysql
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >=
- name: Delete MySQL Dir
shell: rm -rf /usr/local/mysql
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >=
- name: Delete MySQL User
shell: userdel {{ mysql_user }}
ignore_errors: yes
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >=
- name: Delete MySQL Service Start Script
shell: rm -rf /etc/init.d/mysqld
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >=
- name: Delete MySQL Service Config File
shell: rm -rf /etc/init.d/my.cnf
when: ansible_os_family == "RedHat" and ansible_distribution_version|int >= vi ./delete/tasks/main.yml
- include: delete.yml
//MySQL主入口配置文件
cd ../
vi install.yml
---
- hosts: 192.168.75.135
remote_user: root
gather_facts: True
roles:
- common
- install vi delete.yml
---
- hosts: 192.168.75.135
remote_user: root
gather_facts: True
roles:
- delete
完毕
安装MySQL:ansible-playbook install.yml
卸载MySQL:ansible-playbook delete.yml

我的Ansible学习笔记的更多相关文章

  1. ansible学习笔记一

    ansible学习笔记一 参考博客: ansible学习 - 51CTO博客 一.安装 1 .下载epel源 wget -O /etc/yum.repos.d/epel.repo http://mir ...

  2. Ansible 学习笔记

    最近因为需要管理很多台机器,而这些机器又需要频繁重新安装,实在受不了Puppet需要在每个客户机上都安装一遍,于是转头开始学些Ansible.根据这段时间的使用,这个确实是神器,唯一的感觉就是相见恨晚 ...

  3. ansible学习笔记三:playbook和roles

    参考博客: Ansible 系列之 Playbooks 剧本 -飞走不可(博客园) linux运维学习之ansible的playbook及roles的使用 - 51CTO博客 nginx 基于uwsg ...

  4. Ansible学习笔记

    一.Ansible简介 Ansible是一种agentless(基于ssh),可实现批量配置.命令执行和控制,基于Python实现的自动化运维工具. 其特性有: ①模块化:通过调用相关模块,完成指定任 ...

  5. ansible学习笔记二

    Ad-Hoc命令: 所谓Ad-Hoc,简而言之是"临时命令",英文中作为形容词有"特别的,临时"的含义.Ad-Hoc只是官方对Ansible命令的一种称谓. 从 ...

  6. Ansible学习笔记(一):部署管理Windows机器遇到的一些坑

    在给国盛通上海测试环境做Ansible管理Windows服务器的时候,遇到了一些坑,Google解决掉了,特此记录,坑用红色标记. 一.环境说明 1.Ansible管理主机 操作系统:CentOS 7 ...

  7. Ansible学习记录一:Linux下部署

    0.Ansible介绍 Ansible 是一个简单的自动化运维管理工具,可以用来自动化部署应用.配置.编排 task(持续交付.无宕机更新等),采用 paramiko 协议库(fabric 也使用这个 ...

  8. ansible2.7学习笔记系列

    写在前面:ansible的资料网上很多,本人也是参考网上资料,做总结,如有错误,麻烦指出,谢谢. 所谓学习笔记,就是不断成长的过程,也许一段时间后有更深入理解了,就会继续更新笔记. 笔记定位:目前写的 ...

  9. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

随机推荐

  1. Python用MySQLdb, pymssql 模块通过sshtunnel连接远程数据库

    转载自 https://www.cnblogs.com/luyingfeng/p/6386093.html 安全起见,数据库的访问多半是要做限制的,所以就有一个直接的问题是,往往多数时候,在别的机器上 ...

  2. mysql 约束条件 auto_increment 自动增长

    约束字段为自动增长,被约束的字段必须同时被key约束 id自动增长,每插入一条记录,自动增长 创建一张表 t20 id 字段设置为 不为空 唯一 自动增长 mysql)); Query OK, row ...

  3. vs中nodejs代码 resharper 提示 ECMAScript2015 Feature. your Current language level is ECMAScript5的解决办法

    问题如图 错误信息:ECMAScript 2015 Feature. your Current language level is: ECMAScript5 解决方法, 打开 Resharper -& ...

  4. js如何转义和反转义html特殊字符

    “<”如何反转义为“<”,“>”如何反转义为“>”,下面就介绍如何用js来实现这种类似的操作. //HTML转义 function HTMLEncode(html) { var ...

  5. Spark Sql的UDF和UDAF函数

    Spark Sql提供了丰富的内置函数供猿友们使用,辣为何还要用户自定义函数呢?实际的业务场景可能很复杂,内置函数hold不住,所以spark sql提供了可扩展的内置函数接口:哥们,你的业务太变态了 ...

  6. POJ2653:Pick-up sticks(线段相交)

    题目:http://poj.org/problem?id=2653 题意:题意很简单,就是在地上按顺序撒一对木棒,看最后有多少是被压住的,输出没有被压住的木棒的序号.(有点坑的就是没说清楚木棒怎么算压 ...

  7. mysql 锁相关的视图(未整理)

    mysql 锁相关的视图 查看事务,以及事务对应的线程ID   如果发生堵塞.死锁等可以执行kill  线程ID  杀死线程      kill  199 SELECT * FROM informat ...

  8. vim使用winmanager整合nerd tree和taglist

    winmanager插件安装 • 插件简介 winmanager is a plugin which implements a classical windows type IDE in Vim-6. ...

  9. 列表中相同key的字典相加

    # 怎么把列表中相同key的字典相加,也就是id的值加id的值,doc_count的值加doc_count的值 # 目标列表 l=[{'id': 5, 'doc_count': 129}, {'id' ...

  10. PKU 2155 Matrix(裸二维树状数组)

    题目大意:原题链接 题意很简单,就不赘诉了. 解题思路: 使用二维树状数组,很裸的题. 二维的写起来也很方便,两重循环. Add(int x,int y,int val)表示(x,y)-(n,n)矩形 ...