浏览器工作原理与实践pdf_图解浏览器的基本工作原理

本文详细介绍了浏览器的多进程架构,包括Browser Process、Renderer Process、Plugin Process和GPU Process及其职责。Chrome的多进程架构提高了安全性且避免了单一进程故障影响整个浏览器。浏览器导航过程涉及UI、网络和存储线程。渲染进程主要任务由主线程、工作线程、排版线程和光栅线程完成,包括DOM构建、资源加载、JS执行和绘制。浏览器还优化了事件处理以提升性能。
摘要由CSDN通过智能技术生成
53369aac59c22e9e06edb8e0869934f5.png 作者 | zhangwang来源 | https://zhuanlan.zhihu.com/p/47407398 可能每一个前端工程师都想要理解浏览器的工作原理。 我们希望知道从在浏览器地址栏中输入 url 到页面展现的短短几秒内浏览器究竟做了什么; 我们希望了解平时常常听说的各种代码优化方案是究竟为什么能起到优化的作用; 我们希望更细化的了解浏览器的渲染流程。
浏览器的多进程架构
一个好的程序常常被划分为几个相互独立又彼此配合的模块,浏览器也是如此,以 Chrome 为例,它由多个进程组成,每个进程都有自己核心的职责,它们相互配合完成浏览器的整体功能,每个进程中又包含多个线程,一个进程内的多个线程也会协同工作,配合完成所在进程的职责。 对一些前端开发同学来说,进程和线程的概念可能会有些模糊,为了更好的理解浏览器的多进程架构,这里我们简单讨论一下进程和线程。
进程(process)和线程(thread)
c1e7a82bc0ebb2d0dfde4b3f688b731e.png 进程就像是一个有边界的生产厂间,而线程就像是厂间内的一个个员工,可以自己做自己的事情,也可以相互配合做同一件事情。
当我们启动一个应用,计算机会创建一个进程,操作系统会为进程分配一部分内存,应用的所有状态都会保存在这块内存中,应用也许还会创建多个线程来辅助工作,这些线程可以共享这部分内存中的数据。如果应用关闭,进程会被终结,操作系统会释放相关内存。更生动的示意图如下: 进程(process)和线程(thread) 一个进程还可以要求操作系统生成另一个进程来执行不同的任务,系统会为新的进程分配独立的内存,两个进程之间可以使用 IPC (Inter Process Communication)进行通信。很多应用都会采用这样的设计,如果一个工作进程反应迟钝,重启这个进程不会影响应用其它进程的工作。 进程间通过 IPC 通信 如果对进程及线程的理解还存在疑惑,可以参考下述文章。 进程与线程的一个简单解释 - 阮一峰的网络日志:http://www.ruanyifeng.com/blog/2013/04/processes_and_threads.html
浏览器的架构
有了上面的知识做铺垫,我们可以更合理的讨论浏览器的架构了,其实如果要开发一个浏览器,它可以是单进程多线程的应用,也可以是使用 IPC 通信的多进程应用。
df8d27c3d06c00150168ef2574c22ec5.png 不同浏览器的架构模型
不同浏览器采用了不同的架构模式,这里并不存在标准,本文以 Chrome 为例进行说明 : Chrome 采用多进程架构,其顶层存在一个 Browser process 用以协调浏览器的其它进程。
0f75cb87be36b7071f38713c6100da50.png Chrome 的不同进程
具体说来,Chrome 的主要进程及其职责如下:
  • Browser Process:

  1. 负责包括地址栏,书签栏,前进后退按钮等部分的工作;

  2. 负责处理浏览器的一些不可见的底层操作,比如网络请求和文件访问;

  • Renderer Process:

  1. 负责一个 tab 内关于网页呈现的所有事情

  • Plugin Process:

  1. 负责控制一个网页用到的所有插件,如 flash

  • GPU Process

  1. 负责处理 GPU 相关的任务

e87371ee430654a9ffd906b7df5e2751.png 不同进程负责的浏览器区域示意图
Chrome 还为我们提供了「任务管理器」,供我们方便的查看当前浏览器中运行的所有进程及每个进程占用的系统资源,右键单击还可以查看更多类别信息。 通过「页面右上角的三个点点点 —- 更多工具 —- 任务管理器」即可打开相关面板,
a71d53b36e33d4defc81010beffde469.png Chrome 任务管理器面板
Chrome 多进程架构的优缺点
优点
  1. 某一渲染进程出问题不会影响其他进程

  2. 更为安全,在系统层面上限定了不同进程的权限

缺点 由于不同进程间的内存不共享,不同进程的内存常常需要包含相同的内容。 为了节省内存,Chrome 限制了最多的进程数,最大进程数量由设备的内存和 CPU 能力决定,当达到这一限制时,新打开的 Tab 会共用之前同一个站点的渲染进程。 Chrome 多进程架构的优缺点
测试了一下在 Chrome 中打开不断打开知乎首页,在 Mac i5 8g 上可以启动四十多个渲染进程,之后新打开 tab 会合并到已有的渲染进程中。
Chrome 把浏览器不同程序的功能看做服务,这些服务可以方便的分割为不同的进程或者合并为一个进程。以 Broswer Process 为例,如果 Chrome 运行在强大的硬件上,它会分割不同的服务到不同的进程,这样 Chrome 整体的运行会更加稳定,但是如果 Chrome 运行在资源贫瘠的设备上,这些服务又会合并到同一个进程中运行,这样可以节省内存,示意图如
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值