这是我参与「第三届青训营 -后端场」笔记创作活动的的第4篇笔记。
Docker
环境配置中的几个问题
-
描述:HTTP/2 stream 1 was not closed cleanly before end of the underlying stream
原因:http版本不对
解决:git config --global http.version HTTP/1.1 -
docker run 失败后,名称仍然保留
docker ps -a
docker rm name
Docker作用
Docker 的主要用途,目前有三大类。
- 提供一次性的环境。比如,本地测试他人的软件、持续集成的时候提供单元测试和构建的环境
- 提供弹性的云服务。因为 Docker 容器可以随开随关,很适合动态扩容和缩容
- 组建微服务架构。通过多个容器,一台机器可以跑多个服务,因此在本机就可以模拟出微服务架构
WSL2/Hiper-V
两者均为虚拟机的替代方案,VM-ware占用大量的资源,维护不便。
计算机网络
免费ARP和代理ARP
新增服务器,无需请求直接通知告知MAC ipv6 ARP代理,扩充边界(劫持ARP代理,) NAT映射内网用户到外网IP和端口
DNS
递归迭代,www.douyin.com 请求根服务器、顶级域服务器(com)、douyin.com返回,基于UDP IP分片、MTU传输限制
HTTP/HTTP1.1
主要 长连接 keepalive包头
网络架构给抖音提升质量
HTTP2.0
并发下载 -> 多路复用 TCP连接通道中有多个stream
QUIC/HTTP3.0
需要针对HTTP需求改进TCP,但TCP其他软件也在用(不可插拔)基于UDP
基于用户态,内核态需要对不同的操作系统实现不同方案
0 RTT
弱网优势(队头阻塞)
路径提速
- 数据中心分布式
- 同运营商访问(解析域名,客户端IP)
- CDN 静态资源路径优化(缓存)
- 动态API(播放/评论接口)路径优化(DSA) 拓扑探测
网络稳定-容灾
故障发生-故障感知-自动切换-服务恢复
- 内部机房专线/外网容灾
- 主备切换
- 云控 app中存在SDK 主动/降级容灾
- 缓存响应
故障明确
什么业务什么接口故障? 故障体现在哪里? 访问其他目标是否正常? 是否是修改导致的故障 回退?
分段排查
客户端->服务端排查->中间链路排查
故障排查常用命令
dig查DNS问题 ping/telnet/nmap查询三层四层连通性 tracert排查中间链路 iptabels查防火墙 tcpdump抓包