mysql主从的binlog定时删除是很重要的,一般是通过expire_logs_days = 10来设置binlog保留的天数(mysql5.0一下版本不支持),但有时这还不够,假如有几天的日志量非常大,硬盘可能会满,所以不但要设置保留的天数,还要监控硬盘的空间使用情况。写了一个脚本,适合各个版本的mysql,保留3天的日志,当存放日志的硬盘使用率超过80%,则保留2天,但至少会保留一天的binlog日志文件。

  1. #!/bin/env python
  2. # -*- coding: utf-8 -*-
  3. ##############################################################
  4. #查看存在binlog的目录位置并找出3天前的最后一个bin-log文件名字
  5. #删除3天以前的binlog文件,删除之后data1目录挂载的硬盘使用率超
  6. #过的80%的话,继续删除2天前的日志文件,至少保留一天的日志。
  7. ##############################################################
  8. import os,sys,time,MySQLdb
  9. def log_w(text):
  10. logfile = "/usr/local/zabbix/bin/delet.log"
  11. now = time.strftime("%Y-%m-%d %H:%M:%S")
  12. tt = now + "\t" + str(text) + "\n"
  13. f = open(logfile,'a+')
  14. f.write(tt)
  15. f.close()
  16. def mysql_conn(port,lastlog,days):
  17. try:
  18. center_ip = '127.0.0.1'
  19. center_user = 'repl_monitor'
  20. center_passwd = 'VQMQLGwTaw3k0UV8'
  21. sql = "PURGE MASTER LOGS TO '%s';" % lastlog
  22. conn = MySQLdb.connect(host = center_ip,port = int(port),user = center_user,passwd = center_passwd,connect_timeout=5)
  23. cursor = conn.cursor()
  24. cursor.execute(sql)
  25. alldata = cursor.fetchall()
  26. cursor.close()
  27. conn.close()
  28. text = "Deltet before %s days binlog,deltet %s before !" % (days,lastlog)
  29. log_w(text)
  30. except Exception,e:
  31. log_w(e)
  32. def find_logdir():
  33. conn = "find / -name binlog|grep -v usr"
  34. logdir_list = os.popen(conn).readlines()
  35. if len(logdir_list) != 0:
  36. for logdir in logdir_list:
  37. datadir = logdir.strip().split("/")[1]
  38. if "mysql_log" in logdir.strip():
  39. port = 3306
  40. else:
  41. port = logdir.strip().split("/")[3].split("-")[-1]
  42. days = 3
  43. while 1:
  44. conn = "find %s -mtime %s|sort" % (logdir.strip(),days)
  45. count = os.popen(conn).readlines()
  46. if len(count) != 0:
  47. lastlog = count[-1].strip().split("/")[-1]
  48. mysql_conn(port,lastlog,days)
  49. df = "df -h|grep -e '%s$'|awk '{print $5}'|awk -F '%%' '{print $1}'" % datadir
  50. disk = os.popen(df).read().strip()
  51. if not disk:
  52. break
  53. else:
  54. if int(disk) < 80:
  55. break
  56. else:
  57. days = days - 1
  58. if days == 1:
  59. break
  60. else:
  61. sys.exit()
  62. if __name__ == "__main__":
  63. find_logdir()

本文出自 “王伟” 博客,请务必保留此出处http://wangwei007.blog.51cto.com/68019/1123088

mysql主从日志的定期清理的更多相关文章

  1. mysql 主从日志文件mysql-bin文件清除方法

    默认情况下mysql会一直保留mysql-bin文件,这样到一定时候,磁盘可能会被撑满,这时候是否可以删除这些文件呢,是否可以安全删除,是个问题,不建议使用rm命令删除,这样有可能会不安全,正确的方法 ...

  2. 在 CentOS7 上部署 MySQL 主从

    在 CentOS7 上部署 MySQL 主从 通过 SecureCRT 连接至 MySQL 主服务器: 找到 my.cnf 文件所在的目录: mysql --help | grep my.cnf 一般 ...

  3. 高性能Mysql主从架构的复制原理及配置详解

    温习<高性能MySQL>的复制篇. 1 复制概述 Mysql内建的复制功能是构建大型,高性能应用程序的基础.将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台 ...

  4. mysql主从配置

    引言: 双11,阿里云服务器打折,于是我忍不住又买了一台服务器,于是咱也是有两台服务器的爷们了,既然有了两台服务器,那么肯定要好好利用一下吧,那么就来玩玩mysql的主从配置吧. 准备 两台数据库服务 ...

  5. 恢复MySQL主从数据一致性的总结

    今日上午,同事告知,MySQL主从数据库的数据不一致,猜测备库在同步过程中出现了问题,于是,登上备库,使用 mysql> show slave status\G查看,果然,备库在insert语句 ...

  6. LVS+Keepalived+Squid+Nginx+MySQL主从高性能集群架构部署方案

    方案一,在tomcat的workers.properties里面配置相关条件 worker.tomcat.lbfactor= worker.tomcat.cachesize= worker.tomca ...

  7. Mysql主从配置,实现读写分离

    大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库连接操作,数据库必然会崩溃,数据丢 ...

  8. MySQL 主从配置

    mysql主从复制指两个服务器之间数据库的同步,当主服务器的数据进行了变更,从服务器也会自动更新,其过程是通过bin-log日志实现的,本质是binlog日志的传输. mysql主从分两个角色 1.主 ...

  9. mysql主从切换

    mysql 主从切换 主停,从做主步骤如下: 1 确认从服务器已经完成所有同步操作:stop slave io_thread show processlist 直到看到状态都为:xxx has rea ...

随机推荐

  1. 深度技术32位Win7系统Ghost版2014年

    深度技术32位Win7系统Ghost版,GhostWin7是指使用Ghost软件做成压缩包的Windows7,俗称克隆版Win7.用克隆版的目的是节省安装时间.本作品在采用微软封装部署技术的基础上,结 ...

  2. 《Head First Java》——认识变量

    对象的引用 Book b = new Book(); Book c = new Book(); Book d = c;                   // 声明新的Book引用变量,但不创建新的 ...

  3. Java--Exchanger用于进行线程间的数据交换

    package com; import java.util.concurrent.Exchanger; /** * Created by yangyu on 16/11/28. */ /** * Ex ...

  4. Javascript——DOM

    DOM(Document Object Model)文档对象模型 --DOM可以将任何HTML或XML文档描绘成一个由多层节点构成的结构. D--doument(文档).当创建一个网页并把它加载到we ...

  5. php学习5-时间和日期

    如果时间时区不对,使用时间是要先设定时区,使用date_default_timezone_set() 设置新时区 date_default_timezone_set('Asia/Shanghai'); ...

  6. puporwindow

    //Java代码private void showPopupWindow(View view) { // 一个自定义的布局,作为显示的内容 View contentView = LayoutInfla ...

  7. Seen.js – 使用 SVG 或者 Canvas 渲染 3D 场景

    Seen.js 渲染3D场景为 SVG 或者 HTML5 画布.Seen.js 包含对于 SVG 和 HTML5 Canvas 元素的图形功能的最简单的抽象.所有这个库的其它组件都是不用关心将要渲染的 ...

  8. 分享25个新鲜出炉的 Photoshop 高级教程

    网络上众多优秀的 Photoshop 实例教程是提高 Photoshop 技能的最佳学习途径.今天,我向大家分享25个新鲜出炉的 Photoshop 高级教程,提高你的设计技巧,制作时尚的图片效果.这 ...

  9. [js开源组件开发]模拟下拉选项框select

    模拟下拉选项框select 在css3流行的情况下,下拉框还是无法满足PD的需求,所以有了autosearch,有了模拟下拉框.效果如下图: select DEMO请案例点击这里查看.http://w ...

  10. 变量作用域&函数作用域

    一. 变量作用域 1)全局变量 在全局环境下声明的变量被视为全局变量. 在没有使用var进行声明的时候,变量就被定义为全局变量.在ES5的严格模式下,如果变量没有使用var来声明是会报错的. 2)局部 ...