批量抓取cisco设备配置脚本编写(expect/sed/awk/shell)
应同事需求自行编写了第一个脚本,中间遇到一些坑。
需求,要求抓取设备“show ip interface brief”信息和“show interface des”描述信息。并且要求VLAN与描述信息在一个文件中显示出来。其实抓取工作很简单,难点在于字符处理中遇到时很多坑,比如关键字"More“抓取之后会有类似于“^[[7m--More--^[[m^M”的多余字符,是因为系统版本原因产生的。要用sed将其处理为awk可以匹配的格式。
先上内容。
1,抓取“show ip interface brief”信息(show inter des命令直接替换)。
#!/usr/bin/expect
#set ip
set ipaddress [lindex $argv 0]
#set user
set name [lindex $argv 1]
#set passwd
set passwd [lindex $argv 2]
#set timeout
set timeout 2
#ssh process
spawn ssh $name@$ipaddress
#进行判断
expect {
"yes/no" { send "yes\r" }
"*assword:" { send "$passwd\r";exp_continue}
"*# " { send "show ip inter bri\r" }
while (1) {
expect {
"More--" { send " " }
"*#" { break }
}
}
expect eof
2,字符处理脚本
用户名密码文件的格式为:
ip1 user1 passwd1
ip2 user2 passwd2
脚本如下:
#!/bin/bash
p=`pwd`
for i in `awk '{print $1}' $p/passwd` #取文件中第一列IP
do
j=`grep $i $p/passwd | awk '{print $2}'`
k=`grep $i $p/passwd | awk '{print $3}'` #j,k分别为取到的用户名,密码
echo "正在抓取"$i"的信息"
expect $p/ssh-brief.exp $i $j $k | grep Vlan > $p/brief/$i-bri.log #将ip,j,k作为参数传给expect登录并取配置存入文件中
if [ $? -eq 0 ];then
echo $i"地址文件抓取成功,下一步抓取描述文件。"
else
echo $i"地址文件抓取失败,即将退出脚本"
exit
fi
expect $p/ssh-des.exp $i $j $k | grep Vlan > $p/des/$i-des.log
if [ $? -eq 0 ];then
echo $i"描述文件抓取成功成功"
else
echo $i"描述文件抓取失败,即将退出脚本"
exit
fi
echo "处理"$i"的地址文件"
sed -i 's/^.*Vlan/Vlan/g' $p/brief/$i-bri.log #由于系统不同的原因产生了^[[7m--More--^[[m^M等多余字符这里对多余的字符进行处理。
if [ $? -eq 0 ];then
echo $i"地址文件处理成功"
else
echo $i"地址文件处理失败,即将退出脚本"
exit
fi
echo "处理"$i"的描述文件"
sed -i 's/^.*Vlan/Vlan/g' $p/des/$i-des.log
if [ $? -eq 0 ];then
echo $i"描述文件处理成功"
else
echo $i"描述文件处理失败,即将退出脚本"
exit
fi
echo "生成"$i"文件"
awk '{if(NR==FNR){i++;a1[i]=$1;a2[i]=$2;a3[i]=$3}else{j++;b1[j]=$1;b2[j]=$2" "$3" "$4}}END{for(m=0;m<=i;m++)for(n=0;n<=j;n++){if(a1[m]==b1[n]){print a1[m],a2[m],a3[m],b2[n]}}}' $p/brief/$i-bri.log $p/des/$i-des.log > $p/log/$i.log #处理两个文件件合并为一个文件,以Vlan为标识对两个文件相同Vlan匹配后生成新文件
if [ $? -eq 0 ];then
sed -i "s/$(echo -e '\015')//g" $/log/$i.log #去除新生成文件中的^M字符。
if [ $? -eq 0 ];then
echo $i"---------------------------------------------------------------------成功"
else
echo "生成"$i"文件失败,即将退出。"
exit
fi
done
批量抓取cisco设备配置脚本编写(expect/sed/awk/shell)的更多相关文章
- Python3利用BeautifulSoup4批量抓取站点图片的代码
边学边写代码,记录下来.这段代码用于批量抓取主站下所有子网页中符合特定尺寸要求的的图片文件,支持中断. 原理很简单:使用BeautifulSoup4分析网页,获取网页<a/>和<im ...
- 使用HtmlAgilityPack批量抓取网页数据
原文:使用HtmlAgilityPack批量抓取网页数据 相关软件点击下载登录的处理.因为有些网页数据需要登陆后才能提取.这里要使用ieHTTPHeaders来提取登录时的提交信息.抓取网页 Htm ...
- Web自动化框架LazyUI使用手册(4)--控件抓取工具Elements Extractor详解(批量抓取)
概述 前面的一篇博文详细介绍了单个控件抓取的设计思路&逻辑以及使用方法,本文将详述批量控件抓取功能. 批量抓取:打开一个web页面,遍历页面上所有能被抓取的元素,获得每个元素的iframe.和 ...
- 如何上传Packages到PyPI并批量抓取
1.如何上传包到PyPI ? 更新中... 2.批量抓取simple网站第三方模块 https://pypi.python.org/simple/ 3. 第三方模块的安装和使用 python set ...
- python实现列表页数据的批量抓取练手练手的
python实现列表页数据的批量抓取,练手的,下回带分页的 #!/usr/bin/env python # coding=utf-8 import requests from bs4 import B ...
- Hibernate批量抓取
------------------siwuxie095 Hibernate 批量抓取 以客户和联系人为例(一对多) 1.批量抓取 同时查询多个对象的关联对象,是 Hibernate 抓取策略的一种 ...
- Hibernate学习---第十一节:Hibernate之数据抓取策略&批量抓取
1.hibernate 也可以通过标准的 SQL 进行查询 (1).将SQL查询写在 java 代码中 /** * 查询所有 */ @Test public void testQuery(){ // ...
- Hibernate的批量抓取
批量抓取理解:如果我们需要查找到客户的所有联系人的话,按照正常的思路,一般是首先查询所有的客户,得到返回的客户的List集合.然后遍历List集合,得到集合中的每一个客户,在取出客户中的联系人(客户表 ...
- day36 08-Hibernate抓取策略:批量抓取
package cn.itcast.test; import java.util.List; import org.hibernate.Hibernate; import org.hibernate. ...
随机推荐
- 数据分析与展示——NumPy库入门
这是我学习北京理工大学嵩天老师的<Python数据分析与展示>课程的笔记.嵩老师的课程重点突出.层次分明,在这里特别感谢嵩老师的精彩讲解. NumPy库入门 数据的维度 维度是一组数据的组 ...
- bug:翻页
本章主要分享下,个人测试经历中遇见过的翻页bug 一.列表翻页 1.bug1:去请求翻页page=0,从0页开始算.一般来说page=0 和 page=1的数据是一模一样,所以翻第2页时会发现和第1页 ...
- 分布式数据库TiDB的部署
转自:https://my.oschina.net/Kenyon/blog/908370 一.环境 CentOS Linux release 7.3.1611 (Core)172.26.11.91 ...
- 如何在 Apple TV 上使用描述文件
您可以使用 OS X 上的 Apple Configurator 在 Apple TV 上安装配置描述文件. 开始前,请在 Mac 上安装最新版本的 Apple Configurator(如果尚未安装 ...
- 用户 'IIS APPPOOL\Private' 登录失败。
用户 'IIS APPPOOL\Private' 登录失败. 说明: 执行当前 Web 请求期间,出现未经处理的异常.请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息. 异常详细 ...
- Ionic3 编程-应用启动进入引导页
新建引导页面 ionic g page welcome 导入组件 修改模版文件:welcome.html 修改样式文件:welcome.scss 安装相关插件: 数据库使用SQLite:ionic c ...
- 借助csv用PHP生成excel文件
当你将xml文件改为csv后缀会发现原先的表格结构都变成用逗号隔开的一行一行数据,就像这样 编号,姓名,年龄 001,王宇,28 002,刘三,20 由此看来,如果能将PHP数据输出为这样的格式,然后 ...
- java读写锁ReadWriteLock
package com.java.concurrent; import java.util.concurrent.locks.ReadWriteLock; import java.util.concu ...
- Node.js CVE-2017-1484复现(详细步骤)
0x00 前言 早上看Sec-news安全文摘的时候,发现腾讯安全应急响应中心发表了一篇文章,Node.js CVE-2017-14849 漏洞分析(https://security.tencent. ...
- ORACLE使用数据泵导入导出部分表
1.导出名字为A的表(这里会导出SEQUENCES及FUNCTION等内容) expdp TEST/TEST@orcl schemas=TEST dumpfile=TEST.dmp DIRECTORY ...