新書推薦:
《
滚滚红尘(《滚滚红尘》电影原著)
》
售價:HK$
54.9
《
罗马之变(法语直译,再现罗马共和国走向罗马帝国的辉煌历史)
》
售價:HK$
109.8
《
自然之争:1600年以来苏格兰和英格兰北部地区的环境史(新史学译丛)
》
售價:HK$
106.4
《
硝烟下的博弈:工业革命与中西方战争
》
售價:HK$
87.4
《
让内的理性主义 发现无意识之旅
》
售價:HK$
66.1
《
苏美尔文明(方尖碑)
》
售價:HK$
132.2
《
知命不惧:从芝诺到马可·奥勒留的生活艺术
》
售價:HK$
110.9
《
Zemax光学设计从基础到实践
》
售價:HK$
132.2
|
編輯推薦: |
1)网络运维自动化资深专家撰写,8位专家联袂推荐,网络工程师转型必备指南
2)以场景与实践驱动,涵盖NetDevOps理念、常用工具、编程基础、网络运维常用Python模块与网络设备的数据处理等
|
內容簡介: |
网络运维自动化资深专家撰写,8位专家联袂推荐,网络工程师转型必备指南。以场景与实践驱动,涵盖NetDevOps理念、常用工具、编程基础、网络运维常用Python模块与网络设备的数据处理等,注重实用性与友好性,全书分为5篇,共计14章内容。
概念篇(第1~2章),阐述NetDevOps是什么、怎么做、技术框架,使读者能清晰了解NetDevOps能给他们带来什么,从何入手,如何开展NetDevOps工作。
基础篇(第3~6章),介绍如何构建NetDevOps的工作环境以及在这些环境中的常用工具,提高读者在日常维护的工作效率与准确度。
提高篇(第7~9章),讲解Linux环境编程、Python脚本编程、常用数据结构,学习开发一些在运维或者网络规划中能够使用的关键技能。
实践篇(第10~12章),采用案例的形式,带领读者掌握网络自动化运维、网络设计与规划中应对高频场景的技术与技巧,主要是网络数据的批处理,提高处理效率。
案例篇(第13~14章),通过3个典型案例来巩固提高NetDevOps相关知识和技能,更具体、更实用。
|
關於作者: |
余欣
思科中国资深系统工程师,近20年网络规划设计与运维经验,曾先后就职于瞻博网络、阿里巴巴、京东金融以及博科等公司。有丰富的互联网一线公司的实践经验。擅长大规模运营商级网络、大型园区网以及IDC网络的规划设计与实施。拥有CCIE、JNCIE等认证。
|
目錄:
|
目录 Contents
本书赞誉
前言
第一篇 概念篇
第1章 NetDevOps理念与要义2
1.1 从SDN开始说起2
1.1.1 OpenFlow打开了新的一扇窗3
1.1.2 简单聊聊SDN控制器4
1.1.3 NFV5
1.1.4 云和SDN6
1.1.5 SD-WAN8
1.2 NetDevOps,你需要知道的事8
1.2.1 什么是NetDevOps8
1.2.2 NetDevOps适用环境9
1.2.3 为什么我们需要NetDevOps10
1.2.4 NetDevOps需要什么样的人10
1.3 小结11
第2章 如何开始NetDevOps12
2.1 文档内容与版本管理12
2.1.1 版本管理的重要性13
2.1.2 需要管理哪些文档 13
2.1.3 如何实施版本管理14
2.1.4 版本管理的工具16
2.2 编程语言的选择17
2.2.1 程序语言的选择17
2.2.2 数据描述语言的选择18
2.3 自动化工具的选择22
2.3.1 Ansible22
2.3.2 Puppet23
2.3.3 Chef23
2.3.4 SaltStack24
2.3.5 如何选择24
2.4 网络设备的编程接口25
2.4.1 网络设备接口的分类25
2.4.2 网络设备编程接口的特征27
2.5 小结29
第二篇 基础篇
第3章 认识命令行工具32
3.1 用screen实现终端的会话管理33
3.1.1 安装screen34
3.1.2 screen基本语法34
3.1.3 screen基本操作35
3.1.4 定制你的screen36
3.1.5 用screen连接串口36
3.1.6 管理screen的日志38
3.1.7 多人共享一个会话38
3.2 用Telnet和SSH管理设备39
3.2.1 Telnet39
3.2.2 SSH介绍40
3.2.3 SSH的基本使用40
3.2.4 利用SSH远程执行命令42
3.2.5 SSH客户端常用配置44
3.2.6 使用密钥登录设备45
3.2.7 使用scp进行文件传输47
3.2.8 利用SSH 端口隧道转发功能48
3.2.9 利用SSH做Socket代理50
3.3 小结50
第4章 Linux下的一些常用工具52
4.1 SNMP53
4.1.1 SNMP简介53
4.1.2 常见设备的SNMP配置54
4.1.3 SNMP工具56
4.2 网络可达性检测工具58
4.2.1 Nmap59
4.2.2 Nping62
4.2.3 iPerf63
4.2.4 Fping64
4.3 MTR65
4.4 其他工具66
4.4.1 watch66
4.4.2 Wget68
4.4.3 CURL68
4.5 小结69
第5章 处理网络设备输出的文本70
5.1 正则表达式基础70
5.1.1 正则表达式到底是什么71
5.1.2 单字符的匹配71
5.1.3 多字符的匹配与次数匹配75
5.1.4 在网络设备上的正则表达式77
5.2 使用grep进行搜索与获取信息78
5.2.1 什么是grep78
5.2.2 命令选项的解释78
5.2.3 匹配控制80
5.2.4 输出结果控制81
5.2.5 输入控制83
5.3 使用awk进行文本处理84
5.3.1 认识一下awk84
5.3.2 awk的执行方式与语法84
5.3.3 截取部分信息85
5.3.4 使用内置变量86
5.3.5 对特定内容进行统计分析86
5.3.6 多文件操作88
5.4 使用sed 进行文本编辑89
5.4.1 什么是sed89
5.4.2 sed语法简介89
5.4.3 删除文件中的指定信息90
5.4.4 在文件中进行查找替换91
5.4.5 在文件中插入内容92
5.5 文本编辑工具vi和vim92
5.5.1 vi和vim简介92
5.5.2 vim编辑器的模式93
5.6 小结97
第6章 常用基础服务搭建99
6.1 Docker基础100
6.1.1 什么是Docker100
6.1.2 Docker的基本概念101
6.1.3 Docker的运行环境104
6.1.4 启动Docker镜像105
6.1.5 构建Docker镜像106
6.2 TFTP服务器110
6.2.1 定制一个TFTP服务镜像111
6.2.2 启动一个TFTP服务器的容器112
6.2.3 服务的检查112
6.3 DNS 服务器113
6.3.1 构建DNS镜像113
6.3.2 启动和配置DNS114
6.3.3 用DNS记录设备的接口与IP的对应关系115
6.4 搭建DHCP服务器118
6.4.1 构建DHCP镜像119
6.4.2 启动和配置DHCP服务120
6.5 小结121
第三篇 提高篇
第7章 Linux编程基础124
7.1 Bash编程基础124
7.2 第一个Bash程序125
7.3 变量126
7.4 数组128
7.4.1 定义数组128
7.4.2 数组取值129
7.4.3 获取数组的长度129
7.4.4 截取数组的内容130
7.4.5 替换元素中的内容130
7.4.6 删除数组中的元素或者数组130
7.5 运算符131
7.5.1 算术运算符131
7.5.2 位运算符132
7.5.3 自增自减运算136
7.6 测试136
7.6.1 测试语法的结构136
7.6.2 文件测试136
7.6.3 整数测试138
7.6.4 字符串测试138
7.6.5 逻辑关系139
7.7 判断结构140
7.7.1 if结构140
7.7.2 case结构141
7.8 循环结构141
7.8.1 for结构141
7.8.2 while结构143
7.8.3 until结构144
7.8.4 select结构144
7.9 函数145
7.10 用expect实现与设备的交互式操作147
7.10.1 expect简介147
7.10.2 用expect实现与设备的交互148
7.10.3 用expect实现批量备份设备配置150
7.11 网络设备上的Bash152
7.12 小结154
第8章 Python编程基础155
8.1 Python简介155
8.1.1 Python的版本差异155
8.1.2 主机与网络设备上的Python156
8.1.3 构建Python运行环境158
8.1.4 缩进在Python中的重要性161
8.2 基本数据类型161
8.2.1 数字162
8.2.2 列表163
8.2.3 元组166
8.2.4 字符串167
8.2.5 字典170
8.2.6 集合173
8.3 基本结构175
8.3.1 选择结构175
8.3.2 循环结构177
8.4 函数181
8.4.1 函数的定义181
8.4.2 函数的参数183
8.5 对象186
8.5.1 什么是对象186
8.5.2 对象的属性和方法186
8.5.3 创建对象187
8.5.4 对象的继承188
8.6 模块190
8.6.1 什么是模块190
8.6.2 如何使用模块190
8.7 小结191
第9章 常用数据类型与数据结构定义192
9.1 JSON192
9.1.1 JSON简介193
9.1.2 网络设备上的JSON194
9.1.3 JSON-RPC196
9.1.4 用Python处理JSON196
9.2 XML198
9.2.1 XML简介198
9.2.2 XML Schema200
9.2.3 NETCONF201
9.2.4 用Python处理XML202
9.3 YAML204
9.3.1 YAML简介205
9.3.2 YAML语法206
9.3.3 用Python处理YAML207
9.4 YANG208
9.4.1 YANG简介208
9.4.2 YANG语法211
9.4.3 OpenConfig214
9.4.4 Pyang工具214
9.5 小结216
第四篇 实践篇
第10章 网络设备的连接与登录218
10.1 命令行方式登录218
10.1.1 telnetlib219
10.1.2 paramiko221
10.1.3 netmiko224
10.1.4 pexpect227
10.2 通过NETCONF连接到网络设备231
10.2.1 安装ncclient231
10.2.2 获取配置信息231
10.2.3 获取接口信息233
10.3 REST235
10.3.1 测试REST接口236
10.3.2 安装requests模块237
10.3.3 使用HTTP get方法237
10.3.4 使用HTTP post方法238
10.4 小结239
第11章 命令行文本处理240
11.1 命令行文本输出240
11.1.1 关于TextFSM241
11.1.2 安装TextFSM241
11.1.3 TextFSM模板242
11.1.4 如何编写TextFSM模板243
11.1.5 在Python代码中使用TextFSM248
11.2 Cisco配置类型249
11.2.1 ciscoconfparse模块249
11.2.2 安装模块250
11.2.3 获取配置内容251
11.2.4 修改设备配置252
11.2.5 配置审计253
11.3 JUNOS配置类型254
11.3.1 层次化配置255
11.3.2 set命令行配置256
11.4 小结259
第12章 网络特有数据类型处理260
12.1 Jupyter260
12.1.1 安装Juypter260
12.1.2 启动Juypter261
12.1.3 使用Jupyter263
12.2 使用netaddr处理网络地址264
12.2.1 安装netaddr模块264
12.2.2 IP地址的基本属性264
12.2.3 处理IP地址的基本方法265
12.2.4 IP地址的加减法266
12.2.5 地址的聚合267
12.2.6 IPv6地址268
12.2.7 使用netaddr处理MAC地址268
12.3 使用ipaddr处理网络地址269
12.4 网络拓扑的处理271
12.4.1 描述一个网络拓扑271
12.4.2 最短路径的计算273
12.4.3 可用路径的计算276
12.5 小结278
第五篇 案例篇
第13章 网络设备的配置管理280
13.1 环境的准备280
13.1.1 测试拓扑说明280
13.1.2 Linux服务器的准备281
13.2 网络设备的配置获取282
13.2.1 登录网络设备282
13.2.2 处理多厂家问题287
13.2.3 处理并行问题290
13.3 网络设备的配置版本管理295
13.3.1 用git创建一个本地设备配置管理仓库296
13.3.2 保存设备配置文件到本地仓库296
13.3.3 使用git检查版本信息297
13.4 小结299
第14章 网络拓扑的处理与应用300
14.1 环境的准备300
14.1.1 测试拓扑说明300
14.1.2 Linux服务器的准备300
14.2 网络拓扑的获取与分析304
14.2.1 物理拓扑的获取304
14.2.2 ISIS协议拓扑的获取311
14.2.3 网络拓扑的路径分析313
14.3 网络流量工程应用314
14.3.1 基本信息315
14.3.2 路径计算316
14.3.3 BGP服务318
14.3.4 调用BGP HTTP API324
14.3.5 结果测试324
14.4 小结325
|
內容試閱:
|
前 言 Preface
为什么要写这本书
清晨,我们做的第一件事是什么?睁开眼。睁开眼看手机里的朋友圈是否有更新,昨晚下的单是否已经安排送货,今天的天气是否依旧晴朗。而这些信息的更新都是通过互联网传递到你的手机上。在很多人眼里,手机有电而没有网络是一件非常痛苦的事情。互联网在中国的发展也就是20来年的事,但它已经渗透到了我们工作、学习和生活的方方面面。网络是新时代的基础设施,无论上面有多么丰富多彩的应用软件,它们都离不开网络。这些年,应用软件的迭代速度非常快。而网络在这几十年中却没有发生多大的变化(虽然网络带宽一直在指数级增长)。特别是网络工程师们日常的工作似乎还是和10年前甚至20年前一样。虽然,这几年SDN(Software Defined Networks)在快速发展,但是物理网络仍然没有发生多大的变化。大量的网络工程师还是通过Telnet或SSH登录到网络设备上,然后一条一条地敲击各种各样的命令。应用软件越来越多,应用软件生命周期越来越短。这对网络提出了很多的挑战,网络工程师的工作压力也是直线上升。这几年随着上层应用DevOps思想的发展,网络自动化的需求也在不断提升。那些安分守己的传统网络工程师面临着转型的痛苦。
我是一个和网络打交道20来年的传统网络工程师,但我一直是一个不安分守己且会偷懒的人。早在我大学期间,为了和同寝室的同学一起玩一款叫红色警戒的游戏而接触了网络。从两台电脑之间使用串口互联进行对战,到使用同轴电缆后8个同学可以在一个地图中互相厮杀,再到1999年通过双绞线接入互联网。那个时候,几个寝室的双绞线都汇聚到了我们寝室,我不知不觉也成了96级化学系的网络管理员。日常的工作就是帮同学看看网络怎么不通了;谁的IP地址又和谁冲突了;如何从其他同学的电脑里复制一些电脑游戏等。活脱脱就是一个小型网吧的工作人员。随着1999年学校寝室接入了互联网,出于对工作的热情,我开始用Linux自己搭建一些服务,比如DHCP、DNS、FTP、BBS等。慢慢又干起了系统管理员的工作。
在千禧年(2000年)的毕业季,我的第一份工作是在一家大型的纺织公司做系统管理员和DBA。这份工作和化学没有任何的关系。而日常的工作就是帮助新员工开账号,每天备份那些数据库的数据到磁带中。为了减少自己日常的工作就开始写一些自动化的脚本。其实,当时就是为了每天能偷点懒。开一个账号,懒得去点那么多次的鼠标。每天的备份任务,懒得去一个个地核对和比较,而是让脚本自己去核对,自己去比较,然后把检查后的结果发送E-mail给我。
2003年考完CCIE后到一家为中国电信服务的系统集成公司。在这家公司有幸参与了中国电信CN2(ChinaNet2)的建设工作。在网络建设的初期有大量的设备配置需要增加和修改。纯手工的操作让我觉得痛苦不堪,此时又萌生了偷懒的思想。我开始用Python、Perl等语言写了一些脚本用于设备配置的生成和修改。当时设备并没有丰富的API接口,大部分都是用Telnet模拟登录来操作设备。
2007年我进入了Juniper工作,在这里接触了更多的网络自动化的内容,也写了很多自动化脚本来操作网络设备。比如,2008年考完JNCIE后,有幸做了一年多的中国区JNCIE考官。JNCIE的考官除了要发卷子外,还需要负责给考生判卷。也是为了偷点懒写了一些自己用的脚本提高判卷的效率。2009年开始学习JUNOScript(一种可以运行在JUNOS上的脚本语言),用JUNOScript来实现一些特殊的功能或者对命令进行重新格式化的输出。2010年后由于需要经常参加设备的测试,开始使用Python等语言对JUNOS设备基于NETCONF协议进行操作。
2014年到2016年,我先后在两家互联网公司做网络工程师,负责网络的规划与运维工作。由于互联网公司自身的产品迭代速度很快,对网络的适配性也提出了更多的需求。虽然在互联网公司有很多的程序员,但大部分的程序员对网络和网络设备的理解远逊于网络工程师。这就导致了网络自动化的开发工作比较难推进。因此,我结合自己的编程能力和对网络的理解开始用代码去实现网络自动化的任务。
从2016年到现在,我一直在Cisco工作。在这里我接触到了DevNet(https:developer.cisco.com)。在DevNet的网站上我看到和学习了很多关于基础网络设备的编程知识。在2016年,Cisco发布了思科全数字化网络架构(思科DNA),这个平台不仅提供了实现全数字化的路线图,而且为网络工程师提供了网络自动化和网络安全的途径。这个平台的很多理念和架构为我写这本书提供了很多的帮助。
在这20来年的时间里,我积累了一些使用程序来操作网络设备的经验。一方面是想把这些经验分享给大家;另一方面也是想帮助那些想转型的传统网络工程师。这就是我写这本书的初衷。另外,我还想告诉广大的网络工程师们开发一个小工具用来管理设备其实并没有那么难。对于我这样一个非软件专业的人而言并没有觉得吃力,反而在开发中获得了更多的自信,也偷了懒。
最后,希望这本书能给广大的网络工程师在转型过程中带来一些帮助,也希望大家能少走弯路。
本书特色
首先,本书是专门针对网络工程师而写的。书中关于Bash和Python的基本语法部分使用了网络工程师更加熟悉的内容,并且提供了一些网络设备上的运行情况。
其次,本书的重点是如何编写和网络设备相关的代码。因此,在书中提供了很多关于如何处理网络设备输出的文本的例子,以及处理网络相关的数据。
最后,本书并不是一本纯粹讲解编程的书,而是一本从理论到实践的综合书籍。
读者对象
网络架构师
网络运维工程师
网络运维开发人员
网络与系统管理人员
网络规划与设计人员
网络专业在校学生
如何阅读本书
本书分为五篇,共计14章内容。
第一篇为概念篇,这一篇主要讲述什么是NetDevOps,以及如何开始NetDevOps实践之路,包括如下2章内容。
第1章 从SDN开始谈起,讲解在SDN的大背景下,传统的网络都发生了什么变化,而这些变化给传统网络工程师带来了哪些影响。最后介绍了什么是NetDevOps,NetDevOps需要我们学习什么样的技能才能胜任。
第2章 在业务快速迭代的推动下,传统IP网络的自动化需求在不断增强。大量的网络工程师面临着新的挑战。这章介绍如何从零开始逐步过渡到NetDevOps。这章将重点讲解4个话题:首先,在NetDevOps开始之前需要做什么;其次,在进行NetDevOps开发时,如何选择开发语言;再次,一些常见的NetDevOps开源工具或平台如何选择;最后,在进行NetDevOps时,对网络设备有哪些要求。
第二篇为基础篇,这一篇主要介绍了如何构建NetDevOps的工作环境以及在这些环境中的常用工具,包括如下4章内容。
第3章 介绍在Linux环境下,如何使用Linux下的工具登录网络设备,以及使用SSH工具建立一些SSH的隧道。
第4章 介绍在Linux环境下,如何使用一些工具获取网络设备的信息,以及获取网络的可达信息,涵盖SNMP、traceroute、ping等工具。
第5章 使用Linux中三大文本处理利器(grep、awk和sed)来处理网络设备输出的文本内容。这些文本内容包括命令行的输出、设备的配置以及设备的日志信息等。这些工具可以帮助网络工程师快速地获取相关的数据和信息。
第6章 在NetDevOps的实践过程中,我们需要搭建一些基础的服务。这些服务包括TFTP、DNS和DHCP等。在微模块流行的时代,网络工程师使用Docker可以快速地构建起这些基础服务。
第三篇为提高篇,这一篇将开始介绍编程相关的内容。这一篇都是编程的一些基础知识,包括如下3章内容。
第7章 这一章主要介绍Linux环境或网络设备上的Bash编程基础知识。通过Bash基本语法并结合一些工具,我们可以和设备进行简单的交互或处理一些数据。
第8章 这一章主要介绍Python的编程知识。本书的大部分编程内容都是基于Python语言的。因此,这一章是后续章节的基础。这一章关于Python的基本语法是专门为网络工程师重新编写的。使用的例子将是网络工程师比较熟悉的内容。
第9章 我们在和网络设备进行交互或者进行网络相关的编程时,经常需要处理一些常用的数据类型,这些数据类型包括JSON、XML、YAML和YANG。熟练掌握这些数据类型的处理是编程的基础。在这章,我们将介绍上述这四种数据类型的常用处理方法。
第四篇为实践篇,这一篇将通过一些实际的例子来介绍,包括如下3章内容。
第10章 NetDevOps必然需要和网络设备进行交互,从而获得我们需要的数据。本章将介绍三种常见的连接网络设备的方法,它们分别是:命令行登录、NETCONF以及REST。
第11章 连接到网络设备后就可以获取很多的信息,其中通过命令行获取的数据大部分是半结构化的数据。这些半结构化的数据需要进行结构化处理。这一章将通过几个Python的模块来处理这些数据。
第12章 我们在处理网络相关数据时,有两种常见且特殊的数据需要处理,它们分别是网络地址和网络拓扑数据。同样,我们将通过几个Python的模块来处理这些数据。
第五部分为案例篇,这一篇将介绍3个常见的案例来帮助大家更好地了解和掌握NetDevOps的相关内容,包括如下两章内容。
第13章 众所周知,绝大多数的网络设备都会有配置文件,获取和管理这些配置文件是NetDevOps工作的基础。通过程序化的方式自动地获取这些配置就打通了程序和网络设备之间的通道,这是后续获取更多信息的基础。另外,网络设备的配置文件也是最需要且被优先管理的内容,这些内容的版本管理也是非常重要的。本章将通过网络设备的配置管理案例来描述如何多厂家、并发地与网络设备进行数据交互。
第14章 网络运维与管理的独特之处是,该工作是基于网络拓扑的。获取和处理网络拓扑是基本功能。该章通过两个小的案例来介绍,它们分别是:基于ISIS协议来获取网络拓扑并进行简单的网络拓扑分析;使用BGP协议进行简单的网络流量调度。
其中,本书的第2章、第8章、第9章、第10章、第11章是重点。如果你有一定的Python编程基础,那么可以参考第9章及之后的章节,这些章节提供了Python用于网络管理与维护常用的一些模块,这些模块可以提高你的工作效率。如果你是一位传统的网络工程师且对编程和Linux环境不是十分了解,请从本书的开头读起。笔者希望通过本书的内容能循序渐进地带领大家走上NetDevOps之路。
勘误和支持
由于笔者的水平有限,编写时间仓促,书中难免会出现一些错误或者不准确的地方,恳请读者批评指正。如果读者朋友有更多的宝贵意见,欢迎你发送邮件到netdevops@hotmail.com联系我。本书的大部分代码示例都放在GitHub上,其地址为https:github.comnetdevops-engineernewbie_book。期待能够得到大家的真挚反馈,在技术之路上互勉共进。
特别致谢
这里要特别感谢毛厚君先生,他是这本书的第一位读者,不但给了我很多的宝贵建议,而且帮我润色了全书的文字。如果没有他的帮助我想是很难完成这本书的。
致谢
在本书的写作过程中得到了很多同事和朋友的支持与帮助。没有你们的支持与帮助,本书将难以如期完成。
在本书的写作过程中需要实验环境,感谢徐晓东先生为我提供了便利。
感谢思科同事们的支持和鼓励,他们是方芳女士、徐志骏先生、杨骏先生、刘佳女士等。
感谢身在美国的朋友杨文嘉先生提供了关于Arista产品和技术的相关信息。
最后,我要特别感谢我的家人,我为写作这本书,牺牲了很多陪伴他们的时间,但也正因为有了他们的付出与支持,我才能坚持写下去。
谨以此书献给我最亲爱的人,以及众多的网络工程师朋友们!
余 欣
|
|