C/C++ Linux后台服务器开发高级架构师学习知识点路线总结(2021架构师篇完整版)
前言:
小编之前有跟大家分享过一篇架构师体系知识点总结的文章,今天在原来的基础上有所改变更新(2021版)。
相信大家也知道,想要成为一名架构师肯定是需要一定的时间经验累积,才可以达到架构师的水平,今天分享的是成为架构师需要掌握的技术知识点,尽量的完善,目前对标的是知名企业腾讯、阿里等等后端开发岗位。
今天更新的内容是从Linux高级互联网架构师知识点说起,基础的知识点今天在这里就不写出来了,有需要了解的朋友可以看看我之前的文章:C/C++ Linux 后台服务器开发高级架构师学习知识路线总结
Linux高级互联网架构师专栏
目录:
一:源码分析专题
二:中间件开发专题
三、集群
四:Linux系统专题
五:性能与测试专题
六:运维统计专题
七:分布式架构专题
八:挑战网络性能极限DPDK专栏
九、全方位分析Linux内核代码专栏
文末附上整体的思路图、
一:源码分析专题
源码阅读能力是提升技术必不可少的途径
1、Nginx源码
知识点包括:Nginx基础架构、HTTP架构、 进程间的通信机制、Nginx高级数据结构、slab共享内存、upstream机制设计
2、Redis源码
知识点包括:Redis存储系统原理、数据模型与键值映射、内存操作与磁盘同步、主从同步,原子操作、底层IO实现解析
3、skynet源码
知识点包括:网络模块实现与数据共享、定时器实现、actor实现与cluster集群、lua辅助库的实现、负载均衡与热更新方案、c服务开发与对接客户端、skynet奇技淫巧
4、ZeroMQ源码
知识点包括:消息模型 发布订阅/推拉模型、通信协议 inproc/ipc/tcp/pgm、性能分析与经典MQ对比、底层网络通信实现机制、zmq系统架构与实现原理
二:中间件开发专题
要有造轮子的能力,也要有不造轮子的觉悟,SDK是高级开发必须要有的封装能力
1、高性能组件
知识点包括:如何设计内存池、高并发场景下的消息队列、协程框架的实现、手写线程池、异步请求池、连接池、
2、高并发网络IO
知识点包括:select,poll和epoll模型的区别、 Linux系统IO模型、理解Linux 服务器高并发编程、网络接入层架构设计、你必须懂得Epoll玩法
3、并发性
知识点包括:多线程与线程安全、事务的隔离级别、公平锁&非公平锁、CopyOnWrite容器、悲观锁&乐观锁&CAS&ABA问题、 事务ACID特性
4、Web服务
知识点包括:反向代理Nginx、最广泛的web服务器 Httpd、高性能 Web 平台OpenResty
5、定时调度
知识点包括:分布式定时调度 Opencron、触发器按时启动原理、Linux定时任务cron配置
6、消息队列
知识点包括:消息总线VS消息队列、Redis 消息推送、如何保证消费者接收消息的顺序
7、Web安全
知识点包括:CSRF原理及防范、高级Dos攻击-Hash碰撞攻击、脚本注入文件上传漏洞、SQL注入、XSS攻击原理与解决方案
8、网络协议栈
知识点包括:tcp/udp/ip/eth、多进程实现高并发、滑动窗口、延迟确认、定时重传、流量控制、tcp握手挥手
三、集群
必须要有的产品级技能。
1、MySQL集群
知识点包括:MySQL Cluster 评估指南、读写分离 分库分表、Binlog机制分析、健全性检查与故障排除、数据模型与查询设计
2、Redis集群
知识点包括:Redis Cluster方案、节点自动发现、master/slave 选举,集群容错、ASK转向/MOVED转向机制
3、FastDFS集群
知识点包括:tracker与storage节点、文件上传/下载测试、fastdfs-nginx-module的原理、fastdfs的实现原理
4、K8S集群
知识点包括:K8S核心组件、无缝对接新应用、快速部署应用与扩展、自动部署、管理容器化
5、Nginx集群
知识点包括:Nginx的实现原理、经典应用场景、高可用方案的实现机制、LVS与Nginx集群
6、 MongoDB集群
知识点包括:高可用的MongoDB集群方案、文档管理机制与实现、配置分片的表与片键、MongoDB集群环境部署
7、etcd分布式注册
知识点包括:etcd的概念与集群环境部署、etcd的特性与数据结构、原理及其内部选举机制etcd集群实现机制
8、rpc微服务 tars
知识点包括:tars的搭建与部署、微服务rpc的原理
四:Linux系统专题
Linux是每个工程师都会讨论的话题
1、环境编程
知识点包括:系统文件操作 一切设备接文件、信号量 mmap 共享内存、 系统时间 时间戳 定时器、网络IO编程 epoll机制、锁机制 互斥锁 spinlock 条件变量 原子操作、进程/线程 数据同步机制
2、系统运维
知识点包括:系统日志管理与配置、服务器环境搭建与配置、集成化工具安装、shell命令 文件操作
五:性能与测试专题
程序优化是所有程序产品必不可少的话题
1、理解性能优化
知识点包括:容量评估 平均QPS 高峰QPS 单机QPS、CDN网络加速原理、连接池的性能优化、性能优化方法论
2、MySQL调优
知识点包括:理解MySQL底层原理 B+Tree机制、索引优化揭秘、 SQL语句优化、SQL执行机制详解
3、测试理论
知识点包括:深度解析 TDD 测试驱动开发、全链路压测经验、Nginx根据IP进行灰度发布 A/B Test、真实流量测试工具 tcpcopy、单元测试minUnit
4、Linux调优
知识点包括:内核代码组织架构、系统IO参数调优配置、网络协议栈参数配置、内核代码编译与内核更换
5、GCC调优
知识点包括:快速编译工程Makefile编写、编译机制 编译原理
六:运维统计专题
团队合作,产品开发,必须要有代码管理能力
1、Jenkins
知识点包括:搭建Jenkins自动化部署环境、test\pre\production 多环境发布、Jenkins集成git实现自动部署、Jenkins多环境配置,权限管理及插件使用
2、虚拟化
知识点包括:Xen虚拟化搭建与原理详解、KVM经典详解、OpenStack架构知识梳理、开源Linux容器 OpenVZ
3、Docker
知识点包括:Dockerfile的编译与镜像编译、Docker-Compose部署与编排、Docker命令与镜像版本提交、Docker的原理
七:分布式架构专题
以铜为镜,可以正衣冠;以古为镜,可以知兴替;以人为镜,可以明得失。从互联网一线产品的技术架构,提高自己的视野
1、架构实战
知识点包括:新浪门户负载均衡方案解析、京东海量存储哈希存储引擎解密、虎牙核心视频直播架构技术揭秘、京东分布式K-V存储设计与挑战、阿里网络故障智能化治理解决方案、小艾叮咚语音核心技术语音合成实战、微信安全开放性云平台架构探秘、爱奇艺大数据平台的构建之路
2、架构中间件
知识点包括:远程调用rpc从入门到精通、多进程高效通信之共享MM全攻略、Nginx进程间通信剖析、高性能服务器为什么需要内存池、百度大规模时序指标自动异常检测实战
3、架构策略
知识点包括:订阅者发布者模式实现高并发架构、阿里云Elasticsearch架构解析与性能优化实践、两段提交与多段提交、UDP分片原理分析及其实现方法、Reactor模式和线程池实现高并发服务
4、架构原理
知识点包括:消息驱动式架构设计方法论、动态域名解析和CDN原理、Zookeeper原理、分布式锁的原理、P2P去中心化原理、 应用层协议设计方法论
对于自学的朋友,耗时比较久,技术栈不完善,架构不成体系,自律性差。这里给大家分享一个学习视频链接,订阅后免费试听:C/C++Linux服务器开发/后台架构师【零声学院】-学习视频教程-腾讯课堂
八:挑战网络性能极限DPDK专栏
1、认识DPDK
知识点包括:主流包处理硬件平台、解读数据包处理能力
件包处理的潜力:DPDK加速网络节点、DPDK加速计算节点、DPDK加速存储节点、DPDK的方法论
实践回顾理论:Skeleton、L3fwd
2、Cache和内存
知识点包括:Cache系统、Cache地址映射和变换、Cache的写策略、Cache预取、Cache一致性、TBL和巨页、英特尔数据直接DDIO、非统一内存访问NUMA
存储系统:系统架构的演进、内存子系统
3、并行计算
知识点包括多核性能和可扩展性:追求性能水平扩展、多核处理器亲和性、DPDK的多线程
指令并发与数据并行:指令并发、单指令多数据
4、同步互斥机制
知识点包括原子操作:处理器上的原子操作、Linux内核原子操作、DPDK原子操作实现与应用
读写锁:Linux读写锁核心API、DPDK读写锁实现和应用
自旋锁:自旋锁的缺点、Linux自旋锁API、DPDK自旋锁实现和应用
无锁机制:Linux内核无锁环形缓冲、DPDK无锁环形缓冲
5、报文转发
知识点包括转发框架介绍:网络处理模块划分、DPDK run to completion模型、DPDK pipeline模型
转发算法:精确匹配算法、最长前缀匹配算法、ACL算法、报文分发
6、PCIe与包处理I/O
知识点包括PCIe事务的角度:异常中断模、式轮询模式、混合中断轮询模式
PCIe上的数据传输能力:Brust收发包的优点、批处理和时延隐藏、利用Intel SIMD指令并行化包收发、网卡DMA描述符环形队列、数据包收发—CPU和I/O
Mbuf和Mempool:Mbuf、Mempool
7、网卡性能优化
知识点包括DPDK的轮询模式:异步中断模式、异步中断模式、混合中断轮询模式
网卡I/O性能优化:Burst收发包的优点、批处理和时延隐藏、Intel SIMD指令并行转发
平台优化及其配置调优:硬件平台的性能影响、软件平台的性能影响
队列长度及各种阈值的设置:收包队列长度、发包队列长度、收包队列可释放描述符数量阈值、发包队列可释放描述符数量阈值、发包描述符释放阈值
8、流分类与多队列
知识点包括多队列:网卡多队列的由来、Linux内核对多队列支持、DPDK与多队列、队列分配
流分类:包的类型、接收方扩展 RSS、Flow Director、服务质量、虚拟化流分类的方式、流过滤
流分类技术的使用:DPDK结合网卡Flow Director功能、DPDK结合网卡虚拟化及cloud Filter功能、可重构匹配表
9、Intel 硬件功能
知识点包括:网卡硬件卸载功能、DPDK软件接口、硬件与软件功能实现、分片组包卸载
计算及更新功能卸载:VLAN硬件卸载、IEEE1588硬件卸载功能、IP TCP/UDP/SCTP checksum硬件卸载功能、Tunnel硬件卸载功能
10、X86平台的IO虚拟化
知识点包括:PCIe网卡透传下的收发包流程、I/O透传虚拟化配置
X86平台虚拟化概述:CPU虚拟化、内存虚拟化、I/O虚拟化
I/O透传虚拟化:Intel VT-d、PCI SR-IOV
11、半虚拟化Virtio
知识点包括:Virtio使用
Virtio规范和原理:设备的配置、虚拟队列的配置、设备的使用
Virtio网络设备驱动设计:Virtio网络设备Linux内核驱动设计、基于DPDK用户空间Virtio网络设备驱动设计
12、加速包处理的vhost优化方案
知识点包括vhost的演进和原理:Qemu与Virtio-net、Linux内核态vhost-net、用户态vhost
基于DPDK的用户态vhost设计:消息机制、地址转换和映射虚拟机内存、vhost特性协商、virtio-net设备管理、vhost中的Checksum和TSO功能卸载
DPDK vhost编程实例:报文收发接口、使用DPDK vhost lib、使用DPDK vhost PMD
13、DPDK与网络功能虚拟化
知识点包括:网络功能虚拟化、OPNFV与DPDK、NFV的部署、
VNF自身特性的评估:性能分析方法论、性能优化思路
VNF的设计:VNF虚拟网络接口的选择、IVSHMEM共享内存的PCI设备、网卡轮询和混合中断轮询模式的选择、硬件加速功能的考虑、服务质量的保证
实例分析和商业案例:Virtual BRAS、Brocade vRouter 5600
14、Open vSwitch中的DPDK性能加速
知识点包括:虚拟交换机、OVS
DPDK加速的OVS:OVS的数据通路、DPDK加速的数据通路、DPDK加速的OVS性能
15、基于DPDK的存储软件优化
知识点包括:基于以太网的存储系统、以太网存储系统的优化
SPDK介绍:基于DPDK的用户态TCP/IP栈、用户态存储驱动、SPDK中iSCSI target实现与性能
九、全方位分析Linux内核代码专栏
1、进程管理和调度
知识点包括:进程的优先级、进程生命周期
进程表示:进程类型、命名空间、进程ID号、进程关系
进程管理相关的系统调:进程复制、内核线程、启动新进程、退出进程
调度器的实现:概观、数据结构、处理优先级、核心调度器
完全公平调度类:数据结构、CFS操作、队列操作、选择下一个进程、处理周期性调度器、唤醒抢占、处理新进程
实时调度类:性质、数据结构、调度器操作
调度器增强:SMP调度器、调度域和控制组、内核抢占和低延迟相关工作
2、内存管理
知识点包括(N)UMA模型中的内存组织:概述、数据结构
页表:数据结构、页表项的创建和操作
初始化内存管理:建立数据结构、特定于体系结构的设置、启动过程期间的内存管理
物理内存管理:伙伴系统的结构、避免碎片、初始化内存域和结点数据结构、分配器API、分配页、释放页、内核中不连续页的分配、内核映射
slab分配器:备选分配器、内核中的内存管理、slab分配的原理、实现、通用缓存
3、进程虚拟内存
知识点包括:内存映射的原理
进程虚拟地址空间:进程地址空间的布局、建立布局
数据结构:树和链表、虚拟内存区域的表示、优先查找树
对区域的操作:将虚拟地址关联到区域、区域合并、插入区域、创建区域
内存映射:创建映射、删除映射、非线性映射
反向映射:数据结构、建立逆向映射、使用逆向映射
用户空间缺页异常的校正:按需分配/调页、匿名页、写时复制、获取非线性映射
4、设备驱动程序
知识点包括访问设备:设备文件、字符设备、块设备和其他设备、使用ioctl进行设备寻址、主从设备号的表示、注册
与文件系统关联:inode中的设备文件成员、标准文件操作、用于字符设备的标准操作、用于块设备的标准操作
字符设备操作:表示字符设备、打开设备文件、读写操作
块设备操作:块设备的表示、数据结构、向系统添加磁盘和分区、打开块设备文件、请求结构、BIO、提交请求、I/O调度、ioctl的实现
资源分配:资源管理、I/O内存、I/O端口
总线系统:通用驱动程序模型、PCI总线、USB
5、虚拟文件系统
知识点包括:文件系统类型
通用文件模型:inode、链接、编程接口、将文件作为通用接口
proc文件系统:/proc的内容、数据结构、初始化、装载proc文件系统、管理/proc数据项、进程相关的信息、系统控制机制
简单的文件系统:顺序文件、用libfs编写文件系统、调试文件系统、伪文件系统
sysfs:数据结构、装载文件系统、、文件和目录操作、向sysfs添加内容
VFS的结构:结构概观、inode、特定于进程的信息、文件操作、目录项缓存
处理VFS对象:文件系统操作、文件操作
标准函数:通用读取例程、失效机制、权限检查
6、系统调用
知识点包括系统程序设计基础:追踪系统调用、支持的标准、重启系统调用
中断:中断类型、硬件IRQ、处理中断、数据结构、中断电流处理、初始化和分配IRQ、处理IRQ
软中断:开启软中断处理、软中断守护进程
tasklet:创建tasklet、注册tasklet、执行tasklet
等待队列和完成量:等待队列、完成量、工作队列
系统调用的实现:系统调用的结构、访问用户空间、追踪系统调用
7、页面回收和页交换
知识点包括:交换令牌、数据回写
概述:可换出页、页颠簸、页交换算法
Linux内核中的页面回收和页交换:交换区的组织、检查内存使用情况、选择要换出的页、处理缺页异常、减缩内核缓存
管理交换区:数据结构、创建交换区、激活交换区
交换缓存:标识换出页、交换缓存的结构、添加新页、搜索一页
页面回收:概述、数据结构、确定页的活动程度、收缩内存域、隔离LRU页和集中回收、收缩活动页链表、回收不活动页
处理交换缺页异常:换入页、读取数据、交换预读
发起内存回收:kswapd进行周期性内存回收、在严重内存不足时换出页
收缩其他缓存:数据结构、注册和删除收缩器、收缩缓存
文末整体的思路图分享给大家,清晰版可以后台私信我获取