赞
踩
公司项目License系统激活需要获取IP地址、LZ通过ssh服务连接宿主机执行shell脚本语言在docker容器中获取宿主机的MAC地址、磁盘序列号、CPU序列号与License绑定,达到定制化主机系统激活,中间如果报命令不存在的话,下载对应的命令即可,话不多说脚本写起
注意:LZ是在宿主机的环境编写脚本获取IP地址的,如果是docker环境内想获取宿主机的IP地址可以容器里面装ssh服务,通过ssh来执行宿主机脚本,或者在宿主机上写个http服务来执行脚本,容器通过暴露的端口来调用
①首先ifconfig命令看一下插网线的网卡:可以看到我的网线对应的网卡是em1,ip的内网段是1,且排在内网卡第一位(还有一个内网卡是em2),所以使用hostname -I命令获取IP地址时,再通过awk命令处理打印$1就好
②vim编辑一个脚本文件,脚本内容如下:。然后使用sh getIp.sh 命令或者直接./getIp.sh 跑一下脚本查看运行结果
hostname -I|awk '{print $1}'
注意:
sshpass -p 'yourConnectPassword' ssh -o StrictHostKeyChecking=no -p 22 root@yourIp hostname -I|awk '{print $1}'
vim编辑一个脚本macAddress.sh脚本文件,脚本内容如下:
ifconfig docker0 | grep "ether" | awk '{print $2}'
注意:
sshpass -p 'yourConnectPassword' ssh -o StrictHostKeyChecking=no -p 22 root@yourIp ifconfig docker0 | grep "ether" | awk '{print $2}'
vim编辑一个脚本cpuAddress.sh脚本文件,脚本内容如下:
dmidecode -t 4 | grep ID |sort -u |awk -F': ' '{print $2}'
注意:
sshpass -p 'yourConnectPassword' ssh -o StrictHostKeyChecking=no -p 22 root@yourIp dmidecode -t 4 | grep ID |sort -u |awk -F': ' '{print $2}'
vim编辑一个脚本identifier.sh脚本文件,脚本内容如下:
fdisk -l |grep "Disk identifier" |awk {'print $3'}
注意:
sshpass -p 'yourConnectPassword' ssh -o StrictHostKeyChecking=no -p 22 root@yourIp fdisk -l |grep "Disk identifier" |awk {'print $3'}
结束语:坚定的意志,温柔的心
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。