Python获取网络中的存活主机以及哪些主机是Linux
这个脚本用于扫描网络中的存活主机,通常在CMDB中自动获取主机的时候用到。
#!/usr/bin/env python
# -*- coding: utf-8 -*- """
执行这个脚本的主机要安装下面两个模块
pip3 install python-nmap 这个Python模块依赖操作系统的nmap
确保操作系统安装了nmap yum -y install nmap # for centos
主要功能:扫描网段获取存活主机以及主机是否为Linux。不是Linux的被标记为Unknown,这些主机会包括交换机、路由器、Windows等。
"""
import sys
from functools import partial import nmap
import telnetlib
import asyncio def timer(tagName):
import time
def wapper(func):
def aa(self, *args, **kwargs):
start = time.time()
data = func(self, *args, **kwargs)
end = time.time()
consume = end - start
if consume > 60:
min, sec = divmod(consume, 60)
print("%s 执行耗时:%s 分 %s 秒。" % (tagName, str(min), str(sec)))
else:
print("%s 执行耗时:%s 秒。" % (tagName, str(consume)))
return data
return aa return wapper class ScanHost(object): def __init__(self):
self._hostsinfor = [] @timer(tagName="扫描")
def scan(self, hosts='127.0.0.1', ports=None):
"""
扫描主机
:param hosts: 可以是IP也可以是网段,例如 192.168.100.10、192.168.100.0/24
:param ports: 可以写端口也可以写端口范围,例如22、22-33,默认是None也就是所有端口
:return: [{'IP': '127.0.0.1', 'Status': 'up', 'OSType': 'Linux'}, {}, {}]
"""
hostlist = self._scanner(hosts, ports)
loop = asyncio.get_event_loop()
taskList = []
for hostdic in hostlist:
taskList.append(loop.create_task(self._isLinux(hostdic["IP"],))) for task in taskList:
task.add_done_callback(partial(self._callback)) loop.run_until_complete(asyncio.wait(taskList))
return self._hostsinfor def _callback(self, future):
res = future.result()
self._hostsinfor.append(res) async def _isLinux(self, host, port='22'):
"""
判断目标主机是否是Linux,这是通过telnet远程登录SSH端口号后根据输出内容来判断的
所以需要远程主机开启SSH服务
:param host:
:param port:
:return: True|False
"""
try:
tm = telnetlib.Telnet(host=host, port=port, timeout=5)
# 读取的内容通常是这样的 b'SSH-2.0-OpenSSH_5.3\r\n' 字节,所以只需要判断是否含有OpenSSH就知道是否是Linux
# 因为默认Windows上面没有OpenSSH服务,虽然你可以单独安装通常来讲没必要。
b_content = tm.read_until(b'\n', timeout=5)
str_content = str(b_content.decode(encoding='utf-8')).strip()
# 判断是否包含OpenSSH字符,这里统一用大写比较
if "OPENSSH" in str_content.upper():
return {"IP": host, 'Status': 'up', "OSType": "Linux"}
else:
return {"IP": host, 'Status': 'up', "OSType": "Unknown"}
except (ConnectionRefusedError, TimeoutError) as err:
return {"IP": host, 'Status': 'up', "OSType": "Unknown"}
except Exception as err:
print("Error occurd in class ScanHost function _isLinux")
print("Error message: ", err) def _scanner(self, hosts, ports=None):
"""
探测某一主机是否存活或者探测给定网段内存活的主机
:param hosts: 可以是IP也可以是网段,例如 192.168.100.10、192.168.100.0/24
:param ports: 可以写端口也可以写端口范围,例如22、22-33
:return: [{'IP': '127.0.0.1', 'Status': 'up'}, {}, {}]
"""
data = []
try:
nm = nmap.PortScanner()
"""
-n 不显示主机名,不进行IP到主机名的反向解析
-sP 使用ICMP协议探测
-PE 显示哪些端口号开启
-sP -PE 使用IMCP和TCP来探测,结果不显示端口号
"""
nm.scan(hosts=hosts, ports=ports, arguments='-sP -PE ')
# 这里获取的只是返回的有效IP
hosts_list = nm.all_hosts() for host in hosts_list:
# 通过nmap实例获取主机的信息
# print(nm[host])
data.append({"IP": host, "Status": nm[host]["status"]["state"]})
return data
except Exception as err:
print("Error occurd in class ScanHost function _scanner")
print("Error message: ", err) def main():
sh = ScanHost()
print(sh.scan(hosts="172.16.48.0/24")) if __name__ == "__main__":
try:
main()
finally:
sys.exit()
判断是否是Linux主机的原理是这样的
由于Linux主机通常默认都会开启ssh服务而且默认端口是22,所以telnet上去会出现红色箭头指向的内容。
扩展内容,当有了这些Linux主机后就可以远程执行dmidecode命令来获取更相信的服务器硬件方面的信息。这个功能在我的博客中也有。
Python获取网络中的存活主机以及哪些主机是Linux的更多相关文章
- python获取网络时间和本地时间
今天我们来看一下如何用python获取网络时间和本地时间,直接上代码吧,代码中都有注释. python获取网络时间 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 ...
- 通过python基于netconf协议获取网络中网元的配置数据,助力企业网络控制自动化轻松实现!
摘要:在当今信息化时代,大多数企业都需要网络支撑企业的ICT运行,提升企业运行效率,针对企业网络中的网元设备(包括交换机,路由器,防火墙等),很多企业希望根据自身的业务特点定制网络管理,比如可以实现网 ...
- 【381】python 获取列表中重复元素的索引值
参考:获取python的list中含有重复值的index方法_python_脚本之家 核心思想:建立字典,遍历列表,把列表中每个元素和其索引添加到字典里面 cc = [1, 2, 3, 2, 4] f ...
- 如何用python获取文件中的某一行——python小技巧
很多人有的时候只需要获取文章中的固定的一行,那么我知道这一行,我需要怎么样去获取呢 可能会有人说读取这一行,如果这一行是已什么开头的就读出来, 其实还有一种办法,就是我知道文件的路径.知道我要取的行数 ...
- H5_0016:js获取网络中配置文件中的参数
//获取网络配置文件中的参数 $.get("https://cdn.com/share.json", function(e) { //console ...
- python获取数组中最多的元素
获取数组中数量最多的元素,也就是最频繁的那个元素,方法有很多,下面是3种最简单的: 用max函数 sample = [1,2,3,3,3,4,5,5] max(set(sample), key=sam ...
- python 方法无法在线程中使用(附python获取网络流量)
在python中,定义一个方法,直接调用可以,但是创建一个线程来调用就可能导致失败.这种现象多出现在使用com对象进行系统操作时,而且是以线程的形式调用. 异常提示如下:syntax error.WM ...
- 配置vmWare10(桥接模式),使得虚拟机成为网络中的一台独立的主机
受到启发的原文:https://www.cnblogs.com/liongis/p/3265458.html 第一步:配置虚拟网络 第二步:配置桥接(VMnet0) 第三步:给虚拟机配置桥接模式 第四 ...
- [python]获取网页中内容为汉字的字符串的判断
实际上是这样,将获取到网页中表单内容与汉字字符串作比较,即: a = request.POST['a'] if a == '博客园': print 'ok' else: print 'false' a ...
随机推荐
- JFree图表
************************************************************************************* 使用JFree生成统计图片, ...
- string_array.go
package app import ( "strings" ) type StringArray []string func (a *StringArray) Set(s ...
- BZOJ_2600_[Ioi2011]ricehub_二分答案
BZOJ_2600_[Ioi2011]ricehub_二分答案 Description 乡间有一条笔直而长的路称为“米道”.沿着这条米道上 R 块稻田,每块稻田的坐标均 为一个 1 到 L 之间(含 ...
- VUE+webpack+npm项目中的RSA加解密
一.安装jsencrypt npm i jsencrypt node_modules文件夹中出现jsencrypt 二.引入jsencrypt 在main.js中import: import JsEn ...
- 《Thinking in Android 9.0 系统开发源码钻研录》
最近打算把个人站点的博客文章同步到"博客园"! Thinking in Android -- "系统启动" [启动阶段] [相关文章] 状态 源码版本 init ...
- php多进程模型 开箱即用
仓库地址 https://github.com/xieyong1023/MultiProcess 安装 使用composer 将仓库加到你的项目composer.json的repositories下 ...
- 解决:git push error: failed to push some refs to
出现错误的原因是github中的README.md文件不在本地代码目录中. 也就是说我们需要先将远程代码库中的任何文件先pull到本地代码库中,才能push新的代码到github代码库中. 使用如下命 ...
- typeconfig.json配置说明
如果一个目录下存在一个tsconfig.json文件,那么它意味着这个目录是TypeScript项目的根目录. 不带任何输入文件的情况下调用tsc,编译器会从当前目录开始去查找tsconfig.jso ...
- Unity 用ml-agents机器学习造个游戏AI吧(1)(Windows环境配置)
前言:以前觉得机器学习要应用于游戏AI,还远得很. 最近看到一些资料后,突发兴致试着玩了玩Unity机器学习,才发觉机器学习占领游戏AI的可能性和趋势. Unity训练可爱柯基犬Puppo 机器学习训 ...
- JavaScript实现登录窗口的拖拽
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...