之前曾经写过一篇如何学习Linux的文章,得到了很多反馈,大家都在分享自己的学习经验和体会,并且也提出了不少意见和建议。学习这个事情其实是说起来容易,做起来就很难,虽然给大家提高了很多学习linux的思路和方法,但是很多时候,学习的过程是个锻炼和总结的过程,需要自己去体会和领悟,而这个领悟跟钻研的深度有关,所以,对linux技术点钻研较深的朋友,可能收获的知识就多一些,提高也就快一些,而相反,不太喜欢钻研的朋友们,技能提高就稍微慢一点,因此,我们说虽然有了统一的学习方法,但是由于每个人的领悟力不同,学习的速度和掌握的技能也不尽相同。
学习的方式有很多种,有书本学习、视频学习、面授学习等,书本学习是传统的学习方法,需要有钻研和坚持精神,对领悟能力也有很高要求,因此学习时间成本相对较高;而面授弥补了书本学习的缺点,可以跟老师面对面交流,这是优势,但是由于面授需要专职学习,无论是时间成本还是费用成本都是最高的,如果是小班授课那还好一些,要是遇上群体几百人一起上课,那基本失去了面授的所有优势。最后说说视频学习方式,视频学习是介于书本学习和面授学习直接的一种学习方式,学习的时间成本和费用都属于可接受的范围,对于不懂的知识点可以反复学习,直到学会为止,如果加上课程作业的辅助,完全可以达到最优的学习效果。
考虑到不同学习方式在学习效率和速度方面的特点,也总结了自己的学习方法,我将这么多年对linux学习的经验和技巧等知识录制成了学习视频,并结合书本内容,做了一套《Linux运维工程师必备技能》课程,希望能通过视频学习和书本学习两者相集合的方式帮助那些想学习linux运维的朋友们在短时间能迅速提高运维技能。
本课程汇聚了我多年来在运维行业一线工作经验和培训心得,课程由浅入深,循序渐进,能够帮助零基础或刚毕业的同学以及初中级Linux运维人员们系统学习并迅速掌握Linux的运维实战技能。
全套视频分为入门基础篇、系统运维篇、Web运维篇、数据库运维篇、集群实战篇、运维监控篇总共六个篇幅,13个课程,145个课时,总时长3412分钟。
下面给出本套视频的内容大纲,遵循由浅入深、循序渐进的学习过程。
全套视频访问地址:http://edu.51cto.com/pack/view/id-805.html
第一篇:Linux入门(安装、配置、shell命令)基础篇
一、 学习Linux的经验与技巧
1.1 Linux在各领域发展的现状和趋势
1.1.1 Linux与开源软件(Linux成就了开源)
1.1.2 Linux在服务器领域的发展(市场占有率95%,2015年数据)
1.1.3 Linux在桌面领域的发展
1.1.4 Linux在移动嵌入式领域的发展(安卓的世界)
1.1.5 Linux在云计算/大数据领域的发展(清一色Linux)
1.1.6 Linux运维的现状和前途(Linux运维,有钱途的职业)
1.2 选择适合自己的Linux发行版(初学者重点,教你选择企业使用最多的Linux发行版)
1.2.1 常见的Linux发行版
1.2.2 初学者入门首选——Centos系列
1.2.3 桌面/开发平台首选——Ubuntu Linux
1.2.4 企业级应用首选——Red Hat/Centos系列
1.3 养成良好的Linux操作习惯(重点,经验技巧畅谈)
1.3.1 如何习惯命令行方式操作
1.3.2 如何做到理论结合实践
1.3.3 如何使用Linux联机帮助
1.3.4 如何学会独立思考问题,独立解决问题
1.3.5 Linux学习路线图(Linux学习指路灯)
1.4 用虚拟机virtualbox/vmware学习Linux(常见虚拟机的使用)
1.4.1 virtualbox/vmware的取舍
1.4.2 使用虚拟机技术的好处
1.4.3 virtualbox的运行环境和硬件需求
1.4.4 virtualbox/vmware的安装与使用
1.5 Linux学习资源(学会自我学习)
1、 网络资源、搜索引擎、论坛
2、 学习思路很重要
3、 掌握学习方法
二、 多种方式安装Linux系统
2.1 安装Linux的艺术
2.2 Linux的几种安装方式(教你多种Linux安装方式)
2.2.1 硬盘安装方式
2.2.2 U盘安装方式(首选)
2.2.3 网络安装方式(适用大规模安装)
2.2.4 光驱安装方式(适用初学者)
2.3 光驱安装Linux经验分享(干货)
2.3.1 Linux的分区命名方案
2.3.2 安装Linux过程精讲(重点,包含安装经验和各种技巧)
2.4 U盘安装过程(U盘系统制作方式)
三、 Linux系统基本结构
3.1 Linux下多个控制台的使用(多用户多控制台)
3.2 Linux下的系统与硬件(教你如何识别Linux下的硬件和使用硬件)
3.2.1 Linux硬件资源管理
3.2.2 Linux外在设备的使用
3.3 文件系统结构介绍(linux树形文件结构)
3.3.1 目录结构
3.3.2 系统核心组成
3.4 运行机制介绍(重点内容,会介绍Linux新旧版本之间的差异)
3.4.1 Linux初始化init系统
3.4.2 runlevel到target的改变
3.4.3系统关机过程
3.5系统服务管理工具systemd(重点,RHEL/Centos7.x版本之后新增)
3.5.1 通systemd启动、停止、重启服务方法
3.5.2 通过systemd查看、禁止、启用服务方法
3.5.3 systemd命令和sysvinit命令对比
3.6 Linux与SecureCRT/Xshell/putty(Linux下最常用的客户端连接工具)
3.6.1 SecureCRT概述
3.6.2 SecureCR的安装与使用
3.6.3 与SecureCRT相关的Linux命令
四、 Linux常用命令及使用技巧
4.1 shell命令的语法分析(必学内容,shell语法精讲)
4.1.1 什么是shell
4.1.2 shell通配符、重定向、管道、引用应用技巧
4.1.3 shell应用精讲与使用技巧(传参、比较操作、字符串操作、循环操作、算术操作)
4.2 系统管理与维护命令(Linux运维必学命令,并非枯燥命令讲解,重点是传授使用技巧)
4.2.1 显示目录下内容的万能命令ls
4.2.2 显示当前工作目录的命令pwd
4.2.3 改变当前工作目录的万能命令cd
4.2.4 显示或修改系统时间与日期的命令date
4.2.5 设置/锁定/解锁用户命令passwd
4.2.6 改变身份的命令su/sudo(用户权限管理)
4.2.7 显示指定命令的帮助信息的命令man
4.2.8 显示目前登录到系统的用户的命令who/w
4.2.9 显示操作系统相关信息的命令uname
4.2.10 输出系统任务队列信息的命令uptime
4.2.11 列出目前与过去登入系统的用户相关信息的命令last
4.2.12 显示开机信息系统故障信息的命令dmesg(排除问题很重要)
4.2.13 显示系统内存状态的命令free
4.2.14显示系统进程瞬间的运行动态的命令ps(最常用)
4.2.15实时监控系统处理器状态的命令top
4.3 文件管理与编辑命令(重点,Linux运维必学命令)
4.3.1 创建目录的命令mkdir(批量创建目录)
4.3.2 动态显示文件内容命令tail(很重要,经常用于查看日志)
4.3.3 显示文件内容命令cat/more
4.3.4 比较文件的差异的命令diff(线上运维经常使用)
4.3.5 过滤文本的命令grep(重要,经常使用)
4.3.6 删除某个目录及其所有文件及子目录的命令rm(慎用)
4.3.7 改变指定文件的访问时间和修改时间的命令touch
4.3.8 在文件或目录之间创建链接的命令ln(如何识别软/硬链接)
4.3.9 显示文件类型的命令file/stat
4.3.10 拷贝文件或目录的命令cp(直接复制不提示覆盖方法,线上运维cp使用技巧)
4.3.11 在指定的路径下查找指定文件的命令find
4.3.12 文件/目录改名或变更存储位置的命令mv/rename(批量改名)
4.4 压缩与解压命令(重点,Linux运维必学命令)
4.4.1 压缩/解压缩文件或者目录的命令zip/unzip
4.4.2 压缩/解压缩文件的命令gzip/gunzip
4.4.3 压缩/解压缩文件的命令bzip2/bunzip2
4.4.4 将文件或者目录打包归档的命令tar(压缩/解压/单独解压,重点中的重点)
4.4.5 转换或拷贝文件的命令dd
4.4.6 重定向方式打包备份、还原恢复文件的命令cpio
4.5 磁盘管理与维护命令(重点,Linux运维必学命令)
4.5.1 检查磁盘空间占用情况的命令df
4.5.2 显示文件或目录所占用的磁盘空间的命令du
4.5.3 检查文件系统并尝试修复错误的命令fsck(磁盘故障修复命令)
4.5.4 强制把内存中的数据写回硬盘的命令sync
4.5.6 挂载/卸载指定的文件系统的命令mount/umount(运维必学命令)
4.6 网络设置与维护命令(重点,Linux运维必学命令)
4.6.1 配置网络或显示当前网络接口状态的命令ifconfig(必会)
4.6.2文件远程拷贝/传输命令scp[限速传输/后台传输](重点中的重点)
4.6.3 系统连接状态、服务状态命令netstat(系统运维必备命令)
4.6.4 网络状态跟踪命令traceroute(网络故障排除必备命令)
4.6.5 探测服务状态命令telnet(判断服务运行状态必备)
4.6.6 从网络上下载软件的命令wget(断点续传/批量下载)
4.7 文本编辑工具vi的使用技巧(重点,Linux运维必学命令)
第二篇:Linux系统运维(软件安装、网络管理、故障排查)篇
五、 Linux下软件的安装与管理
5.1 源码安装方式(Linux下软件推荐安装方式)
5.1.1 下载解压源码(tar命令)
5.1.2 分析安装平台环境
5.1.3 编译安装软件(make/make install)
5.1.4 源码安装Apache Http server(案例演示)
5.2 RPM工具安装方式(熟练掌握rpm工具的使用)
5.2.1 RPM包管理工具介绍
5.2.2 RPM包种类和命令
5.2.3 RPM工具的使用
5.3 yum安装方式(最快捷的安装方式,重点掌握)
5.3.1 yum的安装与配置
5.3.2 yum的特点与基本用法
5.3.3 几个不错的yum源
5.4 二进制包安装方式(Linux下最简单的软件安装方式)
5.4.1 安装“*.tar.gz”、“*.bz2”二进制软件包
5.4.2 提供安装程序的软件包
六、 Linux服务器网络管理
6.1 网卡以及驱动的相关问题(硬件基础运维,熟练掌握)
6.1.1 网卡驱动安装的一般思路
6.1.2 实战编译安装网卡
6.1.3 DELL服务器网卡驱动BUG(最普遍的网络故障,驱动升级过程详解)
6.2 配置linux网络(重点,必须掌握的网络知识)
6.2.1 不同linux发行版的网络配置文件
6.2.2 网络配置文件详解
6.3 linux网络应用(灵活掌握Linux下各种网络应用)
6.3.1 Linux下的IP Alias功能
6.3.2 开启linux代理转发功能
6.3.3 路由的概念与配置
6.3.4 linux路由器的架设
第三篇:Web运维(Apache/Tomcat/Nginx)篇
七、 Linux下常用服务器的架设
7.1 使用OpenSSH远程管理Linux服务器(熟练掌握ssh配置)
1、如何提高ssh连接速度
2、如何通过ssh现在远程连接用户(allow user/ allow group)
7.2 apache+tomcat服务器的搭建(重点,apache+tomcat是企业应用重点,必须熟练掌握)
7.2.1 apache的多种安装方式以及各自优劣
7.2.2 httpd.conf文件精讲与经验汇总
7.2.2 apache与tomcat整合的必要性
7.2.2 Apache和Tomcat连接器
7.2.3 Apache与tomcat以及JK模块的安装
7.2.4 apache与tomcat整合配置
7.3 LAMP服务器的搭建(web运维基础,需要重点掌握)
7.3.1 LAMP与WordPress概述
7.3.2 LAMP服务环境的搭建技巧与故障排除经验(干货)
7.3.3 测试LAMP环境安装的正确性
八、企业Web服务器Nginx应用实战
8.1高性能Web服务器Nginx(web应用重点技术,企业必用,学员必学)
8.1.1 高性能Web服务器Nginx介绍(nginx的使用方向与优势)
1、Nginx的组成与工作原理
2、Nginx的性能优势
8.1.2Nginx的安装(熟练掌握nginx的安装)
1、安装Nginx依赖库
2、快速安装Nginx
8.1.3 nginx.conf文件使用解读(nginx技术的核心,重点)
1、Nginx配置文件结构
2、Nginx配置文件详解
3、location实例配置与使用技巧(实际使用中经常犯错的地方,这里是经验总结)
3、Nginx服务日常维护技巧
4、Nginx问题定位与经验总结
8.1.4Nginx常用功能介绍(企业应用中最常用的nginx技术点,必学,纯干货)
1、Nginx反向代理应用实例
2、Nginx的URL重写应用实例
3、Nginx如何加载多核CPU
4、Nginx限制域名访问/IP访问方法
5、Nginx中正则表达式的使用方法
8.1.5案例:Nginx作为负载均衡服务器应用(nginx的负载均衡功能,必学技术)
1、 Nginx的负载均衡算法
2、 Nginx的负载均衡配置实例
第四篇:数据库(MySQL)运维篇
九、构建高性能Mysql数据库系统
9.1 MySQL与MariaDB(mysql数据库的变迁过程)
1、mysql各个版本的选择(经验说话)
2、mysql的安装与使用(企业常规用法)
3、Xtrabackup对mysql的实战应用(mysqldump/ Xtrabackup)
4、mysql优化之my.cnf配置干货分享
9.2 常见的高可用MySQL解决方案(介绍企业常用的mysql解决方案,技术干货)
9.2.1 主从复制解决方案
9.2.2 MMM高可用解决方案
9.2.3 Heartbeat/SAN高可用解决方案
9.2.4 Heartbeat/DRBD高可用解决方案
9.2.5 MySQL Cluster高可用解决方案
9.3 通过KeepAlived搭建MySQL双主模式的高可用集群系统(企业最常见mysql技术应用)
9.3.1 MySQL Replication介绍 (主从复制原理)
9.3.2 MySQL Replication实现原理
9.3.3 MySQL Replication常用架构
9.3.4 MySQL主主互备模式架构图
9.3.5 MySQL主主互备模式配置
9.3.6 配置KeepAlived实现MySQL双主高可用 (纯技术干货,企业高薪必备)
9.3.7 测试MySQL主从同步功能
9.3.8 测试KeepAlived实现MySQL故障转移
9.3.9 mysql主从复制常见故障总结与分析(干货总结)
9.4 MySQL实战调优经验(一线调优技术经验汇总)
9.4.1系统方面针对MySQL的调优经验(cpu/磁盘/文件系统)
9.4.2 内核调优经验和技巧(内存参数)
9.4.3 线上MySQL环境下多种版本的选择(各种mysql分支版本的取舍)
9.4.4 Mysql重要参数调整建议(存储引擎/buffer/慢查询)
9.4.5 Mysql主从架构常见故障以及处理
第五篇:集群架构(LVS/KEEPALIVED/HAproxy)实战篇
十、LVS+Keepalived企业级应用实战
10.1 集群是怎么定义的
10.2 集群的特点与功能(集群技术实现的功能,基础知识必备)
10.3 集群的分类(集群的逻辑分类,学集群的基础知识)
10.4 HA集群中的相关术语
10.5Keepalived介绍
10.6Keepalived安装与配置(实例讲述Keepalived的安装与配置,纯干货)
10.7Keepalived基础功能应用实例(Keepalived实战应用技巧,经验汇总)
10.8 LVS能做什么(lvs结构,原理很重要,必须掌握)
10.9 LVS体系结构
10.10 LVS集群的特点
10.11 LVS的安装与使用(快速安装lvs方法)
10.12通过piranha搭建LVS高可用性集群(lvs的web管理配置工具,推荐)
10.13 通过Keepalived搭建LVS高可用性集群系统(企业中最常见/最实用lvs集群架构,必须掌握)
10.14 测试高可用LVS负载均衡集群系统(实战应用案例,测试lvs的高可以功能)
十一、高性能负载均衡集群HAProxy实战
1、四层和七层负载均衡的区别
2、HAProxy与LVS的异同
3、快速安装HAProxy集群软件
4、HAProxy基础配置文件详解
5、 HAProxy配置文件详解
6、haproxy 解决集群session共享问题
7、启动与测试haproxy的负载均衡功能
8、HAProxy负载均衡器算法与使用技巧
9、通过HAProxy的ACL规则实现智能负载均衡
10、使用HAProxy的Web监控平台
11、HAproxy+KeepAlived高可用负载均衡系统
第六篇:运维监控(nagios/ganglia/centreon/zabbix)实战篇
十二、Ganglia分布式运维监控平台实战
12.1 Ganglia简介
12.2 Ganglia的组成
12.3 Ganglia的工作原理
12.3.1 Ganglia数据流向分析
12.3.2 Ganglia工作模式
12.4 Ganglia的安装
12.4.1 yum源安装方式
12.4.2 源码方式
12.5 配置一个Ganglia分布式监控系统
12.5.1 Ganglia配置文件介绍
12.5.2 Ganglia监控系统架构图
12.5.3 Ganglia监控管理端配置
12.5.4 Ganglia的客户端配置
12.5.5 Ganglia的Web端配置
12.6 Ganglia监控系统的管理和维护
12.6 Ganglia监控扩展实现机制
12.6.1 扩展Ganglia监控功能的方法
12.6.2 通过gmetric接口扩展Ganglia监控
12.6.3通过Python插件扩展Ganglia监控
12.6.4实战:利用Python接口监控Nginx运行状态
12.7 Ganglia在实际应用中要考虑的问题
12.7.1 网络IO可能存在瓶颈
12.7.2 CPU可能存在瓶颈
12.7.3gmetadrrd数据写入可能存在瓶颈
十三、Zabbix监控平台应用实战
1、Zabbix架构与应用思路
2、安装lamp环境
3、源码安装zabbix server端
4、rpm包快速安装zabbix_agent
5、通过zabbix_get测试zabbix监控
6、Zabbix配置文件详解
7:Zabbix用户自定义监控参数User parameters
8、Zabbix的Agentd主动模式与被动模式监控
9、Zabbix的安装常见错误
10、实战案例:通过zabbix监控nginx