Zabbix 数据库迁移
背景:ZABBIX的环境是LNMP,MySQL的架构是M-M主备模式,单台服务器SSD硬盘800G。监控主机日渐增多,空间不足,迁移到同样架构下的SAS盘2T空间。
架构:A 192.168.0.100 -> B 192.168.0.101 -> C 192.168.0.102 -> D 192.168.0.103
步骤:
1、搭建级联从库
2、修改zabbix server配置,加读锁,切库
3、验证
1、搭建级联从库
1> 检查开启B上的两个参数 log_bin log_slave_updates
mysql> show variables like 'log_bin';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| log_bin | ON |
+---------------+-------+
mysql> show variables like 'log_slave_updates'; --log_slave_updates是只读参数,修改该参数需要重启数据库
+-------------------+-------+
| Variable_name | Value |
+-------------------+-------+
| log_slave_updates | ON |
+-------------------+-------+
2> 配置环境
1) B C安装lz4
yum install -y lz4
2) 配置B到C的SSH免认证登陆
3) 关闭C的mysql服务,并清空data目录下文件
service mysqld stop
4) 热备B上数据
nohup /usr/bin/innobackupex --user=root \
--password=xxx \
--parallel=4 \
--socket=/tmp/mysql.sock \
--slave-info --safe-slave-backup \
--no-timestamp \
--stream=xbstream . |\
lz4 -B4 |\
ssh root@192.168.0.102 \
"cat - | lz4 -d -B7 | xbstream -x -C /data/mysql/data" &
5) 到C备份的文件目录下,将数据恢复到一致性位点,对应 FTWRL 时间点
innobackupex --apply-log /data/mysql/data
6) 启动C的mysql服务
chown -R mysql:mysql /data/mysql/
service mysqld start
3> 搭建 B -> C 从库
1) 打开备份目录中xtrabackup_binlog_info文件,替换MASTER_LOG_FILE,MASTER_LOG_POS
CHANGE MASTER TO
MASTER_HOST='192.168.0.101',
MASTER_USER='replication',
MASTER_PASSWORD='XXX',
MASTER_PORT=3306,
MASTER_LOG_FILE='mysql-bin.000312',
MASTER_LOG_POS=149457383,
MASTER_AUTO_POSITION=0
2) C上启动slave
reset master; --重新搭建主从的时候要执行
reset slave;
start slave;
show slave status\G
C -> D 的主从搭建,同 B -> C,要注意的是,切换后,如果要搭建 C-D 双主架构,需要关闭D上log_slave_update参数。
2、修改zabbix server配置,切库
1> 停止zabbix server服务
service zabbix-server stop
2> 修改 zabbix_server.conf
DBHost=192.168.0.102
3> C上停止salve
stop slave
4> 启动zabbix server服务
service zabbix-server start
数据库切换启动后,zabbix会重新同步缓存数据,此时查看数据库processlist,会发现有与StartDBSyncers参数设置个数相同的线程在查询发送数据。时刻关注zabbix_server日志,如果出现下面的问题,同步时间会异常缓慢,要终止同步需要先停止server进程,然后 kill 掉数据库中的连接。问题解决方案,可参考下面记录。
问题记录:
1、zabbix server后台日志出现defunct状态,并且日志中有out of memory报错
查看zabbix server 进程
bestpay : ? :: [zabbix_server] <defunct>
bestpay : ? :: [zabbix_server] <defunct>
bestpay : ? :: [zabbix_server] <defunct>
root : pts/ :: tail -f /data/dataLogs/zabbix_server/zabbix_server.log
root : pts/ :: grep zabbix_server
查看zabbix_server.log
::233508.259 Zabbix agent item "pyora[{$USERNAME},{$PASSWORD},{$ADDRESS},{$DATABASE},sga_shared_pool]" on host "yfkdbrsh-sh-159-33" failed: first network error, wait for seconds
::233510.358 __mem_malloc: skipped asked skip_min skip_max
::233510.358 [file:dbcache.c,line:] zbx_mem_realloc(): out of memory (requested 755232 bytes)
::233510.358 [file:dbcache.c,line:] zbx_mem_realloc(): please increase HistoryIndexCacheSize configuration parameter
::233510.359 __mem_malloc: skipped asked skip_min skip_max
::233510.359 [file:dbcache.c,line:] zbx_mem_realloc(): out of memory (requested bytes)
::233510.359 [file:dbcache.c,line:] zbx_mem_realloc(): please increase HistoryIndexCacheSize configuration parameter
::233510.359 One child process died (PID:,exitcode/signal:). Exiting ...
::233512.381 syncing history data...
::233534.219 slow query: 21.830923 sec, "update items set lastlogsize=3833923,mtime=0 where itemid=285141;
解决方案:
zabbix 参数调整:
HistoryIndexCacheSize=2048M --原来没有,建议根据内存大小设置一个缓存值,取值范围128K-2G,默认4M,zabbix3.0.0后版本支持
StartDBSyncers=16 --sync 数据的时候启动几个进程来干活,根据数据库压力负载来进行设置,值过大会造成数据库阻塞,取值范围1-100,默认值4
系统内核参数调整:
#kernel.shmall = 4294967296 --原有参数值过大,不合理,导致out of memory的根本原因
kernel.shmall = 16252928 --正确的值是按照物理内存除以OS block size的值
参考资料:
|
作者:zero_gg 如果你真心觉得文章写得不错,而且对你有所帮助,那就不妨小小打赏一下吧,如果囊中羞涩,不妨帮忙“推荐"一下,您的“推荐”和”打赏“将是我最大的写作动力! 本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接. |
Zabbix 数据库迁移的更多相关文章
- zabbix数据库mariadb从服务器迁移到云mysql数据库的操作
zabbix数据库mariadb从本机迁移到云mysql数据库的操作 1.将zabbix数据库导出,并导入到云数据库中 由于数据库较大,如果直接使用shell会话中断会导致数据库导出或者导入失败,使用 ...
- zabbix 数据库分表操作
近期zabbix数据库占用的io高,在页面查看图形很慢,而且数据表已经很大,将采用把数据库的数据目录移到新的磁盘,将几个大表进行分表操作 一.数据迁移: 1.数据同步到新的磁盘上,先停止mysql(不 ...
- EF Code First Migrations数据库迁移
1.EF Code First创建数据库 新建控制台应用程序Portal,通过程序包管理器控制台添加EntityFramework. 在程序包管理器控制台中执行以下语句,安装EntityFramewo ...
- 2.EF中 Code-First 方式的数据库迁移
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/code-first-migrations-with-entity-framework/ 系列目 ...
- laravel数据库迁移(三)
laravel号称世界上最好的框架,数据库迁移算上一个,在这里先简单入个门: laravel很强大,它把表中的操作写成了migrations迁移文件,然后可以直接通过迁移文件来操作表.所以 , 数据迁 ...
- Code First开发系列之数据库迁移
返回<8天掌握EF的Code First开发>总目录 本篇目录 开启并运行迁移 使用迁移API 应用迁移 给已存在的数据库添加迁移 EF的其他功能 本章小结 自我测试 本系列的源码本人已托 ...
- ABP Migration(数据库迁移)
今天准备说说EntityFramework 6.0+,它与我之前所学的4.0有所区别,自从4.1发布以来,code first 被许多人所钟爱,Dbcontext API也由此时而生.早在学校的时候就 ...
- sqlserver 2008R2数据库迁移oracle
x项目需要,将以前的sqlserver数据库迁移的oracle数据库中,由于以前对oracle只是在DML语句的步骤,所以总结一下这次遇到的问题以及具体步骤 1,oracle新建数据库 新建Oracl ...
- 【强烈推荐】数据库迁移利器:Migrator.Net
简介 很郁闷,写了一天的遇到LiveWriter错误,可恶啊 几年前在做项目中第一次接触到了Migrator.Net,就深深被吸引住了,至此以后在新的大项目中,我都会使用Migrator.Net来创建 ...
随机推荐
- 10.使用du将文件按大小进行排序
按G进行排序du -sh * | grep G | sort -nr
- java-filter and listener
Java Servlet 是运行在 Web 服务器或应用服务器上的程序,它是作为来自 Web 浏览器或其他 HTTP 客户端的请求和 HTTP 服务器上的数据库或应用程序之间的中间层. 使用 Serv ...
- Jobs(三) HTML的form表单提交中文后,后台取出乱码的问题
解决form表单中提取的中文在后台乱码的问题有两种情况: form表单以GET方式提交: form表单以POST方式提交 一. 解决以GET方式提交的中文乱码问题,可以更改Tomcat服务器的配置文件 ...
- 轻松搭建CAS 5.x系列(1)-使用cas overlay搭建SSO SERVER服务端
概要说明 cas的服务端搭建有两种常用的方式: 1. 基于源码的基础上构建出来的 2. 使用WAR overlay的方式来安装 官方推荐使用第二种,配置管理方便,以后升级也容易.本文就是使用第 ...
- Jersey 写restful接口时QueryParam ,FormParam 等的区别
今天用jersey写接口,发现有一个post方法中没有得到参数,查了半天发现自己一不小心将@formparam写成了@queryparam,真是一个悲伤的故事.在这里把几个参数类型整理了一下放出来. ...
- ScrumBasic开发记录
ScrumBasic 是基于asp.net core 1.0的开源敏捷管理软件.目前第一版.目前只有很基础的东西.希望我能将这个项目演变下去. 地址:https://github.com/CAH-Fl ...
- ie/chorme 清除缓存 刷新js,css
1 有时候你发现你刚改过的js 没有用,然后就是你的浏览器 没有清楚缓存,它可能还是保存的之前的 网页文件: chorme 浏览器下(版本:ver 59.0.3071.104(正式版本) (64 位) ...
- python简答
解释 GIL 全局解释器锁 def func(*args): for i in args: print(i) func(3,2,1,4,7) 在我们不知道该传递多少关键字参数时,使用**kwargs ...
- TypeScript入门六:TypeScript的泛型
泛型函数 泛型类 一.泛型函数 在泛型函数之前,先简单的描述一下泛型,将变量定义成泛型可以在使用变量时来决定它的类型.什么意思呢?假如现在有一个函数,可能出现参数和返回值出现多种情况的现象,只有在调用 ...
- 2.3 使用 dom4j 对 xml文件进行 dom 解析
// 使用dom4j对XML文档进行解析 CRUD public class Demo1 { //读取XML文档中第二本书的书名 <书名>javaWEB</书名> @Test ...