ipmitool+python应用处理大量带外地址
ipmitool 是一种可用在 linux 系统下的命令行方式的 ipmi 平台管理工具,它支持 ipmi 1.5 规范(最新的规范为 ipmi 2.0),通过它可以实现获取传感器的信息、显示系统日志内容、网络远程开关机等功能
- 环境搭建
安装python:
在python官网下载安装文件,选择windows的安装包
安装过程可以直接加入path,也可以安装完后加上环境变量

安装ipmitool:
解压IPMItool.rar
加入环境变量中,如上图
在cmd查看python,ipmitool是否在path上:

2.代码
import os
for i in open(r'G:\My Documents\Desktop\ip.txt'):
odip=i.split("/")[0]
newip=i.split("/")[1]
gwip=i.split("/")[2]
USER=i.split("/")[3]
PASSWD=i.split("/")[4]
#os.system("ipmitool -I lanplus -H " + odip+" -U "+USER+" -P "+PASSWD+" lan set 3 netmask 255.255.254.0")
#os.system("ipmitool -I lanplus -H " + odip+" -U "+ USER+" -P "+PASSWD +" lan set 3 ipaddr "+ newip)
os.system("ipmitool -I lanplus -H " + newip+" -U"+ USER+" -P "+PASSWD +" lan set 3 defgw ipaddr "+ gwip)
#print(newip)
#print("ipmitool -I lanplus -H "+odip+" -U "+USER+" -P "+PASSWD+" lan set 1 netmask 255.255.254.0")
#print("ipmitool -I lanplus -H " + odip+" -U "+ USER+" -P "+PASSWD +" lan set 3 ipaddr "+ newip)
ip.txt文件形式:
odip1/newip1/gwip/PASSWD
odip2/newip2/gwip/PASSWD
......
4.成果截图:
设置掩码:

设置带外ip:
前一个执行是print(查看是否代码写的有误),后一个执行是修改带外ip

设置网关:

5.代码解析:
Python部分:
a.import导入模块
把import os导入模块放到开头,使作用域在全局中可以使用
b.Os模块: os模块就是对操作系统进行操作, 显示结果,os模块包含普遍的操作系统功能,与具体的平台无关
os.system():运行命令
>>>os.system('cmd') #Windows下打开终端
c.split()函数:Python中有split()函数
拆分字符串。通过指定分隔符对字符串进行切片,并返回分割后的字符串列表(list)
语法:str.split(str="",num=string.count(str))[n]
参数说明:
str:表示为分隔符,默认为空格,但是不能为空('')。若字符串中没有分隔符,则把整个字符串作为列表的一个元素
num:表示分割次数。如果存在参数num,则仅分隔成 num+1 个子字符串,并且每一个子字符串可以赋给新的变量
[n]:表示选取第n个分片
Ipmitool部分:
ipmitool远程使用命令:
pmitool -H 192.168.180.201 -U root -P opendoor -I lan command 其中-H表示后面跟的是服务器的地址,-U表示后面跟着用户名,-P表示后面跟着用户密码,command与本地获取信息相同
-l lan:
不同厂商的设备对于信道不同,版本不同
Lan或lanplus,本地及用open
ipmitool命令需要通过相应的interface来访问BMC,在本地获取信息时候采用的是-I open,即为OpenIPMI接口,IPMItool命令包含的接口有open、lan、lanplus。其中open是指的是OpenIPMI与BMC通信,lan是通过Ethernet LAN request/resoponse消息,消息具有一个IPMI session头和RMCP头。采用IPV4的udp协议与BMC通信。UDP的数据段包含了IPMI 。IPMI使用Remote Management Control Protocol (RMCP) 版本1支持操作系统关闭(pre-OS和OS-absent),RMCP把把数据发送到UDP的623端口。像lan接口一样,lanplus同样使用Ethernet LAN的UDP协议与BMC通信,但是lanplus使用rmcp+协议(在IPMIV2.0中描述)来通信,RMCP+允许使用改经的认证方式和数据完整性检查。
Open端口用于本地监控系统使用的,lan/lanplus通过网络进行远程监控。
IP网络设置:
说明:[ChannelNo] 字段是可选的,不同厂商设备不同,可能为1或3
设置网络参数,必须首先设置IP为静态,然后再进行其他设置;
a. 查看网络信息:
ipmitool -H (BMC的管理IP地址) -I lanplus -U (BMC登录用户名) -P (BMC 登录用户名的密码) lan print [ChannelNo]
b. 修改IP为静态还是DHCP模式:
ipmitool -H (BMC的管理IP地址) -I lanplus -U (BMC登录用户名) -P (BMC 登录用户名的密码) lan set <ChannelNo> ipsrc <static/dhcp>
c. 修改IP地址:
ipmitool -H (BMC的管理IP地址) -I lanplus -U (BMC登录用户名) -P (BMC 登录用户名的密码) lan set <ChannelNo> ipaddr <IPAddress>
d. 修改子网掩码:
ipmitool -H (BMC的管理IP地址) -I lanplus -U (BMC登录用户名) -P (BMC 登录用户名的密码) lan set <ChannelNo> netmask <NetMask>
e. 修改默认网关:
ipmitool -H (BMC的管理IP地址) -I lanplus -U (BMC登录用户名) -P (BMC 登录用户名的密码) lan set <ChannelNo> defgw ipaddr <默认网关>
###注意
脚本执行时,可以用print打出要执行的ipmitool命令,确认windows环境下无中文及命令正确。期间可以用#来注释
该代码通过split截取ip.txt的旧带外地址odip,新地址newip等
如果执行过程很快,可以使用import time
在for循环外围使用time.sleep(10000)来看结果

import os
import time
for i in open(r'c:\Users\Desktop\ip.txt'):
ip=i.split("/")[1]
newip=i.split("/")[2]
print(ip)
print(newip)
#print("echo " + ip + " >> C:\\Users\\Desktop\\sn.txt")
#os.system("echo " + ip + " >> C:\\Users\\Desktop\\sn.txt")
#hp惠普服务器
#print("ipmitool -I lanplus -H " + ip+" -U admin -P adminpasswd lan set 2 ipaddr "+ newip)
#os.system("ipmitool -I lanplus -H "+ ip + " -U admin -P adminpasswd fru | find \"Chassis Serial\" >> C:\\Users\\ffcs\\Desktop\\sn.txt")
#os.system("ipmitool -I lanplus -H "+ ip + " -U admin -P password fru | find \"Chassis Serial\" >> C:\\Users\\ffcs\\Desktop\\sn.txt")
#os.system("ipmitool -I lanplus -H " + ip+" -U admin -P adminpasswd lan set 2 netmask 255.255.254.0")
#os.system("ipmitool -I lanplus -H " + ip+" -U admin -P adminpasswd lan set 2 ipaddr "+ newip)
#os.system("ipmitool -I lanplus -H " + ip+" -U admin -P adminpasswd lan set 2 defgw ipaddr 10.241.40.1")
os.system("ipmitool -I lanplus -H "+ip+" -U admin -P adminpasswd mc reset cold")
#huawei服务器
#os.system("ipmitool -I lanplus -H "+ ip + " -U root -P Huawei12#$ fru | find \"Product Serial\" >> C:\\Users\\ffcs\\Desktop\\sn.txt")
#print("ipmitool -I lanplus -H " + ip+" -U root -P Huawei12#$ lan set 1 ipaddr "+ newip)
#os.system("ipmitool -I lanplus -H " + ip+" -U root -P Huawei12#$ lan set 1 netmask 255.255.254.0")
#os.system("ipmitool -I lanplus -H " + ip+" -U root -P Huawei12#$ lan set 1 ipaddr "+ newip)
time.sleep(100)
ipmitool+python应用处理大量带外地址的更多相关文章
- 服务器BMC(带外)
服务器除了装linux,windows系统外,相应还有一个可通过网线(服务器默认带外地址--可改)连接具体厂商服务器的BMC(Baseboard Management Controller,基板管理控 ...
- TCP带外数据
传输层协议使用带外数据(out-of-band,OOB)来发送一些重要的数据,如果通信一方有重要的数据需要通知对方时,协议能够将这些数据快速地发送到对方.为了发送这些数据,协议一般不使用与普通数据相同 ...
- python实现的、带GUI界面电影票房数据可视化程序
代码地址如下:http://www.demodashi.com/demo/14588.html 详细说明: Tushare是一个免费.开源的python财经数据接口包.主要实现对股票等金融数据从数据采 ...
- Python 实现的、带GUI界面的词云生成器
代码地址如下:http://www.demodashi.com/demo/14233.html 详细说明: "词云"就是数据可视化的一种形式,给出一段文本,根据文本中词语的出现频率 ...
- mysql 带外注入
带外通道 有时候注入发现并没有回显,也不能利用时间盲注,那么就可以利用带外通道,也就是利用其他协议或者渠道,如http请求.DNS解析.SMB服务等将数据带出. payload SELECT LOAD ...
- 利用DNS实现SQL注入带外查询(OOB)
根据用于数据检索的传输信道,SQLi可分为三个独立的类别:inference(经典SQL注入),inband(盲注.推理注入.带内注入)和out-of-band 一.什么是OOB out-of-ban ...
- Windows下用Python 3.4+自带的venv模块创建虚拟环境
Python 3.4+自带了venv模块,用于创建虚拟环境,每个虚拟环境都可以安装一套独立的第三方模块. 本文在Windows 10上操作. 1.创建一个虚拟环境: D:\>mkdir test ...
- 网络IPC:套接字之带外数据
带外数据(Out-of-band data)是一些通信协议所支持的可选特征,允许更高优先级的数据比普通数据优先传输.即使传输队列已经有数据,带外数据先行传输.TCP支持带外数据,但是UDP不支持.套接 ...
- UNIX网络编程——带外数据小结
TCP没有真正的带外数据,不过提供紧急模式和紧急指针.一旦发送端进入紧急模式,紧急指针就出现在发送到对端的分节中的TCP首部中.连接的对端收取该指针是在告知接收进程发送端已经进入紧急模式,而且该指针指 ...
随机推荐
- 可以获取JVM信息的一些管理工具类
一些可以获取JVM信息的java工具类 BufferPoolMXBean.class ClassLoadingMXBean.class CompilationMXBean.class GarbageC ...
- ICC Stage Flow
initial: reference library(mw), link library(db), create_mw_lib, read_verilog, link create_floorplan ...
- ASP.NET Core2.1 你不得不了解的GDPR(Cookie处理) - (转载)
前言 时间一晃 ASP.NET Core已经迭代到2.1版本了. 迫不及待的的下载了最新的版本,然后生成了一个模版项目来试试水. ...然后就碰到问题了... 我发现..cookie竟然存不进去了.. ...
- Struts2_learning
一.这是我学习struts2所做的一个记录,因为整个过程较为麻烦,所以,记录下来,以便以后使用 过程: 步骤: 1)dynamic web project 2)jars 3)struts.xml pa ...
- 20155218《网络对抗》MSF基础应用
20155218<网络对抗>MSF基础应用 实验过程 1.一个主动攻击实践,如ms08_067; 首先使用 search ms08_067查询一下该漏洞: show target 查看可以 ...
- 20155334 《网络攻防》 Exp6 信息搜集与漏洞扫描
20155334 Exp6 信息搜集与漏洞扫描 一.实验问题回答 哪些组织负责DNS,IP的管理? 答:互联网名称与数字地址分配机构 ICANN ,该机构决定了域名和IP地址的分配.负责协调管理DNS ...
- # RocEDU.课程设计2018 第三周进展 博客补交
RocEDU.课程设计2018 第三周进展 博客补交 本周计划完成的任务 (1).本周计划完成在平板电脑上实现程序的功能,跟第二周计划完成任务基本相似. 本周实际完成情况 (1).实际完成情况还差最后 ...
- linux下使用软连接之案例二
在笔者的上一篇文章介绍过怎么通过linux的软连接在不修改上传代码的情况下,将上传到项目路径下的图片改为上传到项目外面,防止重新部署后图片被删除了.同时还可以直接通过类似访问静态资源的方 ...
- mfc 基类与子类
基类(父类) 派生类(子类) 一.基类(父类) 基类(又称为父类,基类与派生类是相对的关系! 通过继承机制,可以利用已有的数据类型来定义新的数据类型.所定义的新的数据类型不仅拥有新定义的成员,而且还同 ...
- 为什么要进行阿里云云计算助理工程师认证(ACA)
阿里云助理工程师认证(ACA - Alibaba Cloud Certification Associate)是面向使用阿里云基础产品的专业技术认证,主要涉及阿里云的计算.存储.网络.安全类的核心产品 ...