编译安装mysql和zabbix,xtrabackup数据库备份
阅读原文时间:2023年07月08日阅读:1

xtrabackup参考文章

https://www.cnblogs.com/linuxk/p/9372990.html

下载5.7的mysql 社区版包

https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-5.7.25-1.el7.x86_64.rpm-bundle.tar

如果是redhat7系统需要删除mariadb的包

使用以下命令检查并删除mariadb包

rpm -e --nodeps $(rpm -qa | grep mariadb)

上传到/tmp目录解压缩

tar -xvf mysql-5.7.25-1.el7.x86_64.rpm-bundle.tar

安装依赖包

yum install -y net-tools perl

安装rpm包

rpm -ivh mysql-community-common-5.7.25-1.el7.x86_64.rpm

rpm -ivh mysql-community-libs-5.7.25-1.el7.x86_64.rpm

rpm -ivh mysql-community-libs-compat-5.7.25-1.el7.x86_64.rpm

rpm -ivh mysql-community-client-5.7.25-1.el7.x86_64.rpm

rpm -ivh mysql-community-server-5.7.25-1.el7.x86_64.rpm

创建目录并设置所属

mkdir -p /data/mysql/{data,tmp,log}

chown -R mysql:mysql /data/mysql/{data,tmp,log}

修改配置文件(清除源文件的内容加入以下内容)

vi /etc/my.cnf

[client]

port = 3306

socket = /data/mysql/tmp/mysql.sock

default-character-set = utf8mb4

[mysqld]

port = 3306

datadir = /data/mysql/data

pid-file = /data/mysql/tmp/mysqld.pid

socket = /data/mysql/tmp/mysql.sock

log-error = /data/mysql/log/error.log

character_set_server = utf8mb4

user = mysql

bind-address = *

server-id = 1

symbolic-links=1

connect_timeout = 3600

wait_timeout = 3600

interactive_timeout = 3600

explicit_defaults_for_timestamp = true

启动mysql服务

systemctl start mysqld

获取安装过程中自动生成的密码到MySQL_PASS变量

MySQL_PASS=$(cat /data/mysql/log/error.log | grep "A temporary password" | awk '{print $NF}')

使用root加MySQL_PASS变量登陆

mysql -u root -p"${MySQL_PASS}"

设置新的密码为Admin123,.

mysql> SET PASSWORD='Admin123,.';

开启远程访问

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'ADmin123,.' WITH GRANT OPTION;

flush privileges;

yum -y install gcc pcre-devel openssl-devel

上传nginx-1.12.2.tar.gz包到root的家目录

解压缩nginx的包

tar -xf nginx-1.12.2.tar.gz

进入nginx的目录,编译安装

cd nginx-1.12.2

./configure --with-http_ssl_module

make && make install

yum -y install php php-mysql php-fpm

修改nginx的配置文件,让其支持php动态网站,因为有大量的php脚本需要执行,还有开启nginx的各种fastcgi缓存加速php脚本的执行速度

vi /usr/local/nginx/conf/nginx.conf

添加以下内容,添加的内容要顶格写,添加的位置如图所示

fastcgi_connect_timeout 300;

fastcgi_send_timeout 300;

fastcgi_read_timeout 300;

fastcgi_buffer_size 128k;

fastcgi_buffers 4 128k;

同时添加以下内容,添加位置如图所示

location ~ \.php$ {

root html;

fastcgi_pass 127.0.0.1:9000;

fastcgi_index index.php;

include fastcgi.conf;

}

开启php-fpm服务和nginx服务

systemctl start php-fpm

ln -s /usr/local/nginx/sbin/nginx /sbin/nginx

nginx

首先安装zabbix server 的依赖包

yum -y install net-snmp-devel curl-devel libevent-devel

解压zabbix包,进入目录,编译安装,使用编译安装的mysql数据库时造成zabbix编译失败,报错如

zabbix error: MySQL library not found

造成以上编译错误的话,需要安装mysql的devele包,包名为mysql-community-devel-5.7.25-1.el7.x86_64.rpm

rpm -ivh mysql-community-devel-5.7.25-1.el7.x86_64.rpm

tar -xf zabbix-3.4.11.tar.gz

cd zabbix-3.4.11

./configure --enable-server --enable-proxy --enable-agent --with-mysql=/usr/bin/mysql_config --with-net-snmp --with-libcurl

编译安装参数说明

// --enable-server安装部署zabbix服务器端软件

// --enable-agent安装部署zabbix被监控端软件

// --enable-proxy安装部署zabbix代理相关软件

// --with-mysql配置mysql_config路径

// --with-net-snmp允许zabbix通过snmp协议监控其他设备

// --with-libcurl安装相关curl库文件,这样zabbix就可以通过curl连接http等服务,测试被监控主机服务的状态

执行make && make install

make && make install

数据库配置,登陆数据库,创建中文字符集的数据库,赋权,如图(一下配图为MariaDB的配图,实际情况如果使用mysql的话,mysql不允许简单密码,应该使用大小写数字加特殊字符来组成密码)

mysql

MariaDB [(none)]> create database zabbix character set utf8;

MariaDB [(none)]> grant all on zabbix.* to zabbix@'localhost' identified by 'zabbix';

MariaDB [(none)]> GRANT ALL PRIVILEGES ON *.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';

创建可以访问数据库的账户和密码(zabbix的源码包下有关于数据库的sql脚本,只需要进入到源码包的database/mysql目录下,导入sql脚本即可,注意一定要安装顺序)

cd database/mysql/

mysql -uzabbix -pzabbix zabbix < schema.sql

mysql -uzabbix -pzabbix zabbix < images.sql

mysql -uzabbix -pzabbix zabbix < data.sql

将zabbix的web页面关联到nginx中

cd /root/zabbix-3.4.11/frontends/php/

cp -r * /usr/local/nginx/html/

chmod -R 777 /usr/local/nginx/html/*

修改zabbix-server配置文件,设置数据库的相关参数,启动zabbix-server服务

vi /usr/local/etc/zabbix_server.conf

DBHost=localhost

//数据库主机,默认该行被注释

DBName=zabbix

//设置数据库名称

DBUser=zabbix

//设置数据库账户

DBPassword=zabbix

//设置数据库密码,默认该行被注释

LogFile=/tmp/zabbix_server.log

//设置日志,仅查看以下即可

添加zabbix用户,不让其登陆到系统控制台,,不添加用户的话,无法启动zabbix_server服务

useradd -s /sbin/nologin zabbix

启动zabbix_server服务

zabbix_server

验证服务是否正常启动,如图

netstat -nutpl |grep zabb

提示:如果是因为配置文件不对,导致服务无法启动时,不要重复执行zabbix_server,一定要先使用killall zabbix_server关闭服务后,再重新启动一次。

如果还是无法启动zabbix_server服务的话,查日志,日志位置/tmp/zabbix_server.log

cat /tmp/zabbix_server.log

从日志上来看是找不到sock文件

查找sock文件

find / -name "mysql.sock*"

制作连接

ln -s /data/mysql/tmp/mysql.sock /var/lib/mysql/mysql.sock

然后重新启动zabbix_server

下面配置zabbix_agent服务,同样编辑zabbix_agentd.conf配置文件

vi /usr/local/etc/zabbix_agentd.conf

Server=127.0.0.1,172.16.103.2                    //允许哪些主机监控本机

ServerActive=127.0.0.1,172.16.103.2                 //允许哪些主机通过主动模式监控本机

Hostname=zabbix_server                        //设置本机主机名

LogFile=/tmp/zabbix_server.log                    //设置日志文件

UnsafeUserParameters=1                        //是否允许自定义key

启动zabbix_agent服务,同样如果是因为配置文件不对,导致服务无法启动时,不要重复执行zabbix_agentd,一定要先使用killall zabbix_agentd关闭服务后,再重新启动一次。

zabbix_agentd

使用浏览器访问zabbix的web页面,进行相关配置,访问地址为:http://172.16.103.2/index.php但是因为是首次登陆,会被强制跳转到http://172.16.103.2/setup.php进行配置,如图所示

程序会检查先决条件,对于不满足的,程序已经给了解决方法,

关于以上错误,如果是PHP option类的错误,那么需要修改php.ini配置文件,修改之后需要重启php服务,php.ini文件的位置位于/etc目录下,可以直接使用vi /etc/php.ini命令来编辑该文件,保存修改之后需要执行systemctl restart php-fpm才生效。

vi /etc/php.ini

post_max_size = 16M

max_execution_time = 300

max_input_time = 300

date.timezone = Asia/Shanghai

systemctl restart php-fpm

执行了这些修改之后依然还有报错信息,如下图所示

部分报错可以通过yum安装一些扩展包来解决,例如bcmath mbstring等,执行下面的yum安装命令,安装依赖包。

yum -y install php-gd php-xml php-bcmath php-mbstring

执行完上述依赖包的安装命令之后重启php-fpm再次刷新网页

PHP的LDAP未开启,后面标注是是warning警告,再次忽略。进入下一步,下图中表单中的数据参照zabbix_server.conf配置文件中的内容填写

Name可以自行填写,也可以不填写,Name为此zabbixserver实例的名称

报错提示无法创建配置文件,为了安全起见上文配置nginx的过程中修改的权限为755,也就是其他用户没有写权限,程序提示我们可以手工下载文件,上传到/usr/local/nginx/html/conf目录,保存的绝对路径为/usr/local/nginx/html/conf/zabbix.conf.php

使用admin密码zabbix登陆

登陆之后配置主机,等到zabbix变绿之后观察数据库,有实时的数据写入。

安装xtrabackup,备份的数据为mysql5.7,所以需要安装的xtrabackup版本为2.4最新版本的8.0的版本无法对mysql5.7做备份。只能使用2.4版本

下载

文件列表

https://www.percona.com/downloads/

rpm包

https://www.percona.com/downloads/Percona-XtraBackup-2.4/Percona-XtraBackup-2.4.15/binary/redhat/7/x86_64/percona-xtrabackup-24-2.4.15-1.el7.x86_64.rpm

安装依赖包

下载libev包

http://mirror.centos.org/centos/7/extras/x86_64/Packages/libev-4.15-7.el7.x86_64.rpm

rpm -ivh libev-4.15-7.el7.x86_64.rpm

安装xtrabackup

yum localinstall percona-xtrabackup-24-2.4.15-1.el7.x86_64.rpm

登陆数据库创建备份账户

CREATE USER 'bakuser'@'%' IDENTIFIED BY 'Admin123,.'; #创建bakuser用户

REVOKE ALL PRIVILEGES,GRANT OPTION FROM 'bakuser'; #移除该用户的所有权限

grant reload,process,lock tables,replication client on *.* to 'bakuser'@'%'; #为该用户赋权,包括刷新,锁表,查看服务器信息,复制权限

执行全量备份

innobackupex --user=bakuser --password=Admin123,. /date/db_bakup/

删库跑路

执行恢复操作

innobackupex --apply-log /date/db_bakup/2019-09-18_18-02-35/

innobackupex --copy-back /date/db_bakup/2019-09-18_18-02-35/

执行上述操作之后仅仅为恢复了数据库文件,下面要修改数据库文件的权限

chown -R mysql.mysql /data/mysql/data/

修改完之后重新连库即可看到数据了。