zabbix+tidb

实验前准备

需要用到的软件包

[root@tidb1 ~]# ls
centos-release-scl-2-3.el7.centos.noarch.rpm     mysql-community-devel-5.7.33-1.el7.x86_64.rpm            mysql-community-libs-compat-5.7.33-1.el7.x86_64
centos-release-scl-rh-2-3.el7.centos.noarch.rpm  mysql-community-embedded-5.7.33-1.el7.x86_64.rpm         mysql-community-server-5.7.33-1.el7.x86_64.rpm
mysql-5.7.33-1.el7.x86_64.rpm-bundle(1).tar      mysql-community-embedded-compat-5.7.33-1.el7.x86_64.rpm  mysql-community-test-5.7.33-1.el7.x86_64.rpm
mysql-community-client-5.7.33-1.el7.x86_64.rpm   mysql-community-embedded-devel-5.7.33-1.el7.x86_64.rpm   tidb-latest-linux-amd64.tar.gz
mysql-community-common-5.7.33-1.el7.x86_64.rpm   mysql-community-libs-5.7.33-1.el7.x86_64.rpm

需要三台主机部署tidb

  • 推荐安装 CentOS 7.3 及以上版本
  • 运行环境可以支持互联网访问,用于下载 TiDB 及相关软件安装包
实例个数IP配置
TiKV2192.168.2.20
192.168.2.20
避免端口和目录冲突
PD1192.168.2.10

默认端口

全局目录配置

部署主机软件和环境要求

  • 部署需要使用部署主机的 root 用户及密码
  • 部署主机关闭防火墙或者开放 TiDB 集群的节点间所需端口
  • 目前 TiUP 支持在 x86_64(AMD64 和 ARM)架构上部署 TiDB 集群
    • 在 AMD64 架构下,建议使用 CentOS 7.3 及以上版本 Linux 操作系统
    • 在 ARM 架构下,建议使用 CentOS 7.6 1810 版本 Linux 操作系统

一 ,部署安装zabbbix

 建议参考官方文档:www.zabbix.com

1.1 安装zabbix存储库

[root@tidb1 ~]# rpm -Uvh https://repo.zabbix.com/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
Retrieving https://repo.zabbix.com/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm
warning: /var/tmp/rpm-tmp.gefVff: Header V4 RSA/SHA512 Signature, key ID a14fe591: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:zabbix-release-5.0-1.el7         ################################# [100%]

1.2 安装zabbix服务器和代理

[root@tidb1 ~]# yum install zabbix-server-mysql zabbix-agent
Loaded plugins: product-id, search-disabled-repos, subscription-manager
......
Dependency Installed:
  OpenIPMI-libs.x86_64 0:2.0.23-2.el7    OpenIPMI-modalias.x86_64 0:2.0.23-2.el7   fping.x86_64 0:3.16-1.el7        libevent.x86_64 0:2.0.21-4.el7  
  libtool-ltdl.x86_64 0:2.4.2-22.el7_3   net-snmp-libs.x86_64 1:5.7.2-37.el7       unixODBC.x86_64 0:2.3.1-11.el7  

Complete!

 1.3 安装zabbix前端

[root@tidb1 ~]# yum install centos-release-scl-2-3.el7.centos.noarch.rpm centos-release-scl-rh-2-3.el7.centos.noarch.rpm -y
Loaded plugins: product-id, search-disabled-repos, subscription-manager
This system is not registered with an entitlement server. You can use subscription-manager to register.
......
Installed:
  centos-release-scl.noarch 0:2-3.el7.centos                              centos-release-scl-rh.noarch 0:2-3.el7.centos                             

Complete!

1.4 编辑配置文件 /etc/yum.repos.d/zabbix.repo

[root@tidb1 ~]# vim /etc/yum.repos.d/zabbix.repo
[zabbix-frontend]
...
enabled=1
...

1.4 安装zabbix前端包

[root@tidb1 ~]#   yum install zabbix-web-mysql-scl zabbix-apache-conf-scl -y
Loaded plugins: langpacks, product-id, search-disabled-repos, subscription-manager
This system is not registered with an entitlement server. You can use subscription-manager to register.
centos-sclo-rh                                                                                                                                                  | 3.0 kB  00:00:00
centos-sclo-sclo                                                                                                                                                | 3.0 kB  00:00:00
(1/2): centos-sclo-sclo/x86_64/primary_db                                                                                                                       | 300 kB  00:00:00
(2/2): centos-sclo-rh/x86_64/primary_db                                                                                                                         | 3.4 MB  00:00:00
......
Complete!

2. 创建初始数据库

 2.1 下载数据库

[root@tidb1 ~]# yum install mysql-community-client-5.7.33-1.el7.x86_64.rpm mysql-community-common-5.7.33-1.el7.x86_64.rpm mysql-community-libs-5.7.33-1.el7.x86_64.rpm mysql-community-                       libs-compat-5.7.33-1.el7.x86_64.rpm mysql-community-server-5.7.33-1.el7.x86_64.rpm -y
Loaded plugins: langpacks, product-id, search-disabled-repos, subscription-manager
This system is not registered with an entitlement server. You can use subscription-manager to register.
Examining mysql-community-client-5.7.33-1.el7.x86_64.rpm: mysql-community-client-5.7.33-1.el7.x86_64
......
Complete!

2.2 登录数据库,更改密码

[root@tidb1 ~]# systemctl start mysqld
[root@tidb1 ~]# cat /var/log/mysqld.log            ##查看数据库初始密码
.......
2022-07-11T04:47:54.505655Z 1 [Note] A temporary password is generated for root@localhost: ,dBiE-U>J29-
......
[root@tidb1 ~]# mysql_secure_installation
Securing the MySQL server deployment.

Enter password for user root:   ##输入日志里面的初始化密码    

The existing password for the user account root has expired. Please set a new password.

New password:                   ##输入自己新建数据库的密码

Re-enter new password:          ##确认新建密码
The 'validate_password' plugin is installed on the server.
The subsequent steps will run with the existing configuration
of the plugin.
Using existing password for root.

Estimated strength of the password: 100
Change the password for root ? ((Press y|Y for Yes, any other key for No) :

.......

All done!

 2.3 初始化数据库

[root@tidb1 ~]#  mysql  -p
Enter password:
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 6
Server version: 5.7.33 MySQL Community Server (GPL)

Copyright (c) 2000, 2021, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

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

mysql>  create database zabbix character set utf8 collate utf8_bin;   ##创建数据库zabbix
Query OK, 1 row affected (0.00 sec)

mysql>  create user zabbix@localhost identified by 'Westos+001';      ##创建zabbix用户及密码
Query OK, 0 rows affected (0.00 sec)

mysql> grant all privileges on zabbix.* to zabbix@localhost;          ##授权
Query OK, 0 rows affected (0.00 sec)

mysql>  quit;                                                         ##退出
Bye

2.4 导入初始架构和数据,系统将提示您输入新创建的密码。(时间稍微有点长,切记不要退出)

[root@tidb1 ~]# zcat /usr/share/doc/zabbix-server-mysql*/create.sql.gz | mysql -uzabbix -p zabbix
Enter password:               ##输入建立数据库的密码

 3. 为Zabbix server配置数据库,编辑配置文件 /etc/zabbix/zabbix_server.conf

.....
DBPassword=Westos+001    ##改成数据库密码
.....

4 . 为Zabbix前端配置PHP, 编辑配置文件 /etc/opt/rh/rh-php72/php-fpm.d/zabbix.conf

php_value[date.timezone] = Asia/Shanghai

 5. 启动Zabbix server和agent进程,并为它们设置开机自启

# systemctl restart zabbix-server zabbix-agent httpd rh-php72-php-fpm
# systemctl enable zabbix-server zabbix-agent httpd rh-php72-php-fpm

 至此,zabbix就配置好了

二,  安装tidb数据库

2.1  从官网下载tidb包

[root@tidb1 ~]# wget https://download.pingcap.org/tidb-latest-linux-amd64.tar.gz
--2022-07-10 22:05:30--  https://download.pingcap.org/tidb-latest-linux-amd64.tar.gz
Resolving download.pingcap.org (download.pingcap.org)... 101.206.106.41
Connecting to download.pingcap.org (download.pingcap.org)|101.206.106.41|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 517255312 (493M) [application/x-compressed]
Saving to: ‘tidb-latest-linux-amd64.tar.gz’

100%[=============================================================================================================================================>] 517,255,312 11.0MB/s   in 51s

2022-07-10 22:06:21 (9.65 MB/s) - ‘tidb-latest-linux-amd64.tar.gz’ saved [517255312/517255312]

2.2 解压tidb-latest-linux-amd64.tar.gz

[root@tidb1 ~]# tar zxf tidb-latest-linux-amd64.tar.gz
[root@tidb1 ~]# ls
centos-release-scl-2-3.el7.centos.noarch.rpm     mysql-community-devel-5.7.33-1.el7.x86_64.rpm            mysql-community-libs-compat-5.7.33-1.el7.x86_64.rpm
centos-release-scl-rh-2-3.el7.centos.noarch.rpm  mysql-community-embedded-5.7.33-1.el7.x86_64.rpm         mysql-community-server-5.7.33-1.el7.x86_64.rpm
mysql-5.7.33-1.el7.x86_64.rpm-bundle(1).tar      mysql-community-embedded-compat-5.7.33-1.el7.x86_64.rpm  mysql-community-test-5.7.33-1.el7.x86_64.rpm
mysql-community-client-5.7.33-1.el7.x86_64.rpm   mysql-community-embedded-devel-5.7.33-1.el7.x86_64.rpm   tidb-latest-linux-amd64.tar.gz
mysql-community-common-5.7.33-1.el7.x86_64.rpm   mysql-community-libs-5.7.33-1.el7.x86_64.rpm             tidb-v5.0.1-linux-amd64
[root@tidb1 ~]# cd tidb-v5.0.1-linux-amd64/

2.3 开启PD打入后台

[root@tidb1 ~]# cd tidb-v5.0.1-linux-amd64/
[root@tidb1 tidb-v5.0.1-linux-amd64]# ./bin/pd-server --name=pd1 --data-dir=pd1 --client-urls="http://192.168.2.10:2379" --peer-urls="http://192.168.2.10:2380" --initial-cluster="pd1=                       http://192.168.2.10:2380" --log-file=pd.log &
[1] 19489

2.4 配置另外两台TIKV,两台TIKV配置操作相同

[root@tidb2 ~]#  tar zxf tidb-latest-linux-amd64.tar.gz
[root@tidb2 ~]# cd tidb-v5.0.1-linux-amd64/
[root@tidb2 tidb-v5.0.1-linux-amd64]#  ./bin/tikv-server --pd="192.168.2.10:2379" --addr="192.168.2.20:20160" --data-dir=tikv1 --log-file=tikv.log &
[1] 9289
[root@tidb2 tidb-v5.0.1-linux-amd64]#  netstat -antlp | grep tikv
tcp        0      0 127.0.0.1:20180         0.0.0.0:*               LISTEN      9289/./bin/tikv-ser
tcp6       0      0 192.168.2.20:20160      :::*                    LISTEN      9289/./bin/tikv-ser
tcp6       0      0 192.168.2.20:33734      192.168.2.10:2379       ESTABLISHED 9289/./bin/tikv-ser

2.5 将tidb服务打入后台

[root@tidb1 tidb-v5.0.1-linux-amd64]# ./bin/tidb-server &

2.6 查看两台KITV连接情况及4000端口是否开启

2.7  进入zabbix数据库  创建zabbix用户并设定权限

[root@tidb1 tidb-v5.0.1-linux-amd64]# mysql -h 192.168.2.10 -P 4000 -uroot
mysql> create database zabbix character set utf8 collate utf8_bin;
mysql> CREATE USER 'zabbix'@'%' IDENTIFIED BY 'Westos+001';
grant all privileges on *.* to 'zabbix'@'%';

2.8 TiDB数据库备份 , 导入(时间会比较长,导入的数据很多,不是报错了)

[root@tidb1 zabbix-server-mysql-5.0.25]# mysqldump -uroot -pWestos+001 zabbix >  
 /mnt/zabbix.sql        ##数据库备份
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@tidb1 zabbix-server-mysql-5.0.25]# cd /mnt
[root@tidb1 mnt]# ls
zabbix.sql
[root@tidb1 mnt]# mysql -h 192.168.2.10 -P 4000 -uroot
mysql> use zabbix;
Database changed
mysql> set tidb_batch_insert=1;
Query OK, 0 rows affected (0.00 sec)

mysql> source /mnt/zabbix.sql;
Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

Query OK, 0 rows affected (0.00 sec)
.........

2.9 编辑zabbix的配置文件/etc/zabbix/zabbix_server.conf,将4000端口加进去

[root@tidb1 mnt]# vim /etc/zabbix/zabbix_server.conf
......
DBPort=4000
......

2.10 编辑配置文件/etc/zabbix/web/,更改为pd主机IP及端口还有数据库密码

[root@tidb1 php-fpm.d]# vim /etc/zabbix/web/zabbix.conf.php
<?php
// Zabbix GUI configuration file.

$DB['TYPE']                             = 'MYSQL'
$DB['SERVER']                   = '192.168.2.10';
$DB['PORT']                             = '4000';
$DB['DATABASE']                 = 'zabbix';
$DB['USER']                             = 'zabbix';
$DB['PASSWORD']                 = 'Westos+001';
..........

2.11 重启Zabbix server和agent

[root@tidb1 web]# systemctl restart zabbix-agent
[root@tidb1 web]# systemctl restart zabbix-server

三 启动并访问zabbix

在浏览器输入192.168.2.10/zabbiz可以正常访问说明zabbix配置文件没问题,zabbix的数据库可以正常写入tidb说明zabbix+tidb部署成功

​​​​​​​

 

 

posted @ 2023-03-16 19:48  yunyeblog  阅读(59)  评论(0编辑  收藏  举报  来源