腾讯后台开发工程师的学习之路:如何成为鹅厂的一员!(附赠学习资料)

发表时间: 2021-09-07 16:13

自我介绍一下,本人15年非科班硕士毕业老油条,在开发岗位上蹉跎6年了,前后经历过海康威视C++软件开发、小米云平台软件开发,18年10月份拿到了鹅厂后台开发的offer。

忆当初,在本科我其实在软件方面的基础为0,真正开始学习软件基础知识是从研究生开始。学习的时间也是在跟着导师做项目之余一点点挤出来的。因此,那些觉得自己时间不够或者灭有任何基础的同学完全不需要过于担心,俗话说,时间挤挤就有了,这是有道理的。只要你想进入大厂的目标坚定,肯拼肯努力,静下心来学习积累,并且有进取的心,最后的结果绝对不会太差。

在学生时期,需要用到的知识不是很深,所以最开始接触选择了自学,但是当时还有1年就要毕业,各种学习和项目占满了我的时间,自学肯定是不可行,一是时间不够,二是不够系统,别说进大厂了,能完成进阶都不错了,所以我花费了1个星期的时间找大佬,历经8个多月完成了C++进阶课程。

其实之前一直都想写点东西,主要是也没时间系统来讲,这次终于在毕业季抽出时间来写一些东西,希望对马上要找工作的同学们有帮助,我也把我最近几年累积的C++资料整理了一波,这一波资料更多是偏向进阶版的,有需要的小伙伴可以自行领取,免费的!!

(C++linux服务器开发群(812855908,免费领取)

一般来说,只要能达到“C++解决简单问题”的水平,找工作就不成问题,只是受限比较多,只能从事一些比较初级的工作,很容易陷入没日没夜的写代码的窘境,然后看着层出不穷的新技术束手无策……

你学习的知识越多,代码里的灵气就越多,这时候你就可以用巧力把复杂的工作简单化,并且提升工作效率,做到这个程度,你才可以获得更好的工作机会。

想要达到这个程度必须要进行系统的学习,我也给大家说下我当时8个月的时间,到底学了些什么,是如何规划的。

1、精进基础

1.1数据结构与算法

面试必聊的排序与KMP;随处可见的红黑树;磁盘储存链式的B树与B+树;海量数据去重的Hash与布隆过滤器,bitmap;图论算法,di jkstra,dfs,bfs,动态规划

1.2设计模型

创建型设计模型:单例模式、工厂方法模式与抽象工厂模式、原型模式;结构型设计模式:适配器模式、代理模式、桥接模式、组合模式;行为型设计模式:策略模式、观察者模式、责任链模式、状态模式

1.3工程管理

手写:Makefile/cmake/configure;操作:git/svn与持续集成;Linux系统运行时参数命令

推荐视频:红黑树,在Linux内核的那些故事


2、高性能网络设计

2.1网络编程

项目:网络io与select,poll,epoll;项目:reactor的原理与实现;项目:http、https服务器的实现;项目:websocket协议与服务器实现

2.2网络原理

项目:服务器百万并实现;redis,memcached,nginx网路组件;posix API与网络协议栈;udp的可靠传输,QUIC,KCP

2.3自研框架:协程框架实现NtyCo

协程的设计原理与切换汇编实现;协程的调度器实现与性能测试

2.4 自研框架:用户态协议栈NtyTCP

tcp/ip设计;tcp/ip定时器与滑动窗口的实现;Epoll的实现

推荐视频:网络原理tcp/udp,网络编程epoll/reactor,面试中的八股文

用户态协议栈 三部曲 uio,数据帧,协议栈


3、基础组件实现

3.1池式组件

手写线程池与性能分析;ringbuffer与内存实现;异步请求池 http/mysql/redis/dns;mysql/redis连接池的实现

3.2高性能组件

原子操作CAS与锁实现原理实现;消息队列与无锁实现;实时器方案 红黑树 时间轮 最小堆;try/catch组件的实现

3.3 开源组件

l ibenent/libev框架实战的那些坑;异步日志方案log4cpp;应用层协议涉及ProtoBuf/Thrift;Openssl 对称加密与非对称加密;Json数据解析/Xml解析器和工具包;字符编码Unicode原理及编程实践

推荐视频:150行代码,带你手写线程池,自行准备linux环境

linux后台开发面试必备技能——锁,原子操作,CAS


4、中间件开发

4.1 My SQL

MySQL SQL语句,索引,视图,存储过程,触发器MySQL索引远离以及SQL优;MySQL事务原理分析、缓存策略、集群方案与Replication原理

4.2 Redis

Redis相关命令详解及其远离,协议与异步方式;储存远离与数据模型;主动同步与对象模型;集群方案主从复制/哨兵/集群与持久化

4.3 Nginx

Nginx反向代理与系统参数配置conf原理;进程间同行与Slab共享机制;广告内容推送Nginx过滤模块的实现;访问评率统计Nginx handler模块的实现;Nginx http状态机流程

4.4 MongoDB

接口编程与文档操作集群方案与持久化备份

推荐视频:聊聊linux后台开发人员是如何在开发中使用redis的

手把手带你实现一个nginx模块,更加深入了解nginx(搭建好环境)


到这里已经是4个版块的内容了,学到这里可以稍微的回顾一下前面的内容,消化一下,再继续进行下面的学习,之后就是开源、Linux、性能分析以及分布式构架,学好前面的内容,才能更好的了解后面的知识。

如果上面版块的内容,有任何不懂,一定要及时沟通解决,不要把今天的疑问留到明天,不然只会越累越多,我这边可以推荐给大家一个C++linux服务器开发群(812855908,里面有大佬也有学习者,有任何问题都可以在群里咨询,大家也会热心解答,还有更多学习资料领取!!!

5、开源框架

5.1 Skynet

设计原理;网络层封装以及lua/c接口编程;重要组件以及手撕游戏项目

5.2 ZeroMQ

消息队列与ZeroMQ的应用;消息模型的实现;网络机制与性能分析

5.3 DPDK

DPDK环境与testpmd/l3fwd/skeleton;DPDK的用户态协议栈实现;千万级流量并发的DNS处理;高性能数据处理框架VPP;DPDK的虚拟交换机框架Ovs

推荐视频:千万级并发的难点有哪些?dpdk为我们解决了哪些核心问题?

掌握skynet,linux后端开发原来如此简单


6、Linux内核源码

6.1 进程管理

进程远离与运行分析;全方位剖析调度机制;锁与进程间通信

6.2内存管理

内存原理与内存杂乱繁多的细节;物理内存与虚拟内存管理;虚拟内存及API调用

6.3文件系统

虚拟文件系统;无持久储存的文件系统;磁盘文件系统;用户态文件系统fuse

6.4 设备驱动

实现进程间通信组件;块设备运行远离;虚拟网络适配器的实现

推荐视频:360度无死角讲解进程管理,调度器的5种实现

90分钟了解Linux内存架构,numa的优势,slab的实现,vmalloc原理



7、性能分析

7.1性能工具

高性能代码构建系统tundra,Http压测工具WRK,网站压测工具webbench

7.2 调试库

内库调试性能分析工具Valgrind;谷歌C++测试框架GoogleTest;内存分配跟踪库MemTrack

7.3内核跟踪与火焰图分析

内核探测SystemTap;火焰图分析与生成


8、分布式架构

8.1 架构实战

腾讯微服务RPC框架Tars;容器化Docker与容器编排;容器化管理k8s与核心组件

8.2架构原理

分布式注册服务中心etcd;内核级支持的分布式储存Ceph;快播核心技术揭秘P2P构架的实现

推荐视频:C++方向之分布式存储-fastdfs-ceph


9、上线项目实战

9.1 互联网并发云盘

fastdfs构架分析和配置;fastdfs储存原理;分布式fastds储存集群部署;高负载nginx/fastcgi;文件传输和接口设计;产品上云公网发布/测试用例

9.2微服务即时通讯

IM即时通讯项目框架分析和部署;IM消息服务器/文件传输服务器;消息服务器/路由服务器;数据库代理服务器设计;文件服务器和docker部署;产品上云公网发布/公网测试上线

这个版块的内容更多是结合实际进行项目实战,这也是帮助你进阶完成后能够快速找到理想工作。


以上整个就是我8个月进阶的学习规划,可以说是非常详细了,不管是资料还是大佬我都有在文章中分享给大家,这边也做个汇总,需要的直接点击领取↓↓↓

总之,你的学习都是为了找到更好的工作,不管是学习还是找工作都要做好长期的打算,一定要坚持和不断学习积累,如果受到挫折,要想办法进行疏解,然后再继续向前,保持好的心态,绝对能够学有所成!