zabbix-server服务部署

本文档详细记录了在CentOS7上安装Zabbix监控系统和MySQL的过程,包括关闭防火墙、同步时间、安装YUM源、数据库创建与授权、导入数据库、配置文件修改及启动服务等步骤,最后通过Web端测试并设置为中文界面。
摘要由CSDN通过智能技术生成

关闭防火墙并同步时间

[root@ c7-41 ~]# systemctl stop firewalld
[root@ c7-41 ~]# setenforce 0
setenforce: SELinux is disabled
[root@ c7-41 ~]# ntpdate pool.ntp.org

安装zabbix和mysql

1、上传zabbix_Aliyun.yum源

[root@ c7-41 ~]# rz	#上传安装包命令

[root@ c7-41 ~]# ls	#查看安装包
anaconda-ks.cfg  zabbix_Aliyun.repo
[root@ c7-41 ~]# cat zabbix_Aliyun.repo
[zabbix]
name=Zabbix Official Repository - $basearch
baseurl=http://mirrors.aliyun.com/zabbix/zabbix/4.2/rhel/7/$basearch/
enabled=1
gpgcheck=0
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-ZABBIX-A14FE591

[zabbix-debuginfo]
name=Zabbix Official Repository debuginfo - $basearch
baseurl=http://mirrors.aliyun.com/zabbix/zabbix/4.2/rhel/7/$basearch/debuginfo/
enabled=0
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-ZABBIX-A14FE591
gpgcheck=0

[zabbix-non-supported]
name=Zabbix Official Repository non-supported - $basearch
baseurl=http://mirrors.aliyun.com/zabbix/non-supported/rhel/7/$basearch/
enabled=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-ZABBIX
gpgcheck=0
[root@ c7-41 ~]# cp zabbix_Aliyun.repo /etc/yum.repos.d/	#复制yum仓库到yum.repos.d

2、安装zabbix-server,zabbix-agent和mysql

[root@ c7-41 ~]# yum -y install zabbix-server-mysql zabbix-web-mysql zabbix-agent mariadbmariadb-server

启动mysql,并创建库和授权用户

[root@ c7-41 ~]# systemctl enable mariadb
Created symlink from /etc/systemd/system/multi-user.target.wants/mariadb.service to /usr/lib/systemd/system/mariadb.service.
[root@ c7-41 ~]# systemctl start mariadb	#启动
[root@ c7-41 ~]# mysql	#进入mysql
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 2
Server version: 5.5.68-MariaDB MariaDB Server

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> create database zabbix charset utf8 collate utf8_bin;	#创建zabbix库,字符集utf8
Query OK, 1 row affected (0.00 sec)

MariaDB [(none)]> grant all on zabbix.* to zabbix@localhost identified by 'zabbix';	#创建zabbix授权用户
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> flush privileges;	#刷新
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> \q	#退出
Bye

从zabbix导入mysql数据库

[root@ c7-41 ~]# zcat /usr/share/doc/zabbix-server-mysql-4.2.8/create.sql.gz |mysql -uzabbix -pzabbix zabbix

修改zabbix配置文件,并更改时区

[root@ c7-41 ~]# vim /etc/zabbix/zabbix_server.conf
[root@ c7-41 ~]# cat /etc/zabbix/zabbix_server.conf |grep "DB" |sed '/^#/d'
DBHost=localhost	#本机
DBName=zabbix	#数据库名称
DBUser=zabbix	#用户名
DBPassword=zabbix	#数据库密码
[root@ c7-41 ~]# vim /etc/httpd/conf.d/zabbix.conf
[root@ c7-41 ~]# cat /etc/httpd/conf.d/zabbix.conf |grep "php"
# Zabbix monitoring system php web frontend
    <IfModule mod_php5.c>
        php_value max_execution_time 300
        php_value memory_limit 128M
        php_value post_max_size 16M
        php_value upload_max_filesize 2M
        php_value max_input_time 300
        php_value max_input_vars 10000
        php_value always_populate_raw_post_data -1
        php_value date.timezone Asia/Shanghai	#修改时区为上海

启动zabbix和httpd

[root@ c7-41 ~]# systemctl enable zabbix-server zabbix-agent httpd
[root@ c7-41 ~]# systemctl start zabbix-server zabbix-agent httpd
[root@ c7-41 ~]# netstat -nuptl |egrep "80|10050|10051"	#查看端口是否启动
tcp        0      0 0.0.0.0:10050           0.0.0.0:*               LISTEN      4379/zabbix_agentd
tcp        0      0 0.0.0.0:10051           0.0.0.0:*               LISTEN      4376/zabbix_server
tcp6       0      0 :::10050                :::*                    LISTEN      4379/zabbix_agentd
tcp6       0      0 :::10051                :::*                    LISTEN      4376/zabbix_server
tcp6       0      0 :::80                   :::*                    LISTEN      4374/httpd

在浏览器web端测试

在这里插入图片描述在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述在这里插入图片描述在这里插入图片描述

设置为中文

在这里插入图片描述在这里插入图片描述在这里插入图片描述

在 Kubernetes 中,我们可以使用 DaemonSet 来部署一个副本在每个节点上,并且这些副本会在特定节点上运行。这里我们以部署 Zabbix Server 和 Web UI 的情况为例,假设我们需要在节点 node2 上部署 Zabbix Server,并在所有节点上部署 Zabbix Web UI。 ### 部署 Zabbix Server 对于 Zabbix Server,我们将它作为一个 DaemonSet 并限制其部署到特定的节点(此处为 node2)。以下是使用 Zabbix Server 镜像 (`zabbix/zabbix-server-mysql`) 创建的 YAML 文件示例: ```yaml apiVersion: apps/v1 kind: DaemonSet metadata: name: zabbix-server-node2 spec: selector: matchLabels: app: zabbix-server template: metadata: labels: app: zabbix-server spec: nodeSelector: beta.kubernetes.io/os: ubuntu containers: - name: zabbix-server image: zabbix/zabbix-server-mysql command: ['zabbix_server'] args: ['-d'] ports: - containerPort: 10051 env: - name: MYSQL_ROOT_PASSWORD valueFrom: secretKeyRef: name: mysql-root-pass key: rootpass volumeMounts: - name: zabbix-data mountPath: /var/lib/zabbix volumes: - name: zabbix-data emptyDir: {} --- # 对应的 MySQL ServiceAccount 或 RoleBinding 可能需要在此处添加 ``` 这里的关键点是,我们指定了节点选择器 `beta.kubernetes.io/os: ubuntu` 并且设置了一个环境变量 `MYSQL_ROOT_PASSWORD` ,这个值应该来自于 `mysql-root-pass` 这个 Secret,用于 MySQL 数据库连接时验证根用户身份。 ### 部署 Zabbix Web UI 接下来,我们部署 Zabbix Web UI 到所有节点。这通常涉及使用 Nginx 和 MySQL 组件。为了简化起见,这里假定您已经有一个 MySQL 服务正在运行,并且有一个名为 `mysql-service` 的服务账号或角色绑定允许访问 MySQL。 下面是部署 Zabbix Web UI(包括 Nginx 和 MySQL 客户端)的 YAML 文件示例: ```yaml apiVersion: v1 kind: ServiceAccount metadata: name: zabbix-web-sa --- apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: zabbix-web-crb subjects: - kind: ServiceAccount name: zabbix-web-sa namespace: default roleRef: kind: ClusterRole name: cluster-admin apiGroup: rbac.authorization.k8s.io --- apiVersion: apps/v1 kind: Deployment metadata: name: zabbix-web spec: replicas: 1 selector: matchLabels: app: zabbix-web template: metadata: labels: app: zabbix-web spec: serviceAccountName: zabbix-web-sa containers: - name: zabbix-web-nginx-mysql image: zabbix/zabbix-web-nginx-mysql ports: - containerPort: 80 protocol: TCP env: - name: DB_SERVER value: mysql-service.default.svc.cluster.local - name: DB_USER valueFrom: secretKeyRef: name: mysql-user key: user - name: DB_PASSWORD valueFrom: secretKeyRef: name: mysql-pass key: password readinessProbe: httpGet: path: / port: 80 initialDelaySeconds: 30 periodSeconds: 10 livenessProbe: httpGet: path: / port: 80 initialDelaySeconds: 60 periodSeconds: 30 volumes: - name: zabbix-web-conf configMap: name: zabbix-web-config items: - key: default.conf path: default.conf --- apiVersion: v1 kind: ConfigMap metadata: name: zabbix-web-config data: default.conf: | # ... 配置内容 --- apiVersion: v1 kind: Service metadata: name: zabbix-web-service spec: type: LoadBalancer selector: app: zabbix-web ports: - name: web port: 80 targetPort: 80 ``` 以上 YAML 文件首先定义了必要的 RBAC 规则和服务账号,接着定义了 Deployment 负责启动 Zabbix Web UI 的容器,并配置了探针检查以确保容器健康。最后,我们创建了一个 ConfigMap 包含了 Web UI 的配置文件,并定义了一个负载均衡服务让外部能够访问 Web UI。 请注意,实际部署前应调整镜像标签和其他细节以匹配您的具体环境和需求。在运行这些 YAML 文件之前,请确保所有依赖项(如 MySQL)已经在 Kubernetes 环境中正确设置。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值