Python利用socket實現(xiàn)多進程的端口掃描器
作為開發(fā)人員經(jīng)常需要查看服務(wù)的端口開啟狀態(tài)判斷服務(wù)是否宕機。
特別是部署的服務(wù)比較多的情況下,可能存在幾個甚至幾十個服務(wù)端口的占用,于是我利用socket不斷向服務(wù)發(fā)送請求的方式來判斷端口服務(wù)是否已經(jīng)完成開啟。
其中加入多進程的調(diào)用方式來提高端口掃描的效率,供大家參考!
首先,我們將需要的python模塊全部導入到我們的代碼塊中,若是沒有安裝的模塊使用pip的當時安裝一下即可。
#?Importing?the?socket?module. import?socket #?Importing?the?datetime?module?from?the?datetime?package. from?datetime?import?datetime #?It's?a?shortcut?for?`from?multiprocessing?import?Pool` from?multiprocessing.dummy?import?Pool #?It's?a?shortcut?for?`from?loguru?import?logger` from?loguru?import?logger
然后,創(chuàng)建一個端口掃描類PortScanner來完成對整個業(yè)務(wù)邏輯的處理,另外,封裝到類中也便于大家參考和修改。
class?PortScanner: ????def?__init__(self): ????????""" ????????A?constructor.?It?is?called?when?an?object?is?created?from?a?class?and?it?allows?the?class?to?initialize?the ????????attributes?of?a?class. ????????""" ????????super(PortScanner,?self).__init__() ????????self.remote_ip?=?None ????????self.ports?=?[] ????def?scanner(self,?port): ????????""" ????????It?scans?the?port. ????????:param?port:?The?port?you?want?to?scan ????????""" ????????try: ????????????socket_?=?socket.socket(socket.AF_INET,?socket.SOCK_STREAM) ????????????result_?=?socket_.connect_ex((self.remote_ip,?port)) ????????????if?result_?==?0: ????????????????logger.info('地址:{}?端口:{}?已成功開啟!'.format(self.remote_ip,?port)) ????????????else: ????????????????logger.info('地址:{}?端口:{}?未開啟!'.format(self.remote_ip,?port)) ????????except?Exception?as?e: ????????????logger.error('端口掃描出現(xiàn)異常!') ????????finally: ????????????socket_.close() ????def?start(self): ????????""" ????????It?starts?the?game. ????????""" ????????remote_server?=?input("輸入要掃描的主機地址(127.0.0.1):") ????????if?remote_server.strip()?==?'': ????????????remote_server?=?'127.0.0.1' ????????self.remote_ip?=?socket.gethostbyname(remote_server) ????????port_range?=?input("輸入要掃描的端口范圍(1,50000):") ????????scanner_ports?=?[] ????????if?port_range.strip()?==?'': ????????????port_range?=?'1,50000' ????????scanner_ports?=?[n?for?n?in?range(int(port_range.split(',')[0]),?int(port_range.split(',')[1]))] ????????socket.setdefaulttimeout(0.5) ????????start_?=?datetime.now() ????????pool?=?Pool(processes=10) ????????pool.map(self.scanner,?scanner_ports) ????????pool.close() ????????pool.join() ????????end_?=?datetime.now() ????????logger.info('所有端口掃描已完成,總共耗時:{}'.format(str(end_?-?start_)))
使用python模塊中的main函數(shù)調(diào)用整個端口掃描器執(zhí)行掃描任務(wù)。
#?It's?a?common?idiom?to?determine?if?the?script?is?being?run?directly?or?being?imported. if?__name__?==?'__main__': ????scanner_?=?PortScanner() ????scanner_.start()
到此這篇關(guān)于Python利用socket實現(xiàn)多進程的端口掃描器的文章就介紹到這了,更多相關(guān)Python socket多進程端口掃描內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用Python實現(xiàn)Windows定時關(guān)機功能
是最初的幾個爬蟲,讓我認識了Python這個新朋友,雖然才剛認識了幾天,但感覺有種莫名的默契感。下面通過這篇文章給大家介紹Python實現(xiàn)Windows定時關(guān)機功能,需要的朋友可以參考下2017-03-03Python3安裝模塊報錯Microsoft Visual C++ 14.0 is required的解決方法
這篇文章主要介紹了Python3安裝模塊報錯Microsoft Visual C++ 14.0 is required的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07PyTorch實現(xiàn)聯(lián)邦學習的基本算法FedAvg
這篇文章主要為大家介紹了PyTorch實現(xiàn)聯(lián)邦學習的基本算法FedAvg,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-05-05Python:pycharm中虛擬環(huán)境venv的使用及說明
文章介紹了虛擬環(huán)境的必要性和實踐方法,虛擬環(huán)境可以幫助用戶管理不同項目所需的Python版本和第三方模塊,避免版本沖突和模塊沖突,文章詳細介紹了如何使用Python自帶的`venv`模塊創(chuàng)建和管理虛擬環(huán)境,并通過命令行和PyCharm兩種方式構(gòu)建虛擬環(huán)境2025-01-01基于Python實現(xiàn)將列表數(shù)據(jù)生成折線圖
這篇文章主要介紹了如何利用Python中的pandas庫和matplotlib庫,實現(xiàn)將列表數(shù)據(jù)生成折線圖,文中的示例代碼簡潔易懂,需要的可以參考一下2022-03-03