【Zabbix】zabbix-Server端安装

1、导入源

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

2、安装zabbix包

yum install -y zabbix-server-mysql zabbix-web-mysql zabbix-agent mariadb-server

3、启动mariadb

systemctl start mariadb

4、创建zabbix数据库
回车键入密码的时候,这里不需要密码

mysql -uroot -p

回车完之后输入以下命令

MariaDB [(none)]> CREATE DATABASE `zabbix` DEFAULT CHARACTER SET utf8;
MariaDB [(none)]> grant all privileges on zabbix.* to zabbix@localhost identified by 'zabbix';
MariaDB [(none)]> flush privileges;  //可不做
MariaDB [(none)]> quit

5、初始化数据库

[root@localhost ~]# ls /usr/share/doc/

找到:zabbix-server-mysql-3.0.14(注意这里的版本号,不一定是3.0.14,根据实情来)
进入目录

[root@localhost ~]# cd /usr/share/doc/zabbix-server-mysql-3.0.14

初始化数据库

 [root@localhost zabbix-server-mysql-3.0.14]# zcat create.sql.gz | mysql -uroot -p zabbix

直接回车,这里等待时间较长
6、修改配置文件
首先需要切换到根目录 cd

vi /etc/zabbix/zabbix_server.conf

下面几个参数根据自己的实际情况修改
DBHost=localhost
DBName=zabbix
DBUser=zabbix
DBPassword=zabbix
修改之前:
这里写图片描述
修改之后:
这里写图片描述
将#去掉

点击esc 
:x  //保存退出

7、注意事项
关闭防火墙

systemctl start firewalld
systemctl stop firewalld

永久关闭防火墙

systemctl disable firewalld.service

永久关闭SELinux
1>.永久关闭前,先临时关闭SELinux

setenforce 0

2>.永久关闭SELinux

vi /etc/selinux/config

将SELINUX=enforcing改为SELINUX=disabled
改前
这里写图片描述
改后
这里写图片描述
注:修改配置文件需要重启机器,但我们已临时关闭SELinux,等下次机器重启后,配置文件自动生效

8、开启http服务

service httpd start  //第一句有可能提示redirecting to /bin/systemctl start httpd.service 这时使用第二句
或者
systemctl start httpd.service

9、启动zabbix服务

systemctl start zabbix-server

10、查看zabbix服务

systemctl status zabbix-server

11、配置界面,在网页中输入

http://IP/zabbix/   //IP你当前配置服务器的IP

12、会出现以下问题

Time zone for PHP is not set (configuration parameter “date.timezone”)


小结
下篇博客解决

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 21
    评论
在 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 环境中正确设置。
评论 21
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值