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

news2025/7/19 16:53:10

原文链接:信创系统资产清单采集脚本:主机名+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 地址,每行一个。此文件用于后续脚本读取目标设备列表。

img

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)。

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

img

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 文件,写入表头。

img

4.安装环境依赖

pdsyw@pdsyw-PC:~/Desktop$ sudo apt install sshpass -y

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

img

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 列表。

img

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 或数据库处理。

img

img

7、使用建议

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

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2355822.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot获取用户信息常见问题(密码屏蔽、驼峰命名和下划线命名的自动转换)

文章目录 一、不返回password字段二、返回的createTime和updateTime为空原因解决&#xff1a;开启驼峰命名和下划线命名的自动转换 设置返回的日期格式 一、不返回password字段 在字段上面添加JsonIgnore注解即可 JsonIgnore // 在把对象序列化成json字符串时&#xff0c;忽略…

Mac下安装Python3,并配置环境变量设置为默认

下载Python 访问Python官方网站 https://www.python.org/ 首先获得python3安装路径 执行命令&#xff1a; which python3 以我这台电脑为例&#xff0c;路径为&#xff1a;/Library/Frameworks/Python.framework/Versions/3.9/bin/python3 编辑 bash_profile 文件 然后用 vim 打…

Linux-04-用户管理命令

一、useradd添加新用户: 基本语法: useradd 用户名:添加新用户 useradd -g 组名 用户:添加新用户到某个组二、passwd设置用户密码: 基本语法: passwd 用户名:设置用户名密码 三、id查看用户是否存在: 基本语法: id 用户名 四、su切换用户: 基本语法: su 用户名称:切换用…

【进阶】--函数栈帧的创建和销毁详解

目录 一.函数栈帧的概念 二.理解函数栈帧能让我们解决什么问题 三.相关寄存器和汇编指令知识点补充 四.函数栈帧的创建和销毁 4.1.调用堆栈 4.2.函数栈帧的创建 4.3 函数栈帧的销毁 一.函数栈帧的概念 --在C语言中&#xff0c;函数栈帧是指在函数调用过程中&#xff0c;…

【一】 基本概念与应用领域【数字图像处理】

考纲 文章目录 1 概念2005甄题【名词解释】2008、2012甄题【名词解释】可考题【简答题】可考题【简答题】 2 应用领域【了解】2.1 伽马射线成像【核医学影像】☆2.2 X射线成像2.3 紫外波段成像2.4 可见光和红外波段成像2.5 微波波段成像2.6 无线电波段成像2.7 电子显微镜成像2…

NU1680低成本、无固件、高集成度无线充电电源接收器

无线充电 电子产品具有无线充电功能使用会更便利&#xff0c;介绍一款低成本、无固件、高集成度无线充电电源接收器NU1680 原理图和BOM可点绑定资源下载&#xff0c;LC部分电容建议X7R。 Load空载切满载测试 (CC Mode) – 尽量保证电子负载没有过冲 – 电子负载不要从0到满…

2025MathorCup数学应用挑战赛B题

目录 模型建立与求解 1.问题一的模型建立与求解 1.1 搬迁补偿模型设计 1.2 住户是否搬迁的应对策略与分析 1.3 定量讨论 2.问题二的模型建立与求解 2.1 搬迁方案模型的优化介绍 2.2 模型的评估 2.3 模型结果 3.问题三的模型建立与求解 3.1 拐点存在性分析模型的建立 3.2 模型的…

组件的基本知识

组件 组件的基本知识 组件概念组成步骤好处全局注册生命周期scoped原理 父子通信步骤子传父 概念 就是将要复用的标签&#xff0c;抽离放在一个独立的vue文件中&#xff0c;以供主vue文件使用 组成 三部分构成 template&#xff1a;HTML 结构 script: JS 逻辑 style: CSS 样…

Origin绘图操作:图中迷你图绘制

一、背景描述 Origin绘图时&#xff0c;局部数据变化较小&#xff0c;在整体图片中表现为局部曲线重叠在一起&#xff0c;图中y1和y2在x0-2时重叠在一起&#xff0c;需要将局部放大&#xff0c;绘制迷你图 二、实现方法 1.在左边工具栏选择放大镜&#xff0c;按住ctrl在图中…

数据升降级:医疗数据的“时空穿梭“系统工程(分析与架构篇)

一、核心挑战与量化分析 1. 版本演化困境的深度解析 (1) 格式断层的结构化危机 数据转换黑洞:某医疗信息平台(2021-2023)统计显示: 数据类型CDA R1→R2转换失败率R2→FHIR转换失败率关键失败点诊断记录28.4%19.7%ICD编码版本冲突(18.7%)用药记录15.2%12.3%剂量单位标准化…

【GESP】C++三级练习 luogu-B2089 数组逆序重存放

GESP三级练习&#xff0c;一维数组练习&#xff08;C三级大纲中5号知识点&#xff0c;一维数组&#xff09;&#xff0c;难度★☆☆☆☆。 题目题解详见&#xff1a;https://www.coderli.com/gesp-3-luogu-b2089/ 【GESP】C三级练习 luogu-B2089 数组逆序重存放 | OneCoderGE…

Copilot 上线深度推理智能体 Researcher

近日&#xff0c;微软推出两款首创的工作场景推理智能体&#xff1a;Researcher&#xff08;研究员&#xff09;和Analyst&#xff08;分析师&#xff09;。它们能以安全合规的方式访问您的工作数据&#xff08;包括邮件、会议、文件、聊天记录等&#xff09;及互联网信息&…

日常开发小Tips:后端返回带颜色的字段给前端

一般来说&#xff0c;展示给用户的字体格式&#xff0c;都是由前端控制&#xff0c;展现给用户&#xff1b; 但是当要表示某些字段的数据为异常数据&#xff0c;或者将一些关键信息以不同颜色的形式呈现给用户时&#xff0c;而前端又不好判断&#xff0c;那么就可以由后端来控…

如何在WordPress网站中设置双重验证,提升安全性

随着互联网的不断进步&#xff0c;网站的安全问题越来越受到重视。尤其对于WordPress这样常用的建站平台&#xff0c;安全性显得尤为重要。尽管WordPress自带一定的安全性&#xff0c;但仅依靠用户名和密码的登录方式仍然存在风险。因此&#xff0c;启用“双重验证”便成为了提…

Python 虚拟环境管理:venv 与 conda 的选择与配置

文章目录 前言一、虚拟环境的核心价值1.1 依赖冲突的典型场景1.2 隔离机制实现原理 二、venv 与 conda 的架构对比2.1 工具定位差异2.2 性能基准测试&#xff08;以创建环境 安装 numpy 为例&#xff09; 三、venv 的配置与最佳实践3.1 基础工作流3.2 多版本 Python 管理 四、…

8.Android(通过Manifest配置文件传递数据(meta-data))

配置文件 <?xml version"1.0" encoding"utf-8"?> <manifest xmlns:android"http://schemas.android.com/apk/res/android"xmlns:tools"http://schemas.android.com/tools"><applicationandroid:allowBackup"tr…

三网通电玩城平台系统结构与源码工程详解(二):Node.js 服务端核心逻辑实现

本篇文章将聚焦服务端游戏逻辑实现&#xff0c;以 Node.js Socket.io 作为主要通信与逻辑处理框架&#xff0c;展开用户登录验证、房间分配、子游戏调度与事件广播机制的剖析&#xff0c;并附上多个核心代码段。 一、服务端文件结构概览 /server/├── index.js …

02_java的运行机制以及JDKJREJVM基本介绍

1、运行机制 2、JDK&JRE&JVM JDK 基本介绍 &#xff08;1&#xff09; JDK 的全称(Java Development Kit Java开发工具包) JDK JRE java的开发工具 [ java, javac, javadoc, javap等 ] &#xff08;2&#xff09;JDK是提供给Java开发人员使用的&#xff0c;其…

[论文阅读]REPLUG: Retrieval-Augmented Black-Box Language Models

REPLUG: Retrieval-Augmented Black-Box Language Models REPLUG: Retrieval-Augmented Black-Box Language Models - ACL Anthology NAACL-HLT 2024 在这项工作中&#xff0c;我们介绍了RePlug&#xff08;Retrieve and Plug&#xff09;&#xff0c;这是一个新的检索增强型…

数图信息科技邀您共赴第二十五届中国零售业博览会

数图信息科技邀您共赴第二十五届中国零售业博览会 2025年5月8日至10日&#xff0c;数图信息科技将精彩亮相第二十五届中国零售业博览会&#xff08;CHINASHOP 2025&#xff09;&#xff0c;与行业伙伴共探零售数字化转型新机遇&#xff01; 数图展会新品抢先看 数图商品一…