主要完成通过playbook自动生成zabbix_server,agent,这里没有完全实现自动化,这里机器的获取还是需要人为手工填写,如果感兴趣想通过自动获取需要部署的机器可以通过namp扫描工具awk命令截取,这里不过多描述。我用两台机器做的测试,老版本的模块用法会有差异,如果无法执行可以通过官网去查看https://ansible-tran.readthedocs.io/en/latest/,参考文档https://www.cnblogs.com/LyShark/p/10886486.html

ansible 2.4.2

zabbix 3.4.15

  • 安装nmap扫描工具

    yum install nmap -y
    #通过ping探测172.16.9.0网段中存活机器
    nmap -sP 172.16.9.0/24

完成机器间的免密登录

  • 生成公钥对

    ssh-keygen -t rsa
  • 设置ansible hosts配置

    [test]
    172.16.9.141 ansible_ssh_user="root" ansible_ssh_pass="root"
    172.16.9.142 ansible_ssh_user="root" ansible_ssh_pass="root" [zabbix_server]
    172.16.9.141
    [zabbix_client]
    172.16.9.142
  • 批量推送公钥到集群节点

    - hosts: test
    user: root
    tasks:
    - name: ssh-copy
    authorized_key: user=root key="{{ lookup('file', '/root/.ssh/id_rsa.pub') }}"
    tags:
    - sshkey

    报错:

    FAILED! => {"msg": "Using a SSH password instead of a key is not possible because Host Key checking is enabled and sshpass does not support this.  Please add this host's fingerprint to your known_hosts file to manage this host."}

    解决:

    /etc/ansible/ansible.cfg

    修改host_key_checking(默认是check的)

  • playbook构建zabbix_server(官方建议一个play写一个独立的任务,测试不过多计较了)

    # 初始化,关闭防火墙和SELINUX
    - hosts: zabbix_server
    tasks:
    - name: off selinux
    shell: setenforce 0
    - name: seline modify enforcing
    lineinfile:
    dest: /etc/selinux/config
    regexp: '^SELINUX='
    line: 'SELINUX=disabled'
    - name: seline firealld
    shell: systemctl stop firewalld && systemctl disable firewalld
    # 安装部署LAMP环境,通过YUM模块快速安装
    - hosts: zabbix_server
    tasks:
    - name: install LAMP
    yum: name={{item}} state=installed
    with_items:
    - httpd
    - httpd-devel
    - mariadb
    - mariadb-server
    - php
    - php-mysql
    - name: start httpd
    shell: systemctl restart httpd
    - name: start mariadb
    shell: systemctl restart mariadb
    # 下载YUM源,更新EOEL源,安装Zabbix
    - hosts: zabbix_server
    tasks:
    - name: clear YUM
    shell: rm -rf /etc/yum.repos.d/*
    - name: install YUM EPEL
    get_url: 'url=http://mirrors.aliyun.com/repo/Centos-7.repo dest=/etc/yum.repos.d/CentOS-Base.repo'
    - name: yum install EPEL -y
    yum: name=epel-release state=installed
    - name: install zabbix.repo
    shell: rpm -i http://repo.zabbix.com/zabbix/3.4/rhel/7/x86_64/zabbix-release-3.4-2.el7.noarch.rpm
    - name: install zabbix
    yum: name={{item}} state=installed
    with_items:
    - zabbix-server-mysql
    - zabbix-web-mysql
    - zabbix-agent
    - name: start zabbix-server
    shell: systemctl restart zabbix-server
    - name: start zabbix-agent
    shell: systemctl restart zabbix-agent
    # 安装配置数据库权限,导入zabbix数据库
    - hosts: zabbix_server
    tasks:
    - name: set mariadb password
    shell: mysqladmin -u root password 'ansible'
    - name: create zabbix master databases
    shell: mysql -uroot -pansible -e 'create database zabbix character set utf8 collate utf8_bin;'
    - name: set zabbix master databases grant
    shell: mysql -uroot -pansible -e 'grant all privileges on zabbix.* to zabbix@localhost identified by "zabbix";'
    - name: import zabbix initial data SQL shell
    shell: zcat /usr/share/doc/zabbix-server-mysql*/create.sql.gz | mysql -uzabbix -pzabbix zabbix
    # 修改并拷贝配置文件,给予权限
    - hosts: zabbix_server
    tasks:
    - name: edit zabbix dbhost
    lineinfile:
    dest: /etc/zabbix/zabbix_server.conf
    regexp: '# DBHost=localhost'
    line: 'DBHost=localhost'
    - name: edit zabbix dbpasswd
    lineinfile:
    dest: /etc/zabbix/zabbix_server.conf
    regexp: '# DBPassword='
    line: 'DBPassword=zabbix'
    - name: cp zabbix web
    shell: cp -a /usr/share/zabbix/* /var/www/html/
    - name: chmod web
    shell: chmod 755 -R /var/www/html/*
    - name: chown web
    shell: chown apache.apache -R /var/www/html/* - name: set php
    shell: echo "date.timezone = Asia/Shanghai" >> /etc/php.ini
    - name: set php
    shell: echo "max_execution_time = 300" >> /etc/php.ini
    - name: set php
    shell: echo "max_input_time = 300" >> /etc/php.ini
    - name: set php
    shell: echo "post_max_size = 32M" >> /etc/php.ini
    - name: set php
    shell: echo "memory_limit = 128M" >> /etc/php.ini
    - name: set php
    shell: echo "mbstring.func_overload = 0" >> /etc/php.ini - name: start http mysql zabbix
    shell: systemctl restart httpd ; systemctl restart mariadb
    - name: start http mysql zabbix
    shell: systemctl restart zabbix-server ; systemctl restart zabbix-agent
    - name: enabled http mysql zabbix
    shell: systemctl enable httpd ; systemctl enable mariadb
    - name: start http mysql zabbix
    shell: systemctl enable zabbix-server ; systemctl enable zabbix-agent
    • playbook构建zabbixclient
    ---
    # 初始化,关闭防火墙和SELINUX
    - hosts: zabbix_client
    tasks:
    - name: off selinux
    shell: setenforce 0
    - name: seline modify enforcing
    lineinfile:
    dest: /etc/selinux/config
    regexp: '^SELINUX='
    line: 'SELINUX=disabled'
    - name: seline firealld
    shell: systemctl stop firewalld && systemctl disable firewalld
    # 安装zabbix_client
    - hosts: zabbix_client
    vars:
    zabbix_server_ip: 172.16.9.141
    zabbix_agent_ip: 172.16.9.142 tasks:
    - name: install zabbix_client
    shell: rpm -ivh http://repo.zabbix.com/zabbix/3.4/rhel/7/x86_64/zabbix-agent-3.4.15-1.el7.x86_64.rpm
    - name: Install zabbix agent
    shell: yum -y install zabbix-agent
    - name: modify zabbix server ip address
    shell: sed -i 's#Server=127.0.0.1#Server='{{zabbix_server_ip}}'#g' /etc/zabbix/zabbix_agentd.conf
    - name: modify zabbix server active ip addr
    shell: sed -i 's/ServerActive=127.0.0.1/ServerActive='{{zabbix_server_ip}}'/g' /etc/zabbix/zabbix_agentd.conf
    - name: Enable remote command execution
    shell: sed -i 's/# EnableRemoteCommands=0/EnableRemoteCommands=1'/g /etc/zabbix/zabbix_agentd.conf
    - name: Enable remote command logs
    shell: sed -i 's/# LogRemoteCommands=0/LogRemoteCommands=1'/g /etc/zabbix/zabbix_agentd.conf
    - name: modify zabbix agent hostname
    shell: sed -i 's/Hostname=Zabbix server/Hostname='{{zabbix_agent_ip}}'/g' /etc/zabbix/zabbix_agentd.conf
    - name: enable zabbix-agent
    shell: systemctl start zabbix-agent ;systemctl enable zabbix-agent

再来几个检查语法结构,主机是否生效的命令

ansible-playbook install_zabbix_server.yaml --syntax-check
ansible-playbook install_zabbix_server.yaml --list-task
ansible-playbook install_zabbix_server.yaml --list-hosts

ansible-playbook安装zabbix_server,agent监控的更多相关文章

  1. 写Ansible playbook添加zabbix被监控的对象

    本主题达到的效果是能通过编写Ansible Playbook,创建zabbix主机组,把被监控的对象加入到zabbix监控系统中,同时链接到对象的模板. 1.准备工作 在zabbix服务器上面,我们需 ...

  2. ansible playbook 安装docker

    1.新增host配置到/etc/ansible/hosts文件中 [docker] 192.168.43.95 2.配置无密码登录 # 配置ssh,默认rsa加密,保存目录(公钥)~/.ssh/id_ ...

  3. Vagrant Ansible Playbook 安装一群虚拟机

    https://docs.ansible.com/ https://favoorr.github.io/2017/01/06/vagrant-virtualbox-vagrantfile-config ...

  4. ansible自动安装rabbitmq

    ansible playbook 安装rabbitmq单机版,以下脚本在CentOS6.7服务器测试通过. 需要配置本机的yum源,用于安装socat软件. rabbitmq版本和Erlang版本需要 ...

  5. Centos下zabbix部署(二)agent安装并设置监控

    1.配置zabbix源 rpm -ivh http://repo.zabbix.com/zabbix/3.0/rhel/7/x86_64/zabbix-release-3.0-1.el7.noarch ...

  6. 使用Ubuntu系统编译安装Zabbix企业级监控系统

    使用Ubuntu系统编译安装Zabbix企业级监控系统   作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. Ubuntu系统部署笔记:https://www.cnblogs.com/ ...

  7. Centos7 使用 Ansible 批量安装中文字体

    需求背景 Centos7 下 Java 生成图片水印时中文乱码,原因是没有安装中文字体. 安装中文字体 以下是基于 Centos7 手动安装中文字体的详细步骤.当测试或者生产环境服务器比较多的时候,建 ...

  8. CentOS 6.5安装部署Zabbix监控系统

    CentOS 6.5安装部署Zabbix监控系统 先说一点废话,我没有用centos7做实验,讲真,centos 7我也不常用,喜欢新版本的同学其实可以尝试下,注意一点的就是centos 6.5只支持 ...

  9. ansible离线安装

    目录 1. ansible离线安装 2. ansible配置文件 3. ansible常用的命令: 1. ansible离线安装 最近要在内网部署一台ansible服务器,只能手动离线安装ansibl ...

随机推荐

  1. TCP/IP协议族体系结构:死也不能忘记的四个层

    1.死也不能忘记的四个层 ①数据链路层实现了网卡接口的网络驱动程序,以处理数据在物理媒介(比如以太网.令牌环等)上的传输.主要的协议ARP和RARP经过数据链路层封装的数据成为帧,有以太网帧.令牌环帧 ...

  2. nuxt或者vue,axios中如何发送多个请求

    在使用vue或者nuxt中,我们需要使用axios去发送多个http请求,参考了axios的官方说明你也许会想到使用axios.all发送请求,但是这样可能会出现一些异常错误: (node:9360) ...

  3. Ubuntu16.04安装Filebeat

    Filebeat官方文档地址 https://www.elastic.co/guide/en/beats/filebeat/current/filebeat-installation.html 下载和 ...

  4. Docker环境下的前后端分离项目部署与运维(八)使用Docker部署RabbitMQ集群

    下载RabbitMQ镜像 镜像地址RabbitMQ Docker官方认证镜像地址:https://hub.docker.com/_/rabbitmq 安装命令安装之前,切记把Docker Hub设置为 ...

  5. Makefile文件基本格式

    以下是Makefile的基本模板 #指定编译器CC = g++#指定编译参数CFLAGS = -std=c++11 #指定头文件路径,此处用于指定非标准库的头文件路径INC = -I./ -I /us ...

  6. 【Gamma】“北航社团帮”展示博客

    目录 团队介绍 项目愿景 整个项目的预期典型用户 功能展示 原预期用户数量 项目使用情况数据分析 用户量变化 学生认证人数 社长认证人数 入社申请数 活动发布 新闻发布 网页端使用情况 小程序打开次数 ...

  7. 【Gamma】“北航社团帮”测试报告——小程序v3.0

    目录 测试计划.过程和结果 后端测试--单元测试与覆盖率 后端测试--压力测试 展示部分数据 平均数据 前端测试--小程序v3.0 新功能 各页面均可正常打开,跳转,回退 授权登录与权限检查 页面数据 ...

  8. Excel VBA业余爱好者心得及总结

    我不是IT专业人士,而是一位医务工作者,当初学习Excel VBA时,是因为读研究生时的课题需要:实验仪器每天产生4个Word文件,每个文件有9个表格,总计近百个数据.为了对这些数据进行统计分析,则需 ...

  9. SQL join 三种扩展用法

    以前学习,只知道  LEFT JOIN.RIGHT JOIN.INNER JOIN.FULL  JOIN,共四种集合,然而加上一些条件,可以组合成另外三种集合,直接上图.

  10. Hbase操作集锦

    一.Hbase架构与理解 Hbase架构大致如下,图片取自https://www.cnblogs.com/linkworld/p/10963910.html. 二.Hbase shell操作 创建Hb ...