热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Linux之Ansible的安装与使用(安装httpd和mysql)

一、Ansibleansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、che

一、Ansible

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

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

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

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

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

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

二、Ansible的安装

实验准备:

server1——Ansible管理结点(172.25.5.1)

server2和server3——node结点(172.25.5.2和172.25.5.3)

ansible相关软件

ansible-2.7.8-1.el7.noarch.rpm
libtomcrypt-1.17-25.el7.x86_64.rpm
libtommath-0.42.0-5.el7.x86_64.rpm
python2-crypto-2.6.1-13.el7.x86_64.rpm
python2-jmespath-0.9.0-1.el7.noarch.rpm
python-httplib2-0.9.2-0.1.el7.noarch.rpm
python-keyczar-0.71c-2.el7.noarch.rpm
python-paramiko-2.1.1-0.9.el7.noarch.rpm
sshpass-1.06-1.el7.x86_64.rpm

1. 安装软件,查看软件版本

yum install -y *.rpm
ansible --version #查看版本

2. 创建普通用户及ansible目录

一般情况下,是不允许root用户远程登录主机并对主机进行操控的,因此我们需要创建一个普通用户,用来进行自动化管理

inventory是Ansible管理主机信息的配置文件,相当于系统HOSTS文件的功能,默认存放在/etc/ansible/hosts。

[root@server1 ansible]# useradd devops
[root@server1 ansible]# passwd devops
[root@server1 ansible]# su - devops
[devops@server1 ~]$ ls
[devops@server1 ~]$ mkdir ansible
[devops@server1 ansible]$ vim ansible.cfg #主配置文件
[defaults]
inventory = ./inventory
[devops@server1 ansible]$ vim inventory #主机及组清单
[test] #组
172.25.5.2 #被管理的主机
[prod]
172.25.5.3

组与组之间可以相互调用,并且可以向组中的主机指定变量。不过,这些变量只能在Ansible-playbook中使用,而Ansible不支持。

#分别在server2和server3中创建devops用户并修改密码
[root@server2 ~]# useradd devops
[root@server2 ~]# passwd devops

3. 为server1建立免密连接方便管理

[devops@server1 ansible]$ ssh-keygen #生成公钥和私钥
[devops@server1 ansible]$ ssh-copy-id 172.25.5.2
[devops@server1 ansible]$ ssh-copy-id 172.25.5.3

4. 测试免密连接及ping模块

[devops@server1 ansible]$ ssh 172.25.5.2 #测试免密
[devops@server1 ansible]$ ssh 172.25.5.3
[devops@server1 ansible]$ ansible all -m ping #测试ping模块
[devops@server1 ansible]$ ansible all -m ping -u devops
[devops@server1 ansible]$ ansible all -m ping -u root #root用户是不允许登录的
[devops@server1 ansible]$ ansible all -m ping -u devops -b #普通用户切换为root身份

5. copy模块的使用

(1)普通文件的拷贝(普通用户和root都可以编辑的文件)

[devops@server1 ansible]$ ansible test -m copy -a "src=/etc/passwd dest=/tmp/passwd"
[devops@server1 ansible]$ ansible test -a "ls /tmp" #查看文件是否拷贝到指定目录
[devops@server1 ansible]$ ansible test -a "rm /tmp/passwd" #删除文件

(2)只允许root用户进行操作的文件,我们需要给普通用户下放权利,使devops用户也可以拷贝

[root@server2 ~]# vim /etc/sudoers
devops ALL=(ALL) NOPASSWD: ALL
[devops@server1 ansible]$ ansible test -m copy -a "src=/etc/passwd dest=/mnt/passwd" -b

(3)设置sudo为默认的切换方法,devops用户可以使用-b命令切换为root用户

[devops@server1 ansible]$ vim ansible.cfg
[defaults]
inventory = ./inventory[privilege_escalation]
become=True
become_method=sudo
become_user=root
become_ask_pass=False

三、ansible中的正则

[devops@server1 ansible]$ cat inventory
[test]
172.25.5.2[prod]
172.25.5.3
172.25.5.2
[webserver:children]
test
prod
[devops@server1 ansible]$ ansible 'test:prod' -m ping
[devops@server1 ansible]$ ansible 'test:!prod' -m ping
[devops@server1 ansible]$ ansible 'test:&prod' -m ping
[devops@server1 ansible]$ ansible webserver -m ping

四、Ansible中常用模块的使用

1. yum模块和servcie模块安装httpd服务

[devops@server1 ansible]$ ansible test -m yum -a "name=httpd state=present" #安装软件
[devops@server1 ansible]$ ansible test -a "rpm -q httpd" #查看软件是否安装
[devops@server1 ansible]$ ansible test -m service -a "name=httpd state=started" #开启服务
[devops@server1 ansible]$ ansible test -m service -a "name=httpd state=stopped" #关闭服务
[devops@server1 ansible]$ ansible test -m yum -a "name=httpd state=absent" #卸载软件

在server2中查看该服务是否安装和开启

[root@server2 ~]# systemctl status httpd
[root@server2 ~]# rpm -q | grep httpd

2. mariadb数据库的安装和使用

[devops@server1 ansible]$ ansible test -m yum -a "name=mariadb-server state=present"
[devops@server1 ansible]$ ansible test -m yum -a "name=MySQL-python state=present"
[devops@server1 ansible]$ ansible test -m service -a "name=mariadb state=started"
[devops@server1 ansible]$ ansible test -m mysql_user -a "name=jiang password=westos priv=*.*:select host='%' state=present" #创建用户并授权

在物理机中测试,是否可以远程登录数据库

[root@foundation5 ansible]# mysql -h 172.25.5.2 -u jiang -p

数据库中用户密码的设置

[devops@server1 ansible]$ ansible test -m user -a "name=jiang password={{ 'westos'|password_hash('sha512') }}" #hash加密用户密码
[devops@server1 ansible]$ ansible test -m user -a "name=jiang password={{ 'westos'|password_hash('sha512','mysalt') }}"

 


推荐阅读
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • CentOS系统安装与配置常见问题及解决方案
    本文详细介绍了在CentOS系统安装过程中遇到的常见问题及其解决方案,包括Vi编辑器的操作、图形界面的安装、网络连接故障排除等。通过本文,读者可以更好地理解和解决这些常见问题。 ... [详细]
  • 离线安装Grafana Cloudera Manager插件并监控CDH集群
    本文详细介绍如何离线安装Cloudera Manager (CM) 插件,并通过Grafana监控CDH集群的健康状况和资源使用情况。该插件利用CM提供的API接口进行数据获取和展示。 ... [详细]
  • ElasticSearch 集群监控与优化
    本文详细介绍了如何有效地监控 ElasticSearch 集群,涵盖了关键性能指标、集群健康状况、统计信息以及内存和垃圾回收的监控方法。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 基于Node.js、Express、MongoDB和Socket.io的实时聊天应用开发
    本文详细介绍了使用Node.js、Express、MongoDB和Socket.io构建的实时聊天应用程序。涵盖项目结构、技术栈选择及关键依赖项的配置。 ... [详细]
  • 搭建Jenkins、Ant与TestNG集成环境
    本文详细介绍了如何在Ubuntu 16.04系统上配置Jenkins、Ant和TestNG的集成开发环境,涵盖从安装到配置的具体步骤,并提供了创建Windows Slave节点及项目构建的指南。 ... [详细]
  • Django xAdmin 使用指南(第一部分)
    本文介绍如何在Django项目中集成和使用xAdmin,这是一个增强版的管理界面,提供了比Django默认admin更多的功能。文中详细描述了集成步骤及配置方法。 ... [详细]
  • 使用ASP.NET与jQuery实现TextBox内容复制到剪贴板
    本文将介绍如何利用ASP.NET结合jQuery插件,实现将多行文本框(TextBox)中的内容复制到用户的本地剪贴板上。该方法主要适用于Internet Explorer浏览器。 ... [详细]
  • Jenkins 安装指南:Windows 平台详解
    本文详细介绍了如何在Windows平台上安装和配置Jenkins,包括安装步骤、启动方法及基本的系统配置,旨在帮助初次使用者顺利搭建持续集成环境。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 谢邀。---2016.09.20补充---GitHub-gregmalcolmpython_koans:PythonKoans是个不错的练手项目,我还曾经给它贡献过代 ... [详细]
author-avatar
小菜刀丶
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有