最近公司做数据库的单台服务器多实例,需要对各个数据库的进程进行监控,因为我们的资产数据库中已经有这个服务器跑多少个实例,端口是什么,用来做什么的,所以就拿资产数据库的端口和服务器本地运行的数据库端口进行对比,报出没有运行的mysql实例以及他的用途。一种方法是根据"ps auxww|grep mysqld|grep -v root|grep -v grep"这个命令抓取本地运行的数据库端口,不过你也可以根据netstat命令来获取本地数据库实例的所有端口;还有一种方法就是从资产中得到这个服务器应该运行的所有mysql端口,用python的socket模块来检测端口是否存活,这种方法比较简单一些。我用第一种方法是因为我的这段代码我已经写过用于其他用途,等于复用,图个省事。以下是代码内容:

  1. #!/bin/env python

  2. # -*- coding: utf-8 -*-


  3. import os,sys,MySQLdb


  4. def center(sql):#连接数据库

  5. try:

  6.        center_ip = '192.168.1.100'

  7.        center_user = 'root'

  8.        center_passwd = 'xxxxxx'

  9.        conn = MySQLdb.connect(host = center_ip,user = center_user,passwd = center_passwd,charset='utf8',connect_timeout=20)

  10.        cursor = conn.cursor()  

  11.        cursor.execute(sql)

  12.        alldata = cursor.fetchall()

  13.        cursor.close()

  14.        conn.close()

  15. return alldata

  16. except:

  17. return0


  18. class check_port():#走资产中获取本地IP中应该有多少个mysql实例端口


  19. def __init__(self):

  20.        conn = "ip a|grep glob|grep -v '192.168'|awk '{print $2}'"

  21. self.host = os.popen(conn).readlines()[0].split("/")[0]


  22. def remot(self):

  23.        sql = "SELECT PORT FROM center.host_info WHERE flag='1' AND del_info!=0 AND ip='%s' AND host_name IN ('a','b','c')" % self.host

  24.        alldata = center(sql)

  25.        cent_port = []

  26. if alldata != 0:

  27. for i in alldata:

  28.                cent_port.append(str(i[0]))

  29. return cent_port

  30. else:

  31. return cent_port


  32. def local(self):#获取本地mysql有多少个实例运行

  33.        psinfo = os.popen("ps auxww|grep mysqld|grep -v root|grep -v grep").readlines()

  34.        local_port = []

  35. ifnot psinfo:

  36. return local_port

  37. for i in psinfo:

  38. for j in i.split("--"):

  39. if j.find("port") != -1:

  40.                    port = j.split("=")[1].strip()

  41.                    local_port.append(port)

  42. return local_port


  43. def main(self):

  44.        local_port = self.local()

  45.        cent_port = self.remot()

  46.                cent_port.sort()

  47.                local_port.sort()

  48. if local_port == cent_port and len(local_port) != 0and len(cent_port) != 0:

  49. print0

  50. else:

  51.            error = ""

  52.            diff_list = list(set(local_port) ^ set(cent_port))

  53. for port in diff_list:

  54.                sql = "SELECT CONCAT(a.main_name,'_',b.sub_name,'_',c.app_name,'_',c.port) AS used FROM center_app.main_category a, center_app.sub_category b, center_app.app_info c WHERE a.id = b.main_id AND b.dist_id = c.dist_id AND b.main_id = c.main_id AND b.main_id='2' AND c.flag='1' AND c.del_info!=0 AND c.ip='%s' and c.port='%s'" % (self.host,port)

  55.                alldata = center(sql)

  56. if error == "":

  57.                    error = error + alldata[0][0]

  58. else:

  59.                    error = error + ";" + alldata[0][0]

  60. print error


  61. if __name__ == "__main__":

  62.    boss = check_port()

  63.    boss.main()

如果用第二种方法的话,很简单,用下面的函数可以实现这个端口测试:

  1. ipmort socket


  2. def test_port()

  3.    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

  4.    s.settimeout(2)

  5.    address = '127.0.0.1'

  6.    port = 80

  7. try:

  8.        s.connect((address,port))

  9. returnTrue

  10. except Exception,e:

  11. returnFalse

  12.    s.close()