如何对比两个MySQL实例的参数情况,生产中常会有这样的需求,最近写了个python脚本,可基本实现该需求。

脚本

#!/usr/bin/python
import MySQLdb,sys
def fetch_variables(ip,user,passwd,port,variable=False):
# Open database connection
try:
db = MySQLdb.connect(host=ip, user=user,passwd=passwd,port=port)
except Exception,e:
print e
exit()
# prepare a cursor object using cursor() method
cursor = db.cursor()
if not variable:
sql = 'show variables'
else:
sql= "show variables like '%"+variable+"%'"
try:
# execute SQL query using execute() method.
cursor.execute(sql)
# Fetch all the rows in a list of lists.
results = cursor.fetchall()
dict={}
for row in results:
dict[row[0]]=row[1]
except:
print "Error: unable to fecth data"
return dict
def dict_to_set(dict):
return set(dict.keys()) def main():
if len(sys.argv)!=3 and len(sys.argv)!=4:
print 'Usage:',sys.argv[0],'ip:port nip:nport var'
exit()
user = 'root'
password = ''
ip, port = sys.argv[1].split(':')
nip,nport=sys.argv[2].split(':')
if len(sys.argv)==3:
variable=False
else:
variable=sys.argv[3]
dict = fetch_variables(ip, user, password, int(port),variable)
ndict = fetch_variables(nip, user, password, int(nport),variable)
set=dict_to_set(dict)
nset=dict_to_set(ndict)
same_variables=set.intersection(nset)
for variable in same_variables:
if dict[variable] != ndict[variable]:
print variable,':',dict[variable],'|',ndict[variable]
if __name__=='__main__':
main()

执行方式

输入:ip:port nip:nport var
功能:如果var为空,表示比较所有参数

带实例参数时,执行结果如下:

[root@mysql-server1 ~]# python diff_parameters.py 192.168.244.145:3306 192.168.244.146:3306 general_log_file
general_log_file : /var/lib/mysql/mysql-server1.log | /var/lib/mysql/keepalived01.log

不带实例参数时,执行结果如下:

[root@mysql-server1 ~]# python diff_parameters.py 192.168.244.145:3306 192.168.244.146:3306
version : 5.6.26-log | 5.6.26
log_bin_index : /var/lib/mysql/mysql-bin.index |
log_bin_basename : /var/lib/mysql/mysql-bin |
pseudo_thread_id : 9 | 104
slow_query_log_file : /var/lib/mysql/mysql-server1-slow.log | /var/lib/mysql/keepalived01-slow.log
server_id : 1 | 2
hostname : mysql-server1 | keepalived01
timestamp : 1462931171.666154 | 1462931171.957681
log_bin : ON | OFF
general_log_file : /var/lib/mysql/mysql-server1.log | /var/lib/mysql/keepalived01.log
max_binlog_size : 134217728 | 1073741824
server_uuid : c063ba6f-aee7-11e5-820e-000c29b05336 | 959bf641-b9e7-11e5-89c7-000c294c5ed4

输出结果解读:

第一列是实例参数,第二列和第三列用“|”隔开,其中第二列是第一个实例的参数值,第三列是第二个实例的参数值。

脚本解读

函数def fetch_variables(ip,user,passwd,port,variable=False)是从数据库中获取实例参数及值。variable=False的作用是来处理var为空和var不为空时的情况。

函数def dict_to_set(dict)是将字典转化为集合,这样对于字典的比较可以转为为集合来操作。

最新文章

  1. 结巴分词3--基于汉字成词能力的HMM模型识别未登录词
  2. Python黑帽编程1.2 基于VS Code构建Python开发环境
  3. bootstrap实现弹出窗口
  4. 禁用visual studio实时调试器
  5. eclipse插件:打开选中文件所在的目录
  6. Maven——eclipse中使用Maven创建Web项目
  7. Python3 学习第五弹:类与面向对象
  8. 解决ASP.NET MVC3与FusionCharts乱码问题
  9. nginx配置文件特殊字符说明
  10. django中使用原生sql
  11. S3C2440之IIC裸机驱动
  12. [原创]MinHook测试与分析(x64下 E9,EB,CALL指令测试,且逆推测试微软热补丁)
  13. Linux怎么查看软件安装路径 查看mysql安装在哪
  14. npm killed有可能是内存不够, 为Ubuntu增加swap
  15. ionic4+angular6 混合移动开发 capacitor cordova
  16. 信息安全之路-web-xss学习(2)
  17. Orchard详解--第七篇 拓展模块(译)
  18. (2) linux文件系统简介
  19. Py西游攻关之RabbitMQ、Memcache、Redis
  20. vue中绑定多个class,多个情况使用同一个class时,用js的或 “||”

热门文章

  1. tornado web 框架的认识
  2. 不同类型的指针+1之后增加的大小不同(a,&a的地址是一样的,但意思不一样)
  3. iptables 思维导图 (zz)
  4. cocos2d中各种action方法的应用
  5. Des与3Des加密解密
  6. WPF整理-使用ResourceDictionary管理Logical Resources
  7. Android课程---远程服务器存储
  8. JQM (功能栏、导航条)
  9. 【二】jekyll 的使用
  10. ABP理论学习之多租户