搜索
高级检索
高级搜索
书       名 :
著       者 :
出  版  社 :
I  S  B  N:
文献来源:
出版时间 :
Linux运维之道
0.00    
图书来源: 浙江图书馆(由图书馆配书)
  • 配送范围:
    全国(除港澳台地区)
  • ISBN:
    9787121218774
  • 作      者:
    丁明一编著
  • 出 版 社 :
    电子工业出版社
  • 出版日期:
    2014
收藏
编辑推荐

  《Linux运维之道》从运维工作的实际需求出发,全面讲解相关的技术、经典案例,以及常见问题的解决方案。
  @ 作者丁明一具有丰富的实践及教学经验,且非常认真,《Linux运维之道》是其呕心沥血之作,不仅内容精益求精,代码的编排作者也花了一些心思,可见其缜密。
  @ 《Linux运维之道》得到了多位业内专家的强烈推荐,包括红帽大中华区考官黄军宝、原红帽中国高级认证考官许成林,以及百度、新浪、达内、武汉誉天的运维工程师和培训讲师。
  @ 运维是一项需要多种技能的工作,Linux运维之道作者丁明一告诉您如何成为一名合格的运维工程师,能够直接提高运维人员的工作效率,值得阅读。


推荐购买:

《分布式服务框架原理与实践》

展开
作者简介

  丁明一,领航众达教育创始人,红帽认证高级讲师(RHCI),有着丰富的Linux系统运维以及讲师经验,培养学生两千余名。精通Linux系统管理、生产环境大规模集中部署Linux环境、建立Shell脚本自动化管理平台。主持部署多个LAMP网络服务平台、构建管理多个大型NginxWeb服务平台,项目实施中利用Cacti与Nagios监控平台实现自动故障报警。对企业集群环境及高性能、高可用构架有深入的研究。拥有丰富的虚拟化技术使用经验:Xen、KVM、VMware,利用虚拟化技术构建高效、绿色节能机房。对安全与调优有独特的理解,精通Linux防火墙、SELinux安全、系统性能调优化。翻译过多篇国外云计算解决方案文档,熟悉国外主流云计算技术发展。

展开
内容介绍

  随着开源技术的不断进步与创新,整个IT 行业中越来越多的企业愿意采用开源产品,而基于Linux的操作系统为这些开源产品提供了一个很好的操作平台。《Linux运维之道》将围绕Linux 操作系统这样一个基础平台,讲解如何使用操作系统实现各种开源产品的应用案例。全书主要从运维工作中的应用服务入手,全面讲解基本Linux 操作系统以及各种软件服务的运维工作。
  现在的商业环境是一个充满竞争的环境,很多企业的业务量在不断地增长,而对服务质量的要求也越来越高。特别是互联网企业为了满足客户更高的需求,提升用户使用体验。IT 部门维护的设备往往数以万计,如此庞大的设备维护量,通常会让IT 管理人员头疼不已。
  《Linux运维之道》介绍的自动化运维的内容可以让我们快速掌握大规模批量处理的简单方法。仅仅依靠自动化运维还不足以发挥出这些设备能效,因此,我们还需要将这个服务器设备有机地结合在一起,为客户提供更加安全、快捷、高效的服务,于是集群技术应运而生。《Linux运维之道》最后将围绕集群技术介绍目前比较流行的开源产品部署案例。

展开
精彩书评

  本书从基本的操作系统知识与实践到互联网应用,由浅入深,由表及里,层层推进;对作为开源技术中既基础又非常重要的Linux操作系统的各类操作和技巧作了详细的阐述;进而对各类常用服务如Apache、Nginx、MySQL等进行了深度的剖析;同时又考虑到系统及服务的安全。可见作者心思缜密,为本书费尽心血。拜读本书之后,受益非浅,其中许多小技巧在工作中非常有帮助,相信读者在阅读本书之后也能大受裨益。
  ——红帽大中华区考官黄军宝

  在技术发展十分迅速的领域,赶时髦的书多如牛毛,书店里充满了应景之作,但是,真正经过深入思考、用心、用技术写作的书不多。而本书却是一位技术高手的呕心沥血之作,书中的每项技术都介绍得很通透,并且反复经过思考和推敲。在本书即将出版之际,我向作者表示深深的敬意和祝贺,并向所有的Linux爱好者推荐这本学习Linux技术的好书。
  ——原红帽中国高级认证考官许成林

  作者以其多年的工作经验,总结归纳了一套适合于各种层次水平的Linux书籍。本书内容讲解深入浅出,配合大量的经典案例,通俗易懂,实用性非常强。尤其书中提供的常见问题分析,根据各种常见问题提供了不同的解决方案,这样可以帮助读者排除很多已知的常见故障。对于初级运维人员以及高级运维工作者,本书都相当高的具体技术实践指导意义。
  ——武汉誉天高级讲师邹圣林

  很多初学者,包括笔者的初学期都发现,在品类繁多的入门书籍中,很难找到一本由基础知识展开,深入浅出的覆盖到编程语言、集群架构等全面运维知识点的书籍。本书作者从实际运维工作出发,结合概念、知识,带领读者从实际操作深化到工作原理,让读者轻松上手,全面掌握理论,强化实际操作,非常值得一读。
  ——百度高级运维工程师刘宇

  运维方向上一直缺乏一本内容比较全面的书籍。这本书正是从入门到高级,内容覆盖了运维的方方面面,非常有实践指导价值,是运维和开发人员都可以深入阅读的一本好书。
  ——新浪运维架构师白贵兴

  这是一本难得的好书,内容全面涵盖了Linux入门基础、生产环境常用服务以及大规模业务部署。本书语言精炼、内容紧凑,非常适合作为Linux技术人员的枕边书。通过阅读本书内容您可以获得大量企业实践项目的实际动手能力。
  ——达内集团网络工程教研总监周华飞

展开
精彩书摘
  5.1.2 Cacti监控应用案例
  1.被监控端配置
  Cacti监控其他主机是通过简单的网络管理协议(SNMP)收集被监控端的数据信息的,因此,被监控端Web1与Web2服务器都需要安装net-snmp以及依赖包lm_sensors,并设置SNMP配置文件。lm_sensors软件可以帮助我们监控硬件信息(如CPU的工作电压等数据),具体步骤如下。
  安装snmp主程序及相关的依赖软件包,被监控主机仅需要修改snmp主配置文件即可(根据模板文件,本书对需要修改的地方用黑体字表示)。
  [root@web1 ~]# yum -y install net-snmp lm_sensors
  [root@web1 ~]# vim /etc/snmp/snmpd.conf

  # First, map the community name "public" into a "security name".
  com2sec notConfigUser default rose0011
  # Second, map the security name into a group name.
  group notConfigGroup v1 notConfigUser
  group notConfigGroup v2c notConfigUser
  # Third, create a view for us to let the group have rights to.
  view systemview included .1.3.6.1.2.1.1
  view systemview included .1.3.6.1.2.1.25.1.1
  # Finally, grant the group read-only access to the all view.
  access notConfigGroup "" any noauth exact all none none
  view all included .1 80
  syslocation Unknown (edit /etc/snmp/snmpd.conf)
  syscontact Root (configure /etc/snmp/snmp.local.conf)
  dontLogTCPWrappersConnects yes
  #备注,以上黑色加粗部分为需要修改的内容

  SNMP配置文件主要包括四部分内容需要修改。第一步,映射通信名称到安全用户名称;第二步,将用户加入到组中;第三步,为组创建systemvies视图;第四步,创建all视图并赋予组只读访问权限。主配置文件设置完成后重启服务,即可通过客户端访问该服务器获得系统信息,SNMP使用的端口号为UDP 161端口以及TCP 199端口,我们需要在防火墙规则中开放这些端口数据。
  [root@web1 ~]# iptables -I INPUT -p udp --dport 161 -j ACCEPT
  [root@web1 ~]# iptables -I INPUT -p tcp --dport 199 -j ACCEPT
  [root@web1 ~]# service iptables save
  [root@web1 ~]# service snmpd start
  [root@web1 ~]# chkconfig snmpd start

  Web1与Web2被监控主机均启动snmpd服务后,可以在Cacti主机上执行snmpwalk命令验证SNMPD服务是否运行正常,如果出现如下提示,则说明一切正常(命令输出仅为部分信息):
  [root@cacti ~]# snmpwalk -v 1 192.168.0.101 -c rose0011 system
  SNMPv2-MIB::sysORID.1 = OID: SNMP-MPD-MIB::snmpMPDMIBObjects.3.1.1
  SNMPv2-MIB::sysORID.2 = OID: SNMP-USER-BASED-SM-MIB::usmMIBCompliance
  SNMPv2-MIB::sysORID.3 = OID: SNMP-FRAMEWORK-MIB::snmpFrameworkMIBCompliance
  SNMPv2-MIB::sysORID.4 = OID: SNMPv2-MIB::snmpMIB
  SNMPv2-MIB::sysORID.5 = OID: TCP-MIB::tcpMIB
  SNMPv2-MIB::sysORID.6 = OID: IP-MIB::ip
  2.安装Cacti服务
  Cacti是基于PHP的Web监控管理系统,所以Cacti监控主机需要部署LAMP环境,此环境可以参考第4章的内容搭建。此外,还需要使用SNMP简单网络管理协议从被监控主机提取数据,然后使用RRDTool工具保存数据并最终生成图表信息。
  安装相关依赖包软件:
  [root@cacti ~]# yum -y install net-snmp net-snmp-devel net-snmp-utils\
  >net snmp-libs lm_sensors php-xml zlib libpng freetype cairo-devel\
  >pango-devel gd

  因为Cacti的优势在于其丰富的图表效果,为了将数据绘制成相应的更加直观的图表格式输出,就需要安装RRDTool工具,该软件的安装非常简单,使用configure、make、make install默认安装即可。
  [root@cacti ~]# wget http://oss.oetiker.ch/rrdtool/pub/rrdtool-1.4.7.tar.gz
  [root@cacti ~]# tar -xzf rrdtool-1.4.7.tar.gz -C /usr/src/
  [root@cacti ~]# cd /usr/src/rrdtool-1.4.7/
  [root@cacti ~]# ./configure --prefix=/usr/local/
  [root@cacti ~]# make && make install

  设置Apache虚拟主机:
  因为是基于Web的监控平台,而本书Web服务器采用的是Apache HTTP Server,因此,需要修改Apache主配置文件httpd.conf,通过DirectoryIndex index.php index.html指令设置默认首页为index.php,去除Include conf/extra/httpd-vhosts.conf指令前的“#”符号。Include指令将读取httpd-vhosts.conf文件的内容作为主配置文件的一部分,并在httpd-vhosts.conf文件中加入用来实现监控的虚拟主机。
  [root@cacti ~]# vim /usr/local/apache2/conf/extra/httpd-vhosts.conf
  
  ServerAdmin Jacob_rose@gmail.com
  DocumentRoot "/usr/local/apache2/htdocs/cacti"
  ServerName cacti.example.com
  

  修改PHP配置文件的时区设置,默认date.timezone为注释行,需要手动开启并设置时区,否则进行Cacti初始化时会提示It is not safe to rely on the system's timezone settings。
  本书将时区修改为上海,即编辑PHP配置文件/usr/local/php5/lib/php.ini,修改其中的时区参数date.timezone = "Asia/Shanghai"。
  部署Cacti监控系统,创建Web页面根路径monitor目录,解压Cacti包并移动至Web根路径下,因为Apache默认以daemon用户及组身份启动,所以需要使用chown命令修改目录权限以便Apache读取相关页面。
  [root@cacti ~]# wget http://www.cacti.net/downloads/cacti-0.8.8a.tar.gz
  [root@cacti ~]# tar -xzf /root/cacti-0.8.8a.tar.gz -C /usr/src/
  [root@cacti ~]# mv /usr/src/cacti-0.8.8a/ /usr/local/apache2/htdocs/cacti
  [root@cacti ~]# chown -r daemon.daemon /usr/local/apache2/htdocs/cacti
  [root@cacti ~]# iptables -I INPUT -p tcp --dport 80 -j ACCEPT
  [root@cacti ~]# service iptables save
  [root@cacti ~]# /usr/local/apache2/bin/apachectl restart

  创建初始化数据库,这里要确保MySQL服务器程序是开启的,通过Cacti软件包内提供的数据库备份文件,在本机生成名为cacti的数据库,创建cactiuser账户,并赋予其访问cacti数据库的所有权限,该账号密码为rose0011。
  [root@cacti ~]# /usr/local/mysql/bin/mysqladmin -u root -p create cacti
  [root@cacti ~]# cd /usr/local/apache2/htdocs /cacti
  [root@cacti cacti]# /usr/local/mysql/bin/mysql -u root -p cacti < cacti.sql
  [root@cacti cacti]# /usr/local/mysql/bin/mysql -u root -p
  mysql> GRANT ALL ON cacti.* TO cactiuser@localhost IDENTIFIED BY 'rose0011';
  mysql> flush privileges;
  mysql> exit

  设置Cacti配置文件,根据上一步数据库初始化操作所创建的数据库信息,修改Cacti配置文件中的数据库参数资料,需要修改的内容如下。
  [root@cacti ~]# /usr/local/apache2/htdocs/cacti/include/config.php

  $database_type = "mysql"; #数据库类型
  $database_default = "cacti"; #默认数据库名称
  $database_hostname = "localhost"; #数据库服务器主机名称
  $database_username = "cactiuser"; #数据库账户
  $database_password = "rose0011"; #数据库密码
  $url_path = "/"; #设置监控页面为Apache设置的页面根路径
  ……
展开
目录

第1篇 基础知识
第1章 部署操作系统
1.1 光盘安装Linux 操作系统
1.1.1 操作系统版本的选择
1.1.2 光盘安装Linux 系统案例
1.2 无人职守自动安装Linux 操作系统
1.2.1 大规模部署案例
1.2.2 PXE 简介
1.2.3 Kickstart 技术
1.2.4 配置安装服务器
1.2.5 自动化安装案例
1.3 常见问题分析
第2章 命令工具
2.1 基本命令
2.1.1 目录及文件的基本操作
2.1.2 查看文件内容
2.1.3 链接文件
2.1.4 压缩及解压
2.1.5 命令使用技巧
2.1.6 帮助
2.2 Vim 文档编辑
2.2.1 Vim 工作模式
2.2.2 Vim 光标操作
2.2.3 Vim 编辑文档
2.2.4 Vim 查找与替换
2.2.5 Vim 保存与退出
2.2.6 Vim 小技巧
2.3 账户与安全
2.3.1 账户及组的概念
2.3.2 创建账户及组
2.3.3 修改账户及组
2.3.4 删除账户及组
2.3.5 账户与组文件解析
2.3.6 文件及目录权限
2.3.7 账户管理案例
2.3.8 ACL 访问控制权限
2.4 存储管理
2.4.1 磁盘分区
2.4.2 格式化与挂载文件系统
2.4.3 LVM 逻辑卷概述
2.4.4 创建LVM 分区实例
2.4.5 修改LVM 分区容量
2.4.6 删除LVM 分区
2.4.7 RAID 磁盘阵列概述
2.4.8 RAID 级别
2.4.9 创建与管理软RAID 实例
2.4.10 RAID 性能测试
2.4.11 RAID 故障模拟
2.5 软件管理
2.5.1 Linux 常用软件包类型
2.5.2 RPM 软件包管理
2.5.3 使用YUM 安装软件包
2.5.4 YUM 使用技巧
2.5.5 源码编译安装软件
2.5.6 常见问题分析
2.5.7 服务管理
2.6 计划任务
2.6.1 at 一次性计划任务
2.6.2 cron 周期性计划任务
2.6.3 计划任务权限
2.7 性能监控
2.7.1 监控CPU 使用情况——uptime 命令
2.7.2 监控内存及交换分区使用情况——free 命令
2.7.3 监控磁盘使用情况——df 命令
2.7.4 监控网络使用情况——ifconfig 和netstat 命令
2.7.5 监控进程使用情况——ps 和top 命令
2.8 网络配置
2.8.1 命令行设置网络参数
2.8.2 文件修改网络参数
2.8.3 网络故障排错
2.9 内核模块
2.9.1 内核模块存放位置
2.9.2 查看已加载内核模块
2.9.3 加载与卸载内核模块
2.9.4 修改内核参数
第3章 自动化运维
3.1 Shell 简介
3.2 Bash 功能介绍
3.2.1 命令历史
3.2.2 命令别名
3.2.3 管道与重定向
3.2.4 快捷键
3.3 Bash 使用技巧
3.3.1 重定向技巧
3.3.2 命令序列使用技巧
3.3.3 作业控制技巧
3.3.4 花括号{}的使用技巧
3.4 变量
3.4.1 自定义变量
3.4.2 变量的使用范围
3.4.3 环境变量
3.4.4 位置变量
3.4.5 变量的展开替换
3.4.6 数组
3.4.7 算术运算与测试
3.5 Shell 引号
3.5.1 反斜线
3.5.2 单引号
3.5.3 双引号
3.5.4 反引号
3.6 正则表达式
3.6.1 基本正则表达式(Regular Expression)
3.6.2 扩展正则表达式(Extended Regular Expression)
3.6.3 POSIX 规范
3.6.4 GNU 规范
3.7 Sed
3.7.1 Sed 简介
3.7.2 Sed 基本语法格式
3.7.3 Sed 入门范例
3.7.4 Sed 指令与脚本
3.7.5 Sed 高级应用
3.8 Awk
3.8.1 Awk 简介
3.8.2 Awk 工作流程
3.8.3 Awk 基本语法格式
3.8.4 Awk 操作指令
3.8.5 Awk 高级应用
3.9 Shell 脚本
3.9.1 脚本格式范例
3.9.2 运行脚本的方式
3.9.3 Shell 脚本简单案例
3.9.4 判断语句应用
3.9.5 循环语句应用
3.9.6 控制语句应用
3.9.7 Shell 函数应用
3.9.8 综合案例
3.9.9 图形脚本

第2篇 网络服务
第4章 搭建网络服务
4.1 NFS 文件共享
4.1.1 NFS 服务器配置
4.1.2 客户端访问NFS 共享
4.1.3 NFS 高级设置
4.1.4 常见问题分析
4.2 Samba 文件共享
4.2.1 快速配置Samba 服务器
4.2.2 访问Samba 共享
4.2.3 配置文件详解
4.2.4 Samba 应用案例
4.2.5 常见问题分析
4.3 vsftpd 文件共享
4.3.1 FTP 工作模式
4.3.2 安装与管理vsftpd
4.3.3 配置文件解析
4.3.4 账户权限
4.3.5 vsftpd 应用案例
4.3.6 常见问题分析
4.4 ProFTPD 文件共享
4.4.1 安装ProFTPD 软件
4.4.2 配置文件解析
4.4.3 ProFTPD 权限设置
4.4.4 虚拟用户应用案例
4.4.5 常见问题分析
4.5 Subversion 版本控制
4.5.1 Subversion 简介
4.5.2 Subversion 服务器对比
4.5.3 安装Subversion 软件
4.5.4 svnserve 服务器搭建
4.5.5 svnserve+SSH 服务器搭建
4.5.6 Apache+SVN 服务器搭建
4.5.7 常见问题
4.6 网络存储服务器
4.6.1 iSCSI 网络存储
4.6.2 Rsync 文件同步
4.6.3 Rsync+Inotify 实现文件自动同步
4.7 DHCP 服务器
4.7.1 安装软件
4.7.2 配置文件解析
4.7.3 DHCP 应用案例
4.7.4 常见问题分析
4.8 DNS 域名服务器
4.8.1 DNS 简介
4.8.2 安装DNS 软件
4.8.3 配置文件解析
4.8.4 部署主域名服务器
4.8.5 部署从域名服务器
4.8.6 DNS 视图应用案例
4.8.7 常见问题分析
4.9 Apache 网站服务器
4.9.1 Apache 简介
4.9.2 安装Apache 软件
4.9.3 配置文件解析
4.9.4 虚拟主机应用案例
4.9.5 网站安全应用案例
4.9.6 常见问题分析
4.10 Nginx 网站服务器
4.10.1 Nginx 简介
4.10.2 安装Nginx 软件
4.10.3 配置文件解析
4.10.4 虚拟主机应用案例
4.10.5 SSL 网站应用案例
4.10.6 HTTP 响应状态码
4.11 数据库基础
4.11.1 MySQL 数据库简介
4.11.2 安装MySQL 软件
4.11.3 MySQL 管理工具
4.11.4 数据库定义语言
4.11.5 数据库操作语言
4.11.6 数据库查询语言
4.11.7 MySQL 与安全
4.11.8 MySQL 数据库备份与还原
4.12 动态网站架构案例
4.12.1 论坛系统应用案例
4.12.2 博客系统应用案例
第5章 系统监控
5.1 Cacti 监控系统
5.1.1 简介
5.1.2 Cacti 监控应用案例
5.2 Nagios 监控系统
5.2.1 简介
5.2.2 Nagios 监控应用案例
第6章 网络安全
6.1 iptables 防火墙
6.1.1 iptables 防火墙语法格式
6.1.2 iptables 防火墙应用案例
6.1.3 防火墙备份与还原
6.2 SELinux 简介
6.2.1 SELinux 配置文件
6.2.2 SELinux 软件包
6.2.3 SELinux 安全上下文
6.2.4 SELinux 排错
6.2.5 修改安全上下文
6.2.6 查看与修改布尔值
6.2.7 SELinux 应用案例
6.2.8 httpd 相关的SELinux 安全策略
6.2.9 FTP 相关的SELinux 安全策略
6.2.10 MySQL 相关的SELinux安全策略
6.2.11 NFS 相关的SELinux安全策略
6.2.12 Samba 相关的SELinux安全策略
6.3 OpenVPN
6.3.1 OpenVPN 简介
6.3.2 安装OpenVPN 服务
6.3.3 OpenVPN 客户端

第3篇 高级应用
第7章 虚拟化技术
7.1 虚拟化产品对比
7.1.1 VMware 虚拟化技术
7.1.2 Xen 虚拟化技术
7.1.3 KVM 虚拟化技术
7.2 KVM 虚拟化应用案例
7.2.1 安装KVM 组件
7.2.2 创建虚拟机操作系统
7.2.3 监控虚拟机操作系统
7.2.4 命令工具使用技巧
7.2.5 虚拟存储与虚拟网络
第8章 集群及高可用
8.1 集群
8.1.1 LVS 负载均衡简介
8.1.2 基于NAT 的LVS 负载均衡
8.1.3 基于TUN的LVS 负载均衡
8.1.4 基于DR 的LVS 负载均衡
8.1.5 LVS 负载均衡调度算法
8.1.6 部署LVS 服务
8.1.7 LVS 负载均衡应用案例
8.1.8 常见问题分析
8.2 Keepalived 双机热备
8.2.1 Keepalived 简介
8.2.2 VRRP 协议简介
8.2.3 安装Keepalived 服务
8.2.4 配置文件解析
8.2.5 Keepalived+LVS 应用案例
8.2.6 常见问题分析
8.3 Squid 代理服务器
8.3.1 Squid 简介
8.3.2 安装Squid 服务
8.3.3 常见代理服务器类型
8.3.4 配置文件解析
8.3.5 Squid 应用案例
8.4 HAProxy 负载均衡
8.4.1 HAProxy 简介
8.4.2 配置文件解析
8.4.3 HAProxy 应用案例
8.5 Nginx 高级应用
8.5.1 Nginx 负载均衡
8.5.2 Nginx 负载均衡案例
8.5.3 Nginx rewrite 规则
8.6 MySQL 高可用
8.6.1 MySQL 复制
8.6.2 一步一步操作MySQL复制

展开
加入书架成功!
收藏图书成功!
我知道了(3)
发表书评
读者登录

请选择您读者所在的图书馆

选择图书馆
浙江图书馆
点击获取验证码
登录
没有读者证?在线办证