信创系统资产清单采集脚本:主机名+IP+MAC 一键生成 CSV

原文链接:信创系统资产清单采集脚本:主机名+IP+MAC 一键生成 CSV

Hello,大家好啊!今天给大家带来一篇在信创终端操作系统上自动批量采集主机名、IP 和 MAC 并导出为 CSV 表格的实战文章!本方案使用 sshpass 和 Bash 脚本配合,支持从外部 IP 列表和密码文件中读取内容,轻松实现批量自动采集,是信创设备台账登记、资产管理、批量部署前信息归档的利器!欢迎大家点赞、转发、点个在看!

场景介绍

日常运维工作中,尤其是在以下场景下常常需要批量采集主机信息:

信创设备批量上架后登记 IP、MAC、主机名

网络规划前快速收集节点信息

离线环境中准备资产台账

自动化部署前环境清查

如果一个个登录再 copy 太低效,这时候一套 "免登录 + 自动生成 CSV" 的脚本就很有必要!

1.准备设备IP列表

复制代码
pdsyw@pdsyw-PC:~/Desktop$ vim pdsyw_ip.txt
​
pdsyw@pdsyw-PC:~/Desktop$ cat pdsyw_ip.txt 
​
192.168.80.44

用 vim 创建并编辑了一个名为 pdsyw_ip.txt 的文件,内容是目标设备的 IP 地址,每行一个。此文件用于后续脚本读取目标设备列表。

2.准备对应密码

复制代码
pdsyw@pdsyw-PC:~/Desktop$ vim pdsyw_passwd.txt
​
pdsyw@pdsyw-PC:~/Desktop$ cat pdsyw_passwd.txt
​
1 

创建一个名为 pdsyw_passwd.txt 的文件,里面存放对应设备的登录密码。支持:

所有设备共用同一个密码(如每行内容都为 1)。

每台设备一个密码(一一对应 pdsyw_ip.txt 中的 IP)。

脚本通过索引一一读取对应的密码。

3.编写批量采集脚本

复制代码
pdsyw@pdsyw-PC:~/Desktop$ vim generate_host_list.sh
​
pdsyw@pdsyw-PC:~/Desktop$ cat generate_host_list.sh
​
#!/bin/bash
​
 
​
output="host_list.csv"
​
echo "主机名,IP地址,MAC地址" > "$output"
​
 
​
mapfile -t ip_list < pdsyw_ip.txt
​
mapfile -t pw_list < pdsyw_passwd.txt
​
 
​
if [ "${#ip_list[@]}" -ne "${#pw_list[@]}" ]; then
​
  echo "错误:IP 和密码数量不一致"
​
  exit 1
​
fi
​
 
​
for i in "${!ip_list[@]}"; do
​
  ip="${ip_list[$i]}"
​
  password="${pw_list[$i]}"
​
 
​
  echo "正在采集:$ip"
​
 
​
  sshpass -p "$password" ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no pdsyw@"$ip" '
​
    h=$(hostname)
​
    ipaddr=$(ip a | grep "inet " | grep -v "127.0.0.1" | awk "{print \$2}" | cut -d/ -f1 | head -n1)
​
    mac=$(ip link | awk "/ether/ {print \$2}" | head -n1)
​
    echo "$h,$ipaddr,$mac"
​
  ' >> "$output"
​
done
​
 
​
echo "所有采集完成,结果保存在 $output"

读取 IP 和密码,远程登录每台主机,采集主机名、IP、MAC 地址,并输出到 host_list.csv 文件中。关键步骤说明:

复制代码
mapfile -t ip_list < pdsyw_ip.txt
​
mapfile -t pw_list < pdsyw_passwd.txt

将 IP 列表和密码列表分别读入数组。

复制代码
if [ "${#ip_list[@]}" -ne "${#pw_list[@]}" ]; then
​
  echo "错误:IP 和密码数量不一致"
​
  exit 1
​
fi

校验 IP 与密码数量一致,防止数组越界。

复制代码
sshpass -p "$password" ssh -o ConnectTimeout=5 -o StrictHostKeyChecking=no pdsyw@"$ip" '
​
  h=$(hostname)
​
  ipaddr=$(ip a | grep "inet " | grep -v "127.0.0.1" | awk "{print \$2}" | cut -d/ -f1 | head -n1)
​
  mac=$(ip link | awk "/ether/ {print \$2}" | head -n1)
​
  echo "$h,$ipaddr,$mac"
​
' >> "$output"

利用 sshpass + ssh 无交互登录远程主机,提取主机名(hostname)、IP 地址、MAC 地址。其中用户pdsyw可以根据实际情况调整。awk "{print $2}" 使用 \ 转义是为了在嵌套脚本中正确传递。

复制代码
echo "主机名,IP地址,MAC地址" > "$output"

创建 CSV 文件,写入表头。

4.安装环境依赖

复制代码
pdsyw@pdsyw-PC:~/Desktop$ sudo apt install sshpass -y

sshpass 是一个支持非交互式 SSH 密码输入的工具。它允许你用密码方式批量远程登录(适用于没有设置 SSH 密钥登录的设备)。确保主控终端可 SSH 到目标设备。

5.执行效果预览

复制代码
pdsyw@pdsyw-PC:~/Desktop$ bash generate_host_list.sh
​
正在采集:192.168.80.44
​
Warning: Permanently added '192.168.80.44' (ECDSA) to the list of known hosts.
​
所有采集完成,结果保存在 host_list.csv

执行采集脚本,控制台实时输出当前采集的设备 IP。首次连接会自动将目标 IP 加入 known_hosts 列表。

6.输出文件

复制代码
pdsyw@pdsyw-PC:~/Desktop$ cat host_list.csv 
​
主机名,IP地址,MAC地址
​
pdsyw-PC,192.168.80.44,00:0c:29:cf:46:a3

采集完成后,输出的文件内容是一个标准的 CSV 格式,便于后续导入 Excel 或数据库处理。

7、使用建议

*应用场景* *建议操作*
台账登记 使用WPS 表格打开 .csv 直接导入系统平台
网段清查 一次性采集全网段设备,过滤活跃主机
离线备份 将采集脚本与 .csv 一并打包归档
自动部署前检查 结合设备名 / IP 反查对照配置表

通过这篇文章,你掌握了如何在信创终端环境中,使用脚本结合 SSH 免交互方式批量获取设备主机名、IP 地址和 MAC 地址,并输出为标准的 .csv 表格,极大提高了信息采集效率,也为后续批量运维打下良好基础。如果你觉得这篇文章实用,欢迎点赞、转发、收藏并点个在看,我们下次再见!

相关推荐
GanGuaGua31 分钟前
linux:进程的替换
linux·运维·服务器
梓䈑1 小时前
【Linux系统】详解Linux权限
linux·运维·bash
小茬粥1 小时前
kvm网卡发现的采集信息脚本COLT_CMDB_KVM_NETDISC.sh
linux·kvm
Mr_sun.2 小时前
Day23-Web开发——Linux
linux·运维·服务器
星雨流星天的笔记本2 小时前
1、Linux操作系统下,ubuntu22.04版本切换中英文界面
linux·学习
muxue1782 小时前
centos 7 网络配置(2):ping命令出现问题
linux·网络·centos
唐僧洗头爱飘柔95272 小时前
(云计算HCIP)HCIP全笔记(九)本篇介绍操作系统基础,内容包含:操作系统组成、分类和定义,Linux的特性结构和Linux版本分类
linux·笔记·华为云·云计算·hcip·openeuler·操作系统概述
电鱼智能的电小鱼3 小时前
EFISH-SBC-RK3588 —— 厘米级定位 × 旗舰算力 × 工业级可靠‌
linux·人工智能·嵌入式硬件·边缘计算
yuanlaile3 小时前
Go全栈_Golang、Gin实战、Gorm实战、Go_Socket、Redis、Elasticsearch、微服务、K8s、RabbitMQ全家桶
linux·redis·golang·k8s·rabbitmq·gin
程序员JerrySUN3 小时前
驱动开发硬核特训 · Day 22(上篇): 电源管理体系完整梳理:I2C、Regulator、PMIC与Power-Domain框架
linux·驱动开发·嵌入式硬件