WSL环境部署和网络优化|青训营笔记

288 阅读2分钟

这是我参与「第三届青训营 -后端场」笔记创作活动的的第4篇笔记。

Docker

环境配置中的几个问题

  1. 描述:HTTP/2 stream 1 was not closed cleanly before end of the underlying stream
    原因:http版本不对
    解决:git config --global http.version HTTP/1.1

  2. docker run 失败后,名称仍然保留

docker ps -a  
docker rm name

Docker作用

Docker 的主要用途,目前有三大类。

  1. 提供一次性的环境。比如,本地测试他人的软件、持续集成的时候提供单元测试和构建的环境
  2. 提供弹性的云服务。因为 Docker 容器可以随开随关,很适合动态扩容和缩容
  3. 组建微服务架构。通过多个容器,一台机器可以跑多个服务,因此在本机就可以模拟出微服务架构

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 弱网优势(队头阻塞)

路径提速

  1. 数据中心分布式
  2. 同运营商访问(解析域名,客户端IP)
  3. CDN 静态资源路径优化(缓存)
  4. 动态API(播放/评论接口)路径优化(DSA) 拓扑探测

网络稳定-容灾

故障发生-故障感知-自动切换-服务恢复

  1. 内部机房专线/外网容灾
  2. 主备切换
  3. 云控 app中存在SDK 主动/降级容灾
  4. 缓存响应

故障明确

什么业务什么接口故障? 故障体现在哪里? 访问其他目标是否正常? 是否是修改导致的故障 回退?

分段排查

客户端->服务端排查->中间链路排查

故障排查常用命令

dig查DNS问题 ping/telnet/nmap查询三层四层连通性 tracert排查中间链路 iptabels查防火墙 tcpdump抓包