2020-07-02:在浏览器输入一个url后按回车,会发生什么?
福哥答案2020-07-02:
简单回答:
- 域名解析。
- 建立TCP连接。
- 请求。
- 处理。
- 响应。
- 释放TCP连接。
- 页面渲染。
中级回答:
- 域名解析
- 浏览器DNS缓存。
- 操作系统DNS缓存。
- 路由器缓存。
- ISP 服务商缓存。
- 根服务器递归查询。
- 建立TCP连接。三次握手。
- 请求。
请求报文格式: - 请求行。
请求方式、url、版本,比如 POST index.html / HTTP/1.1。
- 请求行。
- 请求头。
键值对,比如Connection: Keep-Alive。
- 请求头。
- 空行。
- 请求体。
- 4.1. 键值对,比如Pn=2&kw=nba。
- 4.2. 分隔符上传文件。
Content-Type:multipart/form-data;boundary=-----------------------------7db372eb000e2
和
-------------------------------7db372eb000e2
Content-Disposition: form-data; name="file"; filename="kn.jpg"
Content-Type: image/jpeg
(此处省略jpeg文件二进制数据...)
4. 处理。
5. 响应。
响应报文格式:
5.1. 响应行。
版本、状态码、描述。比如 HTTP/1.1 200 OK。
5.2. 响应头。
键值对,比如 Content-Length: 122。
5.3. 空行。
5.4. 响应体。
6. 释放TCP连接。四次挥手。
7. 页面渲染。
7.1. 构建dom树。
7.2. 构建CSSOM 树。
7.3. 构建渲染树。
7.4. 布局计算。
7.5. 渲染呈现。
有那些网站优化的方法?
①减少DNS查询:将服务器域名的ip信息加入本地host文件。
②减少http请求数量,对于图片使用雪碧图,对于html文件和css文件,js文件分别进行合并操作。
③减少下载时间:压缩图片,使用压缩应用压缩文档中的空格,删除文件多余的语句和注释,创造自己的js精简库和精简框架,使用本地浏览器缓存。
④提前渲染开始时间:将css链接放在html头部。
⑤减轻解析器的阻塞:将js链接放在body尾部。
公众号:福大大架构师每日一题
分类:
福大大架构师每日一题
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具