本日就让我带着大家一起回顾高等运维工程师打怪升级之路。
运维工程师在刚入行阶段是一很苦逼的,可能干着修电脑、掐网线、搬机器的活,显得没地位!
韶光也很碎片化,各种零星的琐事环绕着你,也很难表示个人代价,逐渐的对行业很迷茫,以为没什么发展出息。
这些呆板无味事情的确会使人匮乏!
技能是呆板无味的,这些基本事情并非是多余的,这些履历会对后期的运维事情带来一定的帮助。以是在这个期间一定要保持积极向上的心态,持续的学习,争取找一个更磨炼人的事情!

打怪篇:
职业发展技能专家
发展方案:初中级工程师 -> 高等工程师 -> 架构师 -> 专家
适宜人群:比较喜好寻衅,热爱技能,有较强研讨精神,在某一领域有深入的理解,性情比较内向。
技能管理
发展方案:初中级工程师 -> 高等工程师 -> 主管/经理 -> 总监 -> CTO(首席技能官)
适宜人群:技能知识面广,有一些管理思维,长于交际,表达沟通能力强,常常关注行业内动态和主流技能。
目标熟习运维技能学习路线及干系技能熟习职业发展方向及口试剖析低级紧张事情
修电脑,设备巡检做事器高下架网络做事支配网站平台搭建与掩护1、Linux根本
刚开始阶段须要熟习Linux操作系统安装,目录构造、启动流程等。
2、系统管理
紧张学习Linux系统,生产环境中基本都在字符界面完成事情,以是要节制常用的几十个基本管理命令,包括用户管理、磁盘分区、软件包管理、文件权限、文本处理、进程管理、性能剖析工具等。
3、网络根本
OSI和TCP/IP模型一定要熟习。基本的交流机、路由器观点及实现事理要知道。
4、Shell脚本编程根本
节制Shell基本语法构造,能编写大略的脚本即可。
中级紧张事情
集群网站平台搭建数据库基本管理监控系统搭建脚本化事情1、网络做事
常见的网络做事要会支配,比如vsftp、nfs、samba、bind、dhcp等。
代码版本管理系统少不了,可以学习下主流的GIT,能支配和大略利用就可以了。
常常在做事器之间传输数据,以是要会利用:rsync和scp。
数据同步:inotify/sersync。
重复性完成一些事情,可写成脚本定时去运行,以是得会配置Linux下的定时任务做事crond。
2、Web做事
每个公司基本都会有网站,能让网站跑起来,就须要搭建Web做事平台了。
如果是用PHP措辞开拓的,常日搭建LNMP网站平台,这是一个技能名词组合的拼写,分开讲便是得会支配Nginx、MySQL和PHP。
如果是JAVA措辞开拓的,常日利用Tomcat运行项目,为了提高访问速率,可以利用Nginx反向代理Tomcat,Nginx处理静态页面,Tomcat处理动态页面,实现动静分离。
不是会支配这么大略,还要知道HTTP协议事情事理、大略的性能调优。
3、负载均衡器
单台做事器究竟资源有限,抵抗高访问量肯定是无法支撑的,办理此问题最关键的技能便是采取负载均衡器,水平扩展多台Web做事器,同时对外供应做事,这样就成倍扩展性能了。负载均衡器主流开源技能有LVS、HAProxy和Nginx。一定要熟习一两个!
4、数据库
数据库选择MySQL,它是天下上利用最为广泛的开源数据库。学它准没错!
也要会一些大略的SQL语句、用户管理、常用存储引擎、数据库备份与规复。
想要深入点,必须会主从复制、性能优化、主流集群方案:MHA、MGR等。
NoSQL这么盛行当然也少不了,学下Redis、MongoDB这两个就好了。
5、监控系统
监控必不可少,是及时创造问题和追溯问题的救命稻草。可以选择学习主流的Zabbix、Prometheus开源监控系统,功能丰富,能知足企业级监控需求。监控点包括做事器硬件、做事器性能、API、业务、PV/UV、日志等方面。
也可以弄个仪表盘展示几个实时关键的数据,比如Grafana,会非常炫酷。
6、日志剖析系统
日志也很主要,定期的剖析,可创造潜在隐患,提炼出有代价的东西。
主流日志系统:ELK Stack
学会支配利用,能剖析日志并可视化,方便故障排查。
7、安全戒备
安全很主要,不要等到系统被攻击了,再做安全策略,此时已晚!
以是,当一台做事器上线后应立时做安全访问掌握策略,比如利用iptables限定只许可托赖源IP访问,关闭一些无用的做事和端口等。
一些常见的攻击类型一定得知道啊,否则怎么对症下药呢!
比如CC、DDOS、ARP等。
8、Shell脚本编程进阶
Shell脚本是Linux自动完成事情的利器,必须得闇练编写,以是得进一步学习函数、数组、旗子暗记、发邮件等。
文本处理三剑客(grep、sed、awk)得玩6啊,Linux下文本处理就指望它们了。
9、Python/Go开拓根本
Shell脚本只能完成一些基本的任务,想要完成更繁芜些的任务,比如调用API、多进程等。就须要学高等措辞了。
Python是运维领域利用最多的措辞,大略易用,学它准没错!
此阶段节制根本就可以了,例如基本语法构造、文件工具操作、函数、迭代工具、非常处理、发邮件、数据库编程等。
紧张事情
亿级网站架构设计性能优化容器化落地大规模自动化运维平台化事情1、Web静态缓存
用户老喊着访问网站慢,看看做事器资源还很富余啊!
网站访问慢大概不是做事器资源饱和导致的,影响成分很多,例如网络、转发层数等。
对付网络,存在南北通信问题,之间访问会慢,这个可以利用CDN办理,同时缓存静态页面,尽可能将要求拦截在最上层相应,减少后端要乞降相应韶光。
如果不用CDN,也可以利用Squid、Varnish、Nginx这样的缓存做事实现静态页面缓存,放到流量入口处。
2、集群
单台做事器究竟资源有限,抵抗高访问量肯定是无法支撑的,办理此问题最关键的技能便是采取负载均衡器,水平扩展多台Web做事器,同时对外供应做事,这样就成倍扩展性能了。负载均衡器主流开源技能有LVS、HAProxy和Nginx。一定要熟习一两个!
Web做事器性能瓶颈办理了,数据库更为关键,还是采取集群,就拿MySQL来说,可以一主多从架构,在此根本上读写分离,主卖力写,多从卖力读,从库可水平扩展,前面再来个四层负载均衡器,承载千万级PV,妥妥的!
高可用软件也得会,避免单点的利器,主流的有Keepalived、Heartbeat等。
随着业务扩展,网站图片越来越多!
NFS共享存储支撑不过了,处理很慢!
上分布式文件系统,并行处理任务,无单点,高可靠,高性能等特性,主流的有FastDFS、MFS、HDFS、Ceph、GFS等。初期的话我建议学习下FastDFS,能知足中小规模需求。
3、容器化
硬件做事器资源利用率很低,甚是摧残浪费蹂躏!
可以把空闲多的做事器虚拟化,弄成很多个的虚拟机,每个虚拟机便是一个完全的操作系统。可以很大程度提高资源利用率。主流私有云平台实现:KVM+OpenStack
虚拟机作为根本平台还可以,但运用业务弹性伸缩也太重量了吧!
启动好几分钟,文件又这么大,快速扩展太费劲了!
好说,上容器,容器紧张特点便是快速支配和环境隔离。一个做事封装到镜像中,分分钟钟可创建几百个容器。
主流的容器技能非Docker莫属了。
当然,生产环境单机Docker大多数情形下是无法知足业务需求的,可以基于Kubernetes构建容器平台,集群化管理容器,形成一个大的资源池,为根本架构供应有力的支撑。
4、自动化运维
反反复复重复的事情,不但提高不了效率,代价也得不到表示。
统统运维事情标准化,例如环境版本、目录构造、操作系统等统一。在标准化根本上才能更方面的自动化,点点鼠标或者敲几个命令即可完成一项繁芜的事情任务,爽哉爽哉!
因此,所有的操作尽可能自动化,减少人为失落误,提高事情效率。
主流做事器集中管理工具:Ansible、Saltstack
持续集成工具:Jenkins、Gitlab
5、Python开拓进阶
可以再深入学习下Python开拓,节制面向工具编程。
最好也掌学习一个Web框架开拓网站,例如Django、Flask,紧张是开拓运维管理系统,将一些繁芜的流程写到平台中,再集成集中管理工具,可打造一个属于运维自己的管理平台。
7、性能优化
只会支配是远远不足的,性能优化能最大化提升做事承载量。
这块也是比较难的,也是高薪的关键点之一,为了钱也得下点功夫学习啊!
可以从硬件层、操作系统层、软件层和架构层维度展开思考。
师门任务篇:
节制 80% 互联网公司会用到的技能才有更大竞争力!
意识
1、坚持
学习是一个很漫长的过程,是我们每个人须要用生平去坚持的奇迹。
贵在坚持,难在坚持,成在坚持!
2、目标
没有目标的不叫事情,没有量化的不叫目标。
每到一个阶段,制订一个目标。
比如:先定一个能达到的小目标,挣它一个亿!
3、兴趣
如果你热爱这个行业,那它就不但是一份事情。
如果你不热爱这个行业,可能是做不好,也可能坚持不超过2年,由于你心里上过不去。