服务器IPMI用户名、密码批量检查

背景

大规模服务器部署的时候,少不了较多的网管和监测平台,这些平台会去监控服务器的性能、硬件等指标参数,为了便于管理和控制,则需要给服务器IPMI带外管理添加较多的用户,这就需要对较多的服务器检查所对应的IPMI用户和密码设置的准确性。又因不同厂商的不同型号的服务器较多给检查工作又带来了不小的困难,所以你可以通过下面的脚本来批量检查。

使用说明

脚本在Linux服务器上执行,前提是安装ipmitool工具,且安装驱动软件,能在系统下读到IPMI信息才可以执行。

user_Quantity代表检查的用户数量;

下面的用户id,则代表ipmi系统里的用户ID值,(用户ID信息可以使用ipmitool user list命令查看);

密码则是该ID要检查的密码;

检查输出

用户不存在输出

脚本信息

bash 复制代码
#!/bin/bash
#用户数量
user_Quantity=3
#检查的用户信息
user1_id=2
user1_Password="superAdmin@01"

user2_id=3
user2_Password="superAdmin@02"

user3_id=8
user3_Password="superAdmin@03"


#厂商与型号获取
Vendor_out=$(dmidecode -t 1 | grep -Ei "Manufacturer" |cut -d ":" -f 2)
Product=$(dmidecode -t 1 |grep "Product Name" |cut -d ":" -f 2)

#管理地址获取
bond0_net_01=`ls /etc/sysconfig/network-scripts/ifcfg-bond0.* | awk '{print $0}' |sed -n "1p"`
[ -e "$bond0_net_01" ] && bond0_ip=`cat $bond0_net_01  |grep IPADDR |tr -d '\r'|cut -d "=" -f 2`



vendor=$(dmidecode -t 1 | grep -Ei "Manufacturer")

if [[ $vendor == *H3C* ]];then
    BMC_IP=$(ipmitool lan print 8 | grep -E "IP\s+Address\s+:" | awk '{print $4}')
	
	#H3C服务器获取IPMI_ID用户名、密码检查信息
	for((i = 1; i <= $user_Quantity ;i++)); do
	eval userid="$"user${i}_id""
	eval user$i=`ipmitool user list 8 |grep ^${userid} |awk '{print $2}'`
	eval user_password="$"user${i}_Password""
	eval user${i}_passwd_check=`ipmitool user test $userid  16 $user_password` &> /dev/null
	eval user_passwd_check_next="$"user${i}_passwd_check""
	[ $user_passwd_check_next == "Success" ] &> /dev/null && eval user${i}_passwd_check_out="OK" || eval user${i}_passwd_check_out="Fail"
	done
elif [[ $vendor == *ZTE* ]];then
	BMC_IP=$(ipmitool lan print | grep -E "IP\s+Address\s+:" | awk '{print $4}')
	
	#ZTE服务器获取IPMI_ID用户名、密码检查信息
	for((i = 1; i <= $user_Quantity ;i++)); do
	eval userid="$"user${i}_id""
	eval user$i=`ipmitool user list 8 |grep ^${userid} |awk '{print $2}'`
	eval user_password="$"user${i}_Password""
	eval user${i}_passwd_check=`ipmitool user test $userid  16 $user_password` &> /dev/null
	eval user_passwd_check_next="$"user${i}_passwd_check""
	[ $user_passwd_check_next == "Success" ] &> /dev/null && eval user${i}_passwd_check_out="OK" || eval user${i}_passwd_check_out="Fail"
	done
	
elif [[ $vendor == *Suma* ]];then
	BMC_IP=$(ipmitool lan print | grep -E "IP\s+Address\s+:" | awk '{print $4}')
	
	#中科可控服务器获取IPMI_ID用户名、密码检查信息
	for((i = 1; i <= $user_Quantity ;i++)); do
	eval userid="$"user${i}_id""
	eval user$i=`ipmitool user list 8 |head -11 |grep ^${userid} |awk '{print $2}'`
	eval user_password="$"user${i}_Password""
	eval user${i}_passwd_check=`ipmitool user test $userid  16 $user_password` &> /dev/null
	eval user_passwd_check_next="$"user${i}_passwd_check""
	[ $user_passwd_check_next == "Success" ] &> /dev/null && eval user${i}_passwd_check_out="OK" || eval user${i}_passwd_check_out="Fail"
	done
	
else
    BMC_IP=$(ipmitool lan print | grep -E "IP\s+Address\s+:" | awk '{print $4}')
	
	#通用获取IPMI_ID用户名、密码检查信息
	for((i = 1; i <= $user_Quantity ;i++)); do
	eval userid="$"user${i}_id""
	eval user$i=`ipmitool user list |grep ^${userid} |awk '{print $2}'`
	eval user_password="$"user${i}_Password""
	eval user${i}_passwd_check=`ipmitool user test $userid  16 $user_password` &> /dev/null
	eval user_passwd_check_next="$"user${i}_passwd_check""
	[ $user_passwd_check_next == "Success" ] &> /dev/null && eval user${i}_passwd_check_out="OK" || eval user${i}_passwd_check_out="Fail"
	done
fi

#IPMI密码检查
	#通用获取IPMI_ID用户名、密码检查信息
for((i = 1; i <= $user_Quantity ;i++)); do
	eval user_id="$"user${i}_id""
	eval user_out="$"user${i}""
	[ $user_out == "true" ] && user_out="该用户ID用户无配置,请检查!"
	eval check_out="$"user${i}_passwd_check_out""
	echo -e "服务器管理网IP:$bond0_ip IPMI地址:$BMC_IP 厂商:$Vendor_out 型号:$Product IPMI用户ID:$user_id IPMI用户:$user_out 密码检查结果:$check_out"
done

干货分享(自取)

相关推荐
magic 24513 分钟前
第五章:Linux用户管理
linux·运维·服务器
小叶子来了啊19 分钟前
信息系统运行管理员:临阵磨枪版
运维·服务器·数据库
-天涯7628 分钟前
5.13/14 linux安装centos及一些操作命令随记
linux·运维·服务器
佩奇的技术笔记1 小时前
CentOS系统中升级Python 3.12.2版本
linux·运维·服务器
HackerKevn1 小时前
【项目】自主实现HTTP服务器:从Socket到CGI全流程解析
服务器·网络协议·http
北漂老男孩1 小时前
主流数据库运维故障排查卡片式速查表与视觉图谱
运维·数据库
云手机管家2 小时前
CDN加速对云手机延迟的影响
运维·服务器·网络·容器·智能手机·矩阵·自动化
zandy10112 小时前
如何快速入门-衡石科技分析平台
服务器·前端·科技·数据库管理员
云手机管家2 小时前
账号风控突破:云手机设备指纹篡改检测与反制技术解析
android·运维·网络协议·网络安全·智能手机·矩阵·自动化
孤的心了不冷2 小时前
【Docker】CentOS 8.2 安装Docker教程
linux·运维·docker·容器·eureka·centos