Python實現根據指定端口探測服務器/模塊部署的方法
更新時間:2014年08月25日 10:23:54 投稿:shichen2014
這篇文章主要介紹了Python根據指定端口探測服務器/模塊部署的方法,非常具有實用價值,需要的朋友可以參考下
本文實例講述了Python實現根據指定端口探測服務器/模塊部署的方法,非常具有實用價值。分享給大家供大家參考借鑒。
有些時候,在維護過程中,服務器數量非常多。應用模塊部署在不同服務器上。有時維護人員做了模塊遷移,而未及時同步至手冊中。查找比較困難。于是,產生Python根據應用端口進行探測,獲取模塊部署。
設想非常簡單:通過簡單的tcp鏈接,如果能夠成功的建立,立即斷開,防止影響業(yè)務。表示模塊在某服務器上有部署。
具體功能代碼如下:
#!/bin/env python # import socket import time from threading import Thread hostList=["10.10.126.170","10.10.126.173","10.10.126.177","10.10.126.170","10.10.126.173","10.10.126.177"] onLine=[] offLine=[] gathered=[] hostDict={"onLine":[],"offLine":[]} class detect(Thread): def __init__(self,ip, port=22): Thread.__init__(self) self.ip=ip self.port=port def run(self): address=(self.ip,self.port) sock=socket.socket(socket.AF_INET, socket.SOCK_STREAM) try: sock.connect(address) buff=sock.recv(1024) if(len(buff)): print("detect Host %s Online" % self.ip) onLine.append(self.ip) except: print("detect Host %s OffLine" % self.ip) offLine.append(self.ip) sock.close def sigle_detect(ip): p=detect(ip) p.start() p.join(60) def multi_detect(host): T_thread=[] for ip in set(host): t=detect(ip) t.name=ip t.start() T_thread.append(t) for t in T_thread: t.join(15) def filter_gather(hlist): gather=[] for t in set(hlist): gather.append(t) return gather def mak_hostList_byip3(iplist): global hostList hostList=[] for ip in set(iplist): tmp=ip.split('.') if(len(tmp)==3): for i in range(2,254): hostList.append('%s.%d' % (ip, i)) elif(len(tmp)==4): hostList.append(ip) else: continue return hostList def update_hostDict(onLine, offLine): hostDict["onLine"]=onLine hostDict["offLine"]=offLine def make_pickle_fileName(): import time fileName="" for s in time.localtime()[:5]: fileName=fileName+str(s) fileName="Host_%s.pkl" % fileName return fileName def save_gathered(fileName, hostDict): import pickle F=open(fileName,'wb') pickle.dump(hostDict,F) F.close() def recovery_gathered(fileName, keyList): import pickle try: F=open(fileName,'rb') E=pickle.load(F) keyList.append(E) except: F.close() return while E: try: E=pickle.load(F) keyList.append(E) except: F.close() break if __name__=='__main__': sigle_detect(hostList[0]) #--------------- mak_hostList_byip3(hostList) multi_detect(hostList) onLine=filter_gather(onLine) print(onLine) offLine=filter_gather(offLine) print(offLine) gathered=onLine+offLine print(gathered) update_hostDict(onLine, offLine) print(hostDict) fN=make_pickle_fileName() save_gathered(fN,hostDict) keyList=[] recovery_gathered(fN,keyList) print(keyList)
希望本文講述的方法對大家的Python程序設計有所幫助。
相關文章
Python 、Pycharm、Anaconda三者的區(qū)別與聯(lián)系、安裝過程及注意事項
這篇文章主要介紹了Python,Pycharm,Anaconda三者的區(qū)別與聯(lián)系、安裝過程及其注意事項,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-10-10python數據庫操作常用功能使用詳解(創(chuàng)建表/插入數據/獲取數據)
這篇文章主要介紹了python數據庫操作常用功能使用方法:獲取mysql版本、創(chuàng)建表、插入數據、slect獲取數據等,下面看示例吧2013-12-12