美文网首页学习笔记
Day75-Zabbix分布式监控 监控JVM 优化

Day75-Zabbix分布式监控 监控JVM 优化

作者: 三德书生 | 来源:发表于2019-11-25 15:23 被阅读0次

    1.安装proxy 数据库

    yum install zabbix-proxy-mysql mariadb-server -y
    
    systemctl start mariadb
    
    MariaDB [(none)]> create database zabbix_proxy character set utf8 collate utf8_bin;
    MariaDB [(none)]> grant all privileges on zabbix_proxy.* to zabbix_proxy@localhost identified by 'zabbix_proxy';
    
    zcat /usr/share/doc/zabbix-proxy-mysql-4.0.14/schema.sql.gz  | mysql -uzabbix_proxy -pzabbix_proxy zabbix_proxy
    

    2.配置zabbix-proxy

    [root@web02 ~]# grep "^[a-Z]" /etc/zabbix/zabbix_proxy.conf 
    ....
    Server=10.0.0.71
    Hostname=sh_proxy
    
    DBHost=localhost
    DBName=zabbix_proxy
    DBUser=zabbix_proxy
    DBPassword=zabbix_proxy
    ....
    

    3.启动proxy

    systemctl enable zabbix-proxy.service 
    
    systemctl start zabbix-proxy
    

    4.配置zabbix-agent 不通区域的agent指向不同的proxy

    10.0.0.71   <--- 10.0.0.7       <---172.16.1.51
    10.0.0.71   <--- 10.0.0.8       <---172.16.1.41
    

    5.登录zabbix-web

    1.管理-->agent代理程序
    

    注意: zabbix-server 与 zabbix-proxy 需要版本一致

    ProxyLocalBuffer Proxy将在本地保留数据N小时,即使数据已与server同步。(默认不保留立即发送)
    ProxyOfflineBuffer 如果无法连接Zabbix server,proxy将默认保留数据1小时.

    zabbix监控jvm? tomcat

    zabbix   ---> jmx   ---> java(zabbix-agent)
    
    1.Zabbix-Server找Zabbix-Java-Gateway获取Java数据
    2.Zabbix-Java-Gateway找Java程序获取数据
    3.Java程序返回数据给Zabbix-Java-Gateway
    4.Zabbix-Java-Gateway返回数据给Zabbix-Server
    5.Zabbix-Server进行数据展示
    

    配置JMX监控的步骤:

    1.安装Zabbix-Java-Gateway。
    2.配置zabbix_java_gateway.conf参数。
    3.配置zabbix-server.conf参数。-->连接java-gateway
    4.Tomcat应用开启JMX协议。
    5.ZabbixWeb配置JMX监控的Java应用。
    

    环境:

    zabbix-server   10.0.0.71  172.16.1.71
    zabbix-gateway              172.16.1.7
    tomcat                      172.16.1.8
    

    zabbix Api ( 开发 )
    1.在使用zabbix-api之前,先获取一个token

    curl -s -X POST -H 'Content-Type:application/json' -d '
    {
    "jsonrpc": "2.0",
    "method": "user.login",
    "params": {
    "user": "Admin",
    "password": "oldxu.com"
    },
    "id": 1
    }' http://zabbix.oldxu.com/zabbix/api_jsonrpc.php
    
    {"jsonrpc":"2.0","result":"4c831e081ff77510f9662bb9de0f9144","id":1}
    
    
    
    curl -s -X POST -H 'Content-Type:application/json' -d '
    {
        "jsonrpc": "2.0",
        "method": "host.get",
        "params": {
            "output": [
                "hostid",
                "host"
            ],
            "selectInterfaces": [
                "interfaceid",
                "ip"
            ]
        },
        "id": 2,
        "auth": "4c831e081ff77510f9662bb9de0f9144"
    }' http://zabbix.oldxu.com/zabbix/api_jsonrpc.php
    

    2.使用token验证身份, 并禁用某一台主机

    curl -s -X POST -H 'Content-Type:application/json' -d '
    {
        "jsonrpc": "2.0",
        "method": "host.update",
        "params": {
            "hostid": "10283",
            "status": 1
        },
        "auth": "4c831e081ff77510f9662bb9de0f9144",
        "id": 1
    }' http://zabbix.oldxu.com/zabbix/api_jsonrpc.php
    

    4.使用API创建主机

    curl -s -X POST -H 'Content-Type:application/json' -d '
    {
        "jsonrpc": "2.0",
        "method": "host.create",
        "params": {
            "host": "10.0.0.1",
            "interfaces": [
                {
                    "type": 1,
                    "main": 1,
                    "useip": 1,
                    "ip": "10.0.0.1",
                    "dns": "",
                    "port": "10050"
                }
            ],
            "groups": [
                {
                    "groupid": "20"
                }
            ],
            "templates": [
                {
                    "templateid": "10001"
                }
            ]
        },
        "auth": "4c831e081ff77510f9662bb9de0f9144",
        "id": 1
    }' http://zabbix.oldxu.com/zabbix/api_jsonrpc.php
    
    1. Zabbix属于写多读少的业务, 所以需要针对zabbix的MySQL进行拆分.
      1.LAMP -->拆分成LAP + MySQL
      2.MySQL尽量使用SSD固态盘
    2. 将Zabbix-Agent被动监控模式, 调整为主动监控模式.
    3. 使用zabbix-proxy分布式监控, 在大规模监控时用于缓解Zabbix-Server压力
    4. 去掉无用监控项, 增加监控项的取值间隔, 减少历史数据保存周期(由housekeeper进程定时清理)
      5)针对于Zabbix-server进程调优, 谁忙就加大谁的进程数量, 具体取决实际情况, 不是越大越好
      6)针对于Zabbix-server缓存调优, 谁使用的缓存多,就加大它的缓存值(zabbix cache usage图表)
    5. 关注管理->队列, 是否有被延迟执行的监控项

    相关文章

      网友评论

        本文标题:Day75-Zabbix分布式监控 监控JVM 优化

        本文链接:https://www.haomeiwen.com/subject/guldwctx.html