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. 002-Spring Boot将WAR文件部署到Tomcat

    一.概述 springboot 带有内置Tomcat 服务器,可以直接将项目打包成jar运行,如果在需要把项目打成war包,使用外置tomcat部署.下面是将springboot项目部署为war项目的 ...

  2. FB05付款清帐Function

    函数组:FIPI-->内部FI过帐接口1.CALL FUNCTION 'POSTING_INTERFACE_START'. -->Initial information for inter ...

  3. Flask与pyaudio实现音频数据流的传输(电话会议语音交互式应用)

    1.声卡设备验证 #查看音频设备 dong@dong-ubuntu:~$ arecord -l**** CAPTURE 硬體裝置清單 ****card 0: PCH [HDA Intel PCH], ...

  4. 在MFC里面使用ADO访问微软的ACCESS数据库 实现增删改查

    声明:百度以外的公司可以自由转载该文. 正如我上一篇博文提到,ADO这货和MFC没有任何关系,ADO 是一个独立的组件.所以为了使用ADO 我们就要把ADO引入到MFC中. ADO是硬盘上的表现形式是 ...

  5. IOS中程序如何进行推送消息(本地推送,远程推送)2(下)

    内容中包含 base64string 图片造成字符过多,拒绝显示

  6. NHibernate和Castle调试过程中,如何输出SQL的问题

             首先,我在此需要强调的是,不管是Castle或者NHibernate输出SQL,都应该是属于NHibernate的技术,Castle的本身也是基于NHibernate开发的ORM框架 ...

  7. 跨域问题-nginx代理

    有时候我们跨域是借助了浏览器对 Access-Control-Allow-Origin 的支持.但有些浏览器是不支持的,所以这并非是最佳方案现在我们来利用nginx 通过反向代理 满足浏览器的同源策略 ...

  8. HDU - 4786 Fibonacci Tree (MST)

    题意:给一张由白边和黑边构成的无向图,求是否存在一个生成树,使白边的数量为一个斐波那契数. 分析:白边权值为1,黑边权值为0.求出该图的最小生成树和最大生成树,若这两个值之间存在斐波那契数,则可以,若 ...

  9. iOS 关于BTC 一些知识点

    1.BTC 用这个网 可以校验 自己的库生成的助记词 地址 是否是合法正常的 https://iancoleman.io/bip39/ 2.知晓 BTC 钱包是否有钱 和交易记录 https://te ...

  10. Java应用开发中的SQL注入攻击

    1. 什么是SQL注入攻击? SQL注入攻击是黑客对数据库进行攻击的常用手段之一.随着B/S模式应用开发的发展,使用这种模式编写应用程序的程序员越来越多.但是由于程序员的水平及经验参差不齐,相当一部分 ...