自动化运维软件设计实战是面向从事系统运维人员而是开发的一本图书,书中的内容以思想分享居多,通过分享引起读者与笔者在思想上的碰撞,在碰撞上让读者发现一些其他的方法。全书共12章,第1章与读者一起探讨什么是自动化运维,第2章到第4章简单介绍目前比较热门的集中化运维软件ansible、puppet和saltstack。第5章介绍为什么有这么多运维软件的情况下我们还需要重复造一个轮子。第6、7章介绍重复制作轮子所需要的一些技术apache karaf和apache activeMQ,更多的介绍可自行下载自动化运维软件设计实战pdf文档。
内容介绍
《自动化运维软件设计实战》主要讲解采用OSGi技术来设计一款可插拔式的运维软件的方法与思想,为读者提供一种不一样的运维软件设计与自动化运维解决方案。本书分三部分,第一部分讲解开源社区中比较流行的三款集中化运维软件,第二部分与读者一起分享为什么要采用OSGi的技术来设计集中化运维软件,第三部分介绍设计这款运维软件所涉及的技术和一些设计思想。
自动化运维软件设计实战章节目录
第1章 什么是自动化运维 / 1
1.1 硬件运维和软件运维 / 1
1.1.1 小故事之一――电脑专家 / 1
1.1.2 小故事之二――你居然不会修电脑 / 2
1.1.3 硬件运维与软件运维 / 2
1.2 软件运维的主要问题 / 3
1.2.1 设备数量多 / 3
1.2.2 系统异构性大 / 3
1.2.3 虚拟化的成熟带来更大的困难 / 4
1.3 运维常用工具 / 4
1.3.1 Puppet / 6
1.3.2 SaltStack / 6
1.3.3 Ansible / 7
1.4 自动化运维 / 7
1.5 小结 / 9
第2章 集中化运维利器――Ansible / 11
2.1 环境准备 / 11
2.2 安装Ansible / 12
2.2.1 使用CentOS的EPEL源进行安装 / 12
2.2.2 使用Easy_Install安装Ansible / 14
2.3 Ansible基础 / 14
2.3.1 资产配置 / 14
2.3.2 执行命令 / 17
2.3.3 指定目标主机 / 18
2.3.4 常用命令示例 / 19
2.4 Ansible常用模块 / 21
2.4.1 文件管理模块 / 21
2.4.2 命令执行模块 / 25
2.4.3 网络相关模块 / 28
2.4.4 源码管理模块 / 30
2.4.5 包管理模块 / 32
2.4.6 系统管理模块 / 33
2.5 PlayBook / 37
2.5.1 PlayBook简介 / 38
2.5.2 Include语法 / 41
2.5.3 变量 / 41
2.5.4 条件 / 43
2.5.5 循环 / 44
2.5.6 PlayBook使用实例――集中化日常巡检 / 46
2.6 使用Ansible的API / 49
2.7 小结 / 50
2.7.1 Ansible的优点 / 50
2.7.2 Ansible的缺点 / 51
第3章 集中化运维利器――Puppet / 52
3.1 Puppet与Ansible / 52
3.2 Puppet基础 / 56
3.2.1 安装Puppet / 57
3.2.2 Puppet主要配置文件 / 58
3.2.3 颁发证书 / 61
3.2.4 第一个Puppet示例 / 62
3.3 Puppet的常用资源 / 64
3.3.1 定时任务――cron / 64
3.3.2 命令执行――exec / 65
3.3.3 文件管理――file / 67
3.3.4 包管理――packag / 69
3.3.5 服务管理――service / 70
3.4 Puppet语法基础 / 71
3.4.1 资源 / 72
3.4.2 类 / 73
3.4.3 变量 / 73
3.5 小结 / 76
3.5.1 Puppet的优点 / 76
3.5.2 Puppet的缺点 / 76
第4章 集中化运维利器――SaltStack / 77
4.1 SaltStack、Puppet、Ansible / 77
4.2 Agent模式――SaltSSH / 79
4.3 SaltStack的基本组成 / 81
4.4 Salt State概述 / 82
4.4.1 top.sls / 82
4.4.2 state文件 / 83
4.4.3 配置主机 / 83
4.4.4 SaltState之Requires / 84
4.4.5 Template、Extends、Includes / 85
4.5 主服务器模式运行 / 88
4.6 使用SaltStack的定时作业 / 89
4.7 实时执行命令 / 89
4.7.1 target / 89
4.7.2 function / 93
4.7.3 arguments / 93
4.8 Pillar / 93
4.8.1 使用Pillar / 94
4.8.2 Pillar的一些操作方法 / 95
4.9 小结 / 96
4.9.1 SaltStack的优点 / 96
4.9.2 SaltStack的缺点 / 96
第5章 重复造一个轮子 / 97
5.1 从一个自动化运维软件说起 / 97
5.2 困难重重 / 100
5.2.1 多样的设备类型 / 100
5.2.2 运维设备的总量大 / 100
5.2.3 艰难的环境 / 100
5.2.4 多变的客户需求 / 101
5.3 轮子需要的特性 / 102
5.4 ActiveMQ基础 / 104
5.4.1 配置ActiveMQ / 105
5.4.2 部署ActiveMQ / 114
5.4.3 第一个ActiveMQ例子 / 117
5.5 Apache Karaf / 123
5.5.1 OSGi简介 / 123
5.5.2 为什么选择Karaf / 124
5.5.3 基础架构设计 / 124
5.5.4 启动Apache Karaf / 126
5.5.5 制作第一个OSGi包 / 127
第6章 ActiveMQ概览 / 136
6.1 消息发送 / 136
6.1.1 TextMessage / 136
6.1.2 MapMessage / 138
6.1.3 BytesMessage / 140
6.1.4 StreamMessage / 144
6.1.5 BlobMessage / 145
6.2 断线重连机制FailOver / 158
6.2.1 配置FailOver / 158
6.2.2 FailOver的常用参数 / 159
6.3 消息生命周期 / 160
6.3.1 为什么消息需要生命周期 / 160
6.3.2 使用消息超时机制 / 162
6.4 清空不常用的队列 / 163
6.5 使用JMX获取队列信息 / 164
6.5.1 启用ActiveMQ的JMX功能 / 165
6.5.2 获取ActiveMQ的队列信息 / 167
6.6 ActiveMQ的HA方案 / 173
6.6.1 配置NFS服务器 / 173
6.6.2 配置NFS客户端 / 173
6.6.3 调整消息中间件的配置文件 / 174
6.6.4 将Failover作为连接串 / 174
6.6.5 原理 / 175
第7章 Apache Karaf概览 / 176
7.1 理解Import和Export / 176
7.2 Service Wraper / 180
7.2.1 支持的平台 / 180
7.2.2 使用Service Wrapper / 181
7.2.3 Karaf Wrapper的配置文件 / 184
7.3 使用控制台 / 187
7.3.1 Shell模块 / 187
7.3.2 OSGi模块 / 190
7.3.3 LOG模块 / 191
7.3.4 SSHD模块 / 192
7.4 Karaf的日志 / 194
7.4.1 Karaf.Out / 194
7.4.2 Karaf.log / 195
7.4.3 Application log4j 日志 / 196
7.5 Karaf子实例 / 197
7.5.1 使用Karaf子实例 / 197
7.5.2 为什么需要使用子实例 / 201
7.6 扩展Karaf控制台 / 203
7.6.1 使用Maven创建项目 / 204
7.6.2 编写控制台插件包 / 206
7.6.3 部署插件包 / 207
7.7 使用Web控制台 / 207
7.8 使用Feature――JDBC数据源 / 209
第8章 核心框架 / 213
8.1 核心层概述 / 213
8.2 核心框架 / 214
8.2.1 服务端消息处理 / 216
8.2.2 客户端消息处理 / 217
8.2.3 插件状态汇报 / 218
8.3 消息分发服务端 / 219
8.4 插件状态服务端 / 220
8.5 PlayBook服务端 / 221
8.5.1 PlayBook服务端设计目的 / 221
8.5.2 PlayBook设计示意图 / 223
8.6 结果处理服务端 / 226
8.6.1 结果处理服务端设计目的 / 226
8.6.2 结果处理服务端处理流程 / 226
第9章 通用插件包 / 228
9.1 插件包概览 / 228
9.2 作业调度模块――Cron4J / 230
9.2.1 Cron4J基本使用方式 / 231
9.2.2 作业调度参数 / 232
9.2.3 重新调度作业 / 233
9.2.4 调度系统进程 / 233
9.3 数据访问模块――MidaoProject / 234
9.3.1 为什么选择Midao / 235
9.3.2 使用Midao / 236
9.4 序列化模块――Gson / 237
9.5 交互式命令执行模块――JavaExpect / 242
9.6 小结 / 249
第10章 常用插件 / 250
10.1 文件下发插件 / 250
10.1.1 文件下发插件设计 / 250
10.1.2 使用Apache Common IO / 251
10.2 文件抓取插件 / 254
10.2.1 文件抓取插件整体设计 / 254
10.2.2 文件抓取插件设计要点 / 256
10.3 命令执行插件 / 257
10.4 目录结构查询插件 / 258
第11章 整合Zabbix / 261
11.1 编译安装Zabbix / 261
11.1.1 部署MySQL / 261
11.1.2 编译部署Apache+PHP / 263
11.1.3 安装Zabbix / 267
11.2 强大的触发规则 / 268
11.2.1 触发规则概览 / 268
11.2.2 特色的触发规则 / 270
11.3 Zabbix调用OSGi 运维功能 / 271
第12章 案例 / 275
发表评论
0条评论软件排行榜
热门推荐
- 有柿电脑版 v11.5.784.12M / 简体中文
- 网易新闻电脑版 v112.697.63M / 简体中文
- 数据挖掘导论 官方版61.61M / 简体中文
- 吉利博瑞用户手册 pdf高清版57.89M / 简体中文
- 开源阅读电脑版 v3.2517.96M / 简体中文
- 京东读书电脑版 v1.13.4官方版1.98M / 简体中文
- cnki全球学术快报电脑版 v0.2.3495.79M / 简体中文
- PHP语言精粹电子书 pdf扫描版25.72M / 简体中文
- linux常用命令大全 chm版1.48M / 简体中文
- 本草纲目 5.34M / 简体中文