为方便维护MySQL,写了个脚本用以提供收集错误信息的接口。这些错误信息来自与MySQL错误日志,而 通过grep mysql可以获取error-log的路径。

以下是全部相关代码:

#!/usr/bin/env python2.7#-*- encoding: utf-8 -*- """该模块用于提取每天mysql日志中的异常或错误信息author: xiaomoemail: moxiaomomo@gmail.com""" import osimport sysimport stringfrom datetime import * # 預設字符解碼器為utf-8reload(sys)sys.setdefaultencoding('utf-8')  COMMON_FLAGS = ["error", "exception", "fail", "crash", "repair"] def _contain_flag(cur_str):  for flag in COMMON_FLAGS:    if flag in string.lower(cur_str):      return True  return False """获取当前mysql实例的error_log文件路径"""def _get_mysql_error_log_path():  log_path = ''  grep_infos = os.popen('ps aux | grep mysql | grep "log-error"').read()  if len(grep_infos) > 1:    grep_infos = grep_infos.split("log-error=")  if len(grep_infos) > 1:    grep_infos = grep_infos[1].split(' ')  if len(grep_infos) > 1:    log_path = grep_infos[0]  return log_path """读取mysql错误日志中包含异常或错误信息的行"""def _get_error_info(error_log, begin_date):  error_infos = []  f = open(error_log, 'r')  lines = f.readlines()  for line in lines:    data_array = line.split(' ')    if len(data_array) > 0 and len(data_array[0]) == 10:      dt_strs = data_array[0].split('-')      cur_date = date(int(dt_strs[0]), int(dt_strs[1]), int(dt_strs[2]))      if cur_date >= begin_date and _contain_flag(line):        error_infos.append(line)  f.close()  return error_infos """组装并返回mysql错误日志信息"""def get_mysql_errors(begin_date=date.today()-timedelta(1)):  try:    err_log_path = _get_mysql_error_log_path()    if len(err_log_path) > 1:      return _get_error_info(err_log_path, begin_date)  except Exception,e:    print "[get_mysql_errors]%s"%e    return []

更多相关文章

  1. MySQL系列多表连接查询92及99语法示例详解教程
  2. Android(安卓)模糊搜索rawquery bind or column index out of ra
  3. 发现 developer.android.com 官网的一个单词错误:
  4. Android(安卓)- Manifest 文件 详解
  5. Android的Handler机制详解3_Looper.looper()不会卡死主线程
  6. Android调用.NET Webservice报org.ksoap2.serialization.SoapPri
  7. Selector、shape详解(一)
  8. Android(OpenCV) NDK开发: 0xdeadbaad(code=1)错误 及 关闭armea
  9. android2.2资源文件详解4--menu文件夹下的菜单定义

随机推荐

  1. Android学习之Asynctask异步操作
  2. android 文件读取(assets)
  3. CocosCreator反射在Android中的使用
  4. eclipse下运行EasyAR官方sample的方法
  5. Android底部导航栏实现之BottomNavigatio
  6. android源码解析之(十四)-->Activity启动流
  7. Android开发之RecyclerView的侧滑删除
  8. Android 可拖动进度条:SeekBar之自定义进
  9. Volley的使用以及源码分析(二)
  10. Android启动其他应用(支持跳转应用市场下