0. 总框架

方法:先从厚读薄,再从薄感受到小细节

第1阶段,c语言层面

(1) c语言基本语法:结构体、指针、宏

(2) 数据结构和算法:hash,rbtree,b/b+tree,linked list(链表)

1.2.1-1部分数据结构的说明-CSDN博客

1.2.1-2部分数据结构的说明02_链表-CSDN博客

(3) 设计模式:单例,策略,观察者,工厂,迭代器模式,过滤器

(4) 库:stl,c++新特性

(5) linux的命令:makefile/cmake,git/svn, 看内存,看网络状态(netstat),看磁盘,比如(htop,top),tcp抓包(tcpdump),测试(iperf)

1.5-1 linux的部分基础命令01-CSDN博客

第2阶段,网络层面

(1) 网络的代码怎么写:管理io的io多路复用(select/poll/epoll),多线程多进程结合业务怎么做,阻塞/非阻塞,同步/异步,来了数据后的业务如何做 → 量化指标:实现网络框架(你的设计理念,你的做法,你的适配业务,把性能参数调节好,很有必要)

2.1.1 网络io-CSDN博客

2.1.2 网络io多路复用-CSDN博客

2.1.3-1 第一次Reactor代码(流程梳理)-CSDN博客

2.1.3-2 webserver和websocket(reactor 怎么用)_webserver和websocketserver-CSDN博客

2.1.3-3 第二次Reactor代码(百万并发测试过程的报错信息)-CSDN博客

2.1.4 posix api_socket api属于posix吗-CSDN博客

2.1.5-1 协程设计原理与汇编实现-01-CSDN博客

2.1.5-2 协程设计原理与汇编实现-02-CSDN博客

2.1.6-1 dpdk的环境设置_dpdk网卡有几个队列-CSDN博客

2.1.6-2 dpdk收发数据代码实现-CSDN博客

2.1.6-3 DPDK实现TCP的三次握手的代码说明-CSDN博客

2.1.6-4 用DPDK实现TCP协议栈并发-CSDN博客

2.1.7-1 io_uring的使用-CSDN博客

2.1.7-2 io_uring与epoll的对比-CSDN博客

2.1.8 epoll的实现原理-CSDN博客

(2) 网络的原理:eth(以太网),ip,udp/tcp(可扩展的),http(可扩展的) → 量化指标: 实现tcp协议栈(很有必要)

第3阶段,基础组件(日常的轮子,要有造轮子的能力,也要有不造轮子的觉悟)

就是软件设计的固定模式,知道20-30个轮子如何实现,以后看代码会感觉似曾相识

(1) 内存池

(2)线程池

(3)数据库连接池

(4)请求池

(5)原子操作

(6)ringbuffer

(7)无锁队列定时器方案

(8)死锁检测

(9)内存泄漏

(10)日志

(11)网络块

(12)共享内存的做法

(13)probuf协议

第4阶段,中间件(形成自己的技术栈,有自己的思路当时解决业务的问题)

(1) redis(缓存)

(2)MySQL(持久化存储,关系数据库)

(3)Nginx(网关开发)

(4)grpc(服务和服务之间调度,一般服务和服务之间调度选择rpc分布式)

(5)mq(消息队列)

第5阶段,适配行业的开源框架

(1) skynet(用于游戏行业)

(2)openresty(用于cdn/waf)

(3)spdk(用于存储)

(4)dpdk(用于网络)

(5)cuda(高性能计算,gpu计算)

(6)workflow(网络编程范式)

第6阶段,devops(运维和部署)是站在产品的角度

(1) docker

(2) k8s

第7阶段,性能分析

(1)内核要足够了解,比如进程调度,内存管理,文件系统。 针对于(a)磁盘(b)网络(c)内存

(2)bpf/ebpf

(3)火焰图

(4)中间件

(5)gtest

第8阶段,分布式(作为技术扩展)

(1)分布式数据库TiDB

(2)分布式文件系统ceph

(3)分布式协同etcd

第9阶段,经历几个项目

相关推荐
嘿黑嘿呦3 天前
chap 8排序
算法·蓝桥杯·排序算法·软件工程
旧曲重听13 天前
2026前端技术从「夯」到「拉」
前端·程序人生·职场和发展·软件工程
承渊政道3 天前
飞算JavaAI 智能引导背后的多 Agent 协作机制解析:从老旧 Java 后台升级到可运行工程
java·开发语言·spring boot·安全·intellij-idea·软件工程·ai编程
apcipot_rain3 天前
计科八股20260616(1)——堆存中位数、链表判环、黑白测试、敏捷开发与瀑布模型、配置管理、持续集成、池化
数据结构·算法·软件工程
lisw054 天前
【计算机科学技术】路由器(route):概念、历史、内容与战略!
机器学习·智能路由器·软件工程
培培说证4 天前
大数据、人工智能、计算机、软件工程,到底怎么选?
大数据·人工智能·软件工程
文艺倾年4 天前
【强化学习】MDP、贝尔曼方程与CartPole 编程,20W字总结(二)
人工智能·软件工程·强化学习
郝学胜-神的一滴5 天前
CMake 017:彩色日志输出实战
linux·c语言·开发语言·c++·软件工程·软件构建·cmake
小程故事多_805 天前
AI软件工程范式革命,终结五十年的“手工伪工程”时代
人工智能·软件工程
精益数智小屋5 天前
项目管理看板如何拆解任务进度?项目管理看板解决跨部门协作难题
大数据·人工智能·数据分析·云计算·软件工程