Saltstack源码安装zabbix_agent客户端
Saltstack源码安装zabbix_agent客户端
安装和环境介绍略,直接上正题:
一,首先是树状图
[root@saltmaster salt]# pwd
/srv/salt
[root@saltmaster salt]# tree
. ├── init │ └── init.sls ├── top.sls └── zabbix ├── conf.sls ├── files │ ├── zabbix_agentd │ ├── zabbix_agentd.conf │ └── zabbix.tar.gz ├── init.sls └── install.sls 3 directories, 8 files
二,先系统初始化
这里目前只是告诉客户端安装vim-enhanced、lrzsz这2个软件,可以根据实际情况自行安装依赖软件,pkg安装模块目前支持apt与yum。
[root@saltmaster salt]# cat init/init.sls
pkgs: pkg.installed: - names: - vim-enhanced - lrzsz
三,入口文件top.sls
SLS(代表SaLt State文件)是Salt State系统的核心。SLS描述了系统的目标状态,由格式简单的数据构成。这经常被称作配置管理,其中top.sls文件是配置管理的入口文件,一切都是从这里开始,在master 主机上,默认存放在/srv/salt/目录. top.sls。
这里有2个配置项,一个是系统初始化,一个是zabbix客户端安装。
[root@saltmaster salt]# cat top.sls
base: '*' - init.init '*': - zabbix.init
四,Zabbinx目录的init.sls
顺序执行zabbix目录下的install.sls与zabbix目录下的conf.sls
[root@saltmaster salt]# cat zabbix/init.sls
include: - zabbix.install - zabbix.conf
五,具体安装配置
Install.sls具体操作是:
1,把zabbix/files/zabbix.tar.gz文件发送到客户端/tmp目录下,我这里的zabbix.tar.gz是编译好的zabbix客户端打包文件,默认解压缩后就能使用;
2,从/tmp/zabbix.tar.gz解压缩到/usr/local目录下;
3,添加zabbix用户
[root@saltmaster salt]# cat zabbix/install.sls
zabbix_source: file.managed: - name: /tmp/zabbix.tar.gz - source: salt://zabbix/files/zabbix.tar.gz - user: root - group: root - mode: 644 extract_zabbix: cmd.run: - cwd: /tmp - names : - tar zxvf zabbix.tar.gz -C /usr/local - require: - file: zabbix_source zabbix_user: user.present: - name: zabbix - createhome: False - gid_from_name: True - shell: /sbin/nologin
六,修改配置文件开机启动
1,先把配置文件下发到/usr/local/zabbix/etc/zabbix_agentd.conf,注意zabbix_agentd.conf有个配置Hostname=`Hostname`,这个可以更加客户端IP不同而修改成不同的IP。
2,下发自动启动zabbix_agentd服务脚本
3,添加到开机启动列表
4,启动zabbix_agentd服务
[root@saltmaster salt]# cat zabbix/conf.sls
zabbix_conf: file.managed: - name: /usr/local/zabbix/etc/zabbix_agentd.conf - source: salt://zabbix/files/zabbix_agentd.conf - template: jinja - defaults: Hostname: {{ grains['ip_interfaces']['eth1'][0] }} zabbix_service: file.managed: - name: /etc/init.d/zabbix_agentd - user: root - mode: 755 - source: salt://zabbix/files/zabbix_agentd cmd.run: - names: - /sbin/chkconfig --add zabbix_agentd - /sbin/chkconfig zabbix_agentd on service.running: - name: zabbix_agentd - enable: True - watch: - file: /usr/local/zabbix/etc/zabbix_agentd.conf
七,测试验证
1,salt '*' state.highstate test=True 这个是测试两个sls功能
2,salt-call state.highstate -l debug 这个是调试
3,salt '*' state.sls init.init 分别下发各个sls功能
4,具体结果如下:
[root@saltmaster salt]# salt '*' state.sls zabbix.init
saltmaster:
----------
ID: zabbix_source
Function: file.managed
Name: /tmp/zabbix.tar.gz
Result: True
Comment: File /tmp/zabbix.tar.gz is in the correct state
Started: 15:24:20.158243
Duration: 12.659 ms
Changes:
----------
ID: extract_zabbix
Function: cmd.run
Name: tar zxvf zabbix.tar.gz -C /usr/local
Result: True
Comment: Command "tar zxvf zabbix.tar.gz -C /usr/local" run
Started: 15:24:20.171608
Duration: 42.115 ms
Changes:
----------
pid:
30427
retcode:
0
stderr:
stdout:
zabbix/
zabbix/bin/
zabbix/bin/zabbix_sender
zabbix/bin/zabbix_get
zabbix/lib/
zabbix/sbin/
zabbix/sbin/zabbix_agent
zabbix/sbin/zabbix_agentd
zabbix/etc/
zabbix/etc/zabbix_agent.conf.d/
zabbix/etc/zabbix_agent.conf
zabbix/etc/zabbix_agentd.conf.d/
zabbix/share/
zabbix/share/man/
zabbix/share/man/man1/
zabbix/share/man/man1/zabbix_get.1
zabbix/share/man/man1/zabbix_sender.1
zabbix/share/man/man8/
zabbix/share/man/man8/zabbix_agentd.8
----------
ID: zabbix_user
Function: user.present
Name: zabbix
Result: True
Comment: User zabbix is present and up to date
Started: 15:24:20.215402
Duration: 14.994 ms
Changes:
----------
ID: zabbix_conf
Function: file.managed
Name: /usr/local/zabbix/etc/zabbix_agentd.conf
Result: True
Comment: File /usr/local/zabbix/etc/zabbix_agentd.conf is in the correct state
Started: 15:24:20.230479
Duration: 13.879 ms
Changes:
----------
ID: zabbix_service
Function: file.managed
Name: /etc/init.d/zabbix_agentd
Result: True
Comment: File /etc/init.d/zabbix_agentd is in the correct state
Started: 15:24:20.244543
Duration: 3.243 ms
Changes:
----------
ID: zabbix_service
Function: cmd.run
Name: /sbin/chkconfig zabbix_agentd on
Result: True
Comment: Command "/sbin/chkconfig zabbix_agentd on" run
Started: 15:24:20.247961
Duration: 17.828 ms
Changes:
----------
pid:
30429
retcode:
0
stderr:
stdout:
----------
ID: zabbix_service
Function: cmd.run
Name: /sbin/chkconfig --add zabbix_agentd
Result: True
Comment: Command "/sbin/chkconfig --add zabbix_agentd" run
Started: 15:24:20.266112
Duration: 25.019 ms
Changes:
----------
pid:
30430
retcode:
0
stderr:
stdout:
----------
ID: zabbix_service
Function: service.running
Name: zabbix_agentd
Result: True
Comment: Service zabbix_agentd is already enabled, and is in the desired state
Started: 15:24:20.296152
Duration: 113.405 ms
Changes:
Summary
------------
Succeeded: 8 (changed=3)
Failed: 0
------------
Total states run: 8

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
iPerf 测试网速的小教训
最近使用iPerf有个小教训,简单记载引以为戒。 上周,豆子公司升级WAN宽带从20M到1G。光纤,SPF,交换机端口,VLAN, iBGP的设定等等都严格按照ISP的要求,最后升级完成以后,豆子做iPerf做了个网速测试。 在我看来,iperf的测试应该很简单,在一端机器上运行 ipferf.exe -s 监听,另外一端运行iperf.exe -c IPaddress,就行了。 测试的结果如下所示。豆子一看,尼玛,带宽怎么才100M?鉴于我们的ISP不太靠谱的历史记录,我的第一个反应就是ISP又在坑爹了。于是很气愤的联系老板和对方的客户经理,%¥##!#¥@, 一通牢骚之后,对方表示会安排工程师测试速度。 过了2天,测试结果出来了,网速没有问题。皮球又踢回给我。豆子挠挠头皮,这到底是哪里出错了?经过研究,最后发现,网速真的没有问题,有问题的是我的测试方式!! iPerf可以进行多线程的并发测试,他默认的情况下只执行了一个线程,但是在带宽很大的情况下,完全达不到带宽的最大上限,这样导致iPerf给了一个错误的带宽值出来。当我同时执行几十个线程进行压力测试,真正的上限才显示出来。 比如说...
- 下一篇
python for循环remove同一个list
下午在用python将Linux的conf配置文件转化成字典dict时遇到了一个奇怪的问题,原先conf配置文件中没有注释行(以#开头的行),后来为了避免这种情况,添加了一个对以#开头的行删除的操作。 实践结果颠覆了已有的认知,直接上代码示例。 代码片段1 #!/usr/bin/python #encoding:utf-8 #-*-coding:utf8-*- importre list_to_test=['#','#conf','NAME="Ubuntu"','VERSION="14.04.3LTS,TrustyTahr"'] formemberinlist_to_test: ifre.search('^#+.*',member)isnotNone: list_to_test.remove(member) printlist_to_test 结果1:['# conf', 'NAME="Ubuntu"', 'VERSION="14.04.3 LTS, Trusty Tahr"'] 代码片段2 #!/usr/bin/python #encoding:utf-8 #-*-codin...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS7设置SWAP分区,小内存服务器的救世主
- CentOS7安装Docker,走上虚拟化容器引擎之路
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- CentOS8安装Docker,最新的服务器搭配容器使用
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程