设为首页 收藏本站
查看: 2118|回复: 0

[经验分享] zabbix数据库备份整理

[复制链接]

尚未签到

发表于 2019-1-21 12:41:00 | 显示全部楼层 |阅读模式
zabbix数据库备份整理
zabbix数据库备份整理
  zabbix的所有操作都是存在数据库里,在数据库里都会有对应的表,所以对zabbix备份,只需备份数据库就行了。
  采用mysqldump进行数据库备份如下:
  mysqldump -uroot -p --opt zabbix |bzip2 > zabbix.sql.bz2
  但是进行此操作时,发现备份需要很长时间,zabbix的MySQL备份文件异常庞大,查看下zabbix的数据库表,发现mysql系统文件下zabbix目录本身并不是很大,也就几百行,但发下同目录下得ibdata1文件异常庞大,达到10多个G
  查看了zabbix数据库的存储原理,zabbix数据库是使用的InnoDB引擎的共享空间,InnoDB把数据库和索引都放在ibdata1下,随着数据的增长,ibdata1会越来越大。性能方面会有影响。
  然后就很好奇zabbix为什么会使用innodb的共享表空间存储数据,网上查看到一段资料写到
  —————————————————————————————-
  使用过MySQL的同学,刚开始接触最多的莫过于MyISAM表引擎了,这种引擎的数据库会分别创建三个文件:表结构、表索引、表数据空间。我们可以将某个数据库目录直接迁移到其他数据库也可以正常工作。
  然而当你使用InnoDB的时候,一切都变了。InnoDB 默认会将所有的数据库InnoDB引擎的表数据存储在一个共享空间中:ibdata1,这样就感觉不爽,增删数据库的时候,ibdata1文件不会自动收缩,单个数据库的备份也将成为问题。通常只能将数据使用mysqldump 导出,然后再导入解决这个问题。
  在MySQL的配置文件[mysqld]部分,增加innodb_file_per_table参数,可以修改InnoDB为独立表空间模式,每个数据库的每个表都会生成一个数据空间。
  独立表空间
  优点:
  1.每个表都有自已独立的表空间。
  2.每个表的数据和索引都会存在自已的表空间中。
  3.可以实现单表在不同的数据库中移动。
  4.空间可以回收(drop/truncate table方式操作表空间不能自动回收)
  5.对于使用独立表空间的表,不管怎么删除,表空间的碎片不会太严重的影响性能,而且还有机会处理。
  缺点:
  单表增加比共享空间方式更大。
  结论:
  共享表空间在Insert操作上有一些优势,但在其它都没独立表空间表现好。
  当启用独立表空间时,请合理调整一下 innodb_open_files 参数。
  —————————————————————————————-
  原来默认情况下innodb会将所有的数据库InnoDB引擎的表数据存储在一个共享空间中ibdata1,而且增删数据库的时候,ibdata1文件不会自动收缩,单个数据库的备份也将成为问题。
  所以决定将innodb的共享表空间改成独立表空间,然后以后单独备份zabbix数据库时就不会备份整个数据库文件,导致系统资源浪费,最后再做一个定期的清理zabbix历史记录脚本,这样就不会担心以后备份文件过大,导致服务器硬盘容量紧张.
  1、查看bdata1文件大小
  cd /data1/mysql
  du -sh *
  2、登陆MySQL查看哪些表占用了空间
  # mysql -uroot -p
  mysql> select table_name, (data_length+index_length)/1024/1024 as total_mb, table_rows from information_schema.tables where table_schema=‘zabbix’;
  发现history表记录已达到8个G左右,8千多万行数据,还有history_unit也比较大,还有以下一些表也存在一些数据:
  trends,trends_uint,event等等
  4、做了如下操作,首先将配置表导出,zabbix数据库中有很多的表,大体上分为存放监控数据的表和配置的表两种。数据表有:
  alerts auditlog events historyhistory_log history_str history_str_sync history_sync history_text history_uint history_uint_sync node_cksum proxy_dhistory proxy_history service_alarms services_times trends trends_uint
  其它的表便是zabbix的配置信息表:
  # mysqldump -uroot -p --databases zabbix --ignore-table=zabbix.alerts --ignore-table=zabbix.auditlog --ignore-table=zabbix.events --ignore-table=zabbix.history --ignore-table=zabbix.history_log --ignore-table=zabbix.history_str --ignore-table=zabbix.history_str_sync --ignore-table=zabbix.history_sync --ignore-table=zabbix.history_text --ignore-table=zabbix.history_uint --ignore-table=zabbix.history_uint_sync --ignore-table=zabbix.node_cksum --ignore-table=zabbix.proxy_dhistory --ignore-table=zabbix.proxy_history --ignore-table=zabbix.service_alarms --ignore-table=zabbix.services_times --ignore-table=zabbix.trends --ignore-table=zabbix.trends_uint > zabbix_config.sql
  # ls /data1/
  lost+found  mysql  nginx  pool-content  share.d00  share.sinajs  zabbix_config.sql  
  然后停止相关服务:
  # /etc/init.d/zabbix_server stop
  # /etc/init.d/httpd stop
  登陆MySQL:
  # mysql -uroot -p
  mysql > use zabbix;
  mysql > truncate table history;
  mysql > optimize table history;
  mysql > truncate table history_str;  # 未输入
  mysql > optimize table history;       # 未输入
  mysql > truncate table history_uint;
  mysql > optimize table history_uint;
  mysql > truncate table trends;
  mysql > optimize table trends;
  mysql > truncate table trends_uint;
  mysql > optimize table trends_uint;
  mysql > truncate table events;   # 未输入
  mysql > optimize table events;   # 未输入\
  # mysqldump -uroot -p --opt zabbix |bzip2 > zabbix.sql.bz2
  ?? 最后重新导入数据库,
  mysqldump -uroot -p zabbix < zabbix.sql
  然后发现之前的数据以丢失,以上方法步骤应该不对,
  !!应该是先使用mysqldump导出数据,然后删除共享表空间数据文件,再重新导入数据
  参考网址:
  http://www.kankanews.com/ICkengine/archives/66531.shtml
  http://www.kankanews.com/ICkengine/archives/108576.shtml


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-666014-1-1.html 上篇帖子: zabbix数据库表结构说明 下篇帖子: 深度剖析Zabbix Web scenarios数据表结构
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表