相信大部分同学刚毕业或者想转行做c++服务端开发的时候都很迷茫不知道从哪里开始学习,于是准备参加各种培训班或者网络培训,无奈动不动成千上万元的高昂的价格另人望而却步,对于在校学生或者刚出来就业的新人无疑是沉重都打击,最后决定自学,但是却不知道从哪里下手。我写这篇文章的目的就是为了帮助更多想入行或者想转行做c++服务器的新人避免走更多的弯路,最终能够顺利的掌握相关知识找到心仪的工作。
一. 基础阶段
-
c/c++编程语言
-
linux基础
-
数据结构与算法
-
设计模式
-
脚本语言(可选)
二. 入门阶段
-
linux系统编程
-
linux网络编程
三. 进阶阶段
-
数据库mysql
-
分布式缓存redis
-
网络库
四. 项目实践阶段
-
编写简单FTP服务器
五. 高级阶段(可选)
-
nginx
-
zookeeper
-
消息队列
-
skynet
-
boost
-
负载均衡
-
容器
-
rpc
-
微服务
…
##一. 基础阶段
###1.
c/c++编程语言
###2.
linux基础
-
linux系统安装和命令、工具使用
c++服务器程序基本都是运行在linux系统下面,所以对于linux的系统安装、命令工具等的使用要学会。
推荐《鸟哥的Linux私房菜-基础学习篇》
-
makefile编程
在软件开发中,make通常被视为一种软件构建工具。该工具主要经由读取一种名为“makefile”或“Makefile”的文件来实现软件的自动化建构。它会通过一种被称之为“target”概念来检查相关文件之间的依赖关系,这种依赖关系的检查系统非常简单,主要通过对比文件的修改时间来实现。在大多数情况下,我们主要用它来编译源代码,生成结果代码,然后把结果代码连接起来生成可执行文件或者库文件。
推荐《跟我一起学makefile》
链接:
https://pan.baidu.com/s/18KSmdTHQhiw-Tng1RJxf1A
密码:526k
###3.
数据结构与算法
-
入门推荐《大话数据结构》这本书,它的最大的特点是把理论讲得很有趣,不枯燥。而且每个数据结构和算法,作者都结合了生活中的例子,能让你有非常直观的感受。虽然这本书有 400 页,但是花两天时间读完应该是没问题的。所以,如果你之前完全不懂数据结构和算法,可以先从这本书看起。
-
你也可以学习《数据结构和算法分析》。国内外很多大学都拿它当作教材。因为这本书非常系统、全面、严谨,而且又不是特别难,适合对数据结构和算法有些基本了解,并且掌握了至少一门编程语言的同学。而且,这个作者也很用心,他用了三种语言,写了三个版本,分别是:《数据结构与算法分析 : C 语言描述》、《数据结构与算法分析 : C++ 描述》、《数据结构与算法分析 : Java 语言描述》。
###4.
设计模式
设计模式是一套被反复使用、多数人知晓的、经过分类的、代码设计经验的总结。
使用设计模式的目的:为了代码可重用性、让代码更容易被他人理解、保证代码可靠性。 设计模式使代码编写真正工程化;设计模式是软件工程的基石脉络,如同大厦的结构一样。
###5.
脚本语言(可选)
做c++开发很多情况下会和其他脚本语言做混合编程,特别是游戏公司以c++配合lua脚本编程作为主流,也有一些用python, 所以建议大家学一下这两门脚本语言
-
lua书籍推荐,包括入门书籍《lua程序设计》和深入原理书籍《lua设计与实现》
-
python书籍推荐 《python核心编程》
##二. 入门阶段
###1.
linux系统编程
linux下的编程你首先要学会文件和目录、标准I/O库、系统数据文件和信息、进程环境、进程控制、进程关系、信号、线程、线程控制、守护进程、各种I/O、进程间通信、网络IPC等方面的内容。
推荐《unix环境高级编程》
###2.
linux网络编程
网络编程可以编写网络通讯程序,比如聊天程序、数据传输程序、文件传输程序等到;可以让你对网络通讯有更深的理解,当你遇到网络通讯方面的问题时,会有很深入的分析;为学习涌现很多分布式应用系统打下坚实的基础。
推荐《unix网络编程》(共两卷)
##三. 进阶阶段
###1.
数据库mysql
-
入门推荐《MySQL必知必会》这是最好的数据库入门书,在Amazon上长期排在数据库销售榜首,建议想快速了解数据库原理和MySQL的新手阅读。快餐性质,简洁明快,小开本,而且很薄,比较好读。
-
怎么说,每个行业都有几本被翻来翻去的“街书”,而《mysql技术内幕》就是MySQL的“街书”。从源代码的角度深度解析了InnoDB的体系结构、实现原理、工作机制,并给出了大量最佳实践,能帮助你系统而深入地掌握InnoDB
-
《高性能mysql》作者推荐的工具、实战案例及经验过的诊断技术,可大大提高性能急救技能,以及加深对MySQL本质的理解。而且本书将数据库结构的客观方面纳入思考,此外还增补了MySQL高可用性及云特性
###2.
分布式缓存redis
-
《Redis 设计与实现》一书全面而完整地讲解了 Redis 的内部运行机制, 对 Redis 的大多数单机功能以及所有多机功能的实现原理进行了介绍, 展示了这些功能的核心数据结构以及关键的算法思想。 通过阅读本书, 读者可以快速、有效地了解 Redis 的内部构造以及运作机制, 从而学会如何更高效地使用 Redis。
-
《redis实践》本书深入浅出地介绍了Redis的5种数据类型,并通过多个实用示例展示了Redis的用法。除此之外,书中还讲述了Redis的优化方法以及扩展方法。
###3.
网络库
linux c/c++网络库比较多,有boost.asio、libevent、libev、libuv、muduo、ace等, 建议找一个代码比较少够精简的来反复学习,琢磨内部原理,有效提升网络编程能力。我自己反复研究了muduo网络库几遍收获不少,你们可以选libevent、libev、libuv、muduo中的一个学习即可,其中libev和muduo最为精简,容易学习。
##四. 项目实践阶段
###1.
编写简单FTP服务器
###2.
未完待续 … (后面更新请关注公众号“
高并发之路
”)
##五. 高级阶段(可选)
###1.
nginx
-
Nginx是一款自由的、开源的、高性能的HTTP服务器和反向代理服务器;同时也是一个IMAP、POP3、SMTP代理服务器;Nginx可以作为一个HTTP服务器进行网站的发布处理,另外Nginx可以作为反向代理进行负载均衡的实现。
推荐书籍《深入理解nginx模块开发与架构解析》
###2.
zookeeper
-
ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。ZooKeeper的目标就是封装好复杂易出错的关键服务,将简单易用的接口和性能高效、功能稳定的系统提供给用户。
###3.
消息队列
-
当前使用较多的消息队列有RabbitMQ、RocketMQ、ActiveMQ、Kafka、ZeroMQ、MetaMq等, 我推荐两本kafka的书籍, 入门书籍《kafka权威指南》和深入的书籍 《Kafka技术内幕:图文详解Kafka源码设计与实现》
###4.
skynet
###5.
未完待续 … (后面更新请关注公众号“
高并发学习社区
”)
视频资料: 微信搜索公众号“高并发学习社区”关注并且发送消息“视频” 。C++服务器开发完整学习路线(含免费学习资料下载地址)相信大部分同学刚毕业或者想转行做c++服务端开发的时候都很迷茫不知道从哪里开始学习,于是准备参加各种培训班或者网络培训,无奈动不动成千上万元的高昂的价格另人望而却步,对于在校学生或者刚出来就业的新人无疑是沉重都打击,最后决定自学,但是却不知道从哪里下手。我写这...
我将展示如何使用现代
C++
编写一个Echo
服务器
,相当于分布式系统
开发
中的“Hello World”。这个
服务器
会将接收的消息直接返回。我们同时需要一个可以向我们的
服务器
发动消息的客户端,在这里可以发现客户端的源码。
Wangle是一个用来搭建事件驱动的现代异步
C++
服务的C/S应用框架。Wangle最基本的抽象概念就是Pipeline(管线)。能够理解这种抽象,将会很容易写出各种复杂的现代
C++
服务,另一个重要的概念是Service(服务),其可以看作一种更高级的Pipeline,不过超出了本文我们关注的范畴。
PipeLine
pipeline 是 Wangle 中最重要也是最强大的抽象,
转眼间已经工作四年有余,回想自己从毕业到现在,迷茫和焦虑往往是萦绕不去的情绪。工作上虽算是有所进步,但自己的职业生涯,技术路线却一直苦于无师可询,摸着石头过河是常态,兜兜转转浪费了不少时间。今天写文记录下自己的技术感悟,斗胆以进阶做名,也是希望对同样迷茫的同行有所启发或共鸣。
我现在应该算是
C++
服务器
开发
的领域,所以主要说下关于
C++
服务器
开发
的相关进阶:
服务器
开发
主要有四块儿的知识领域: