首页 > 其他分享 >前端进阶——浏览器篇

前端进阶——浏览器篇

时间:2024-08-15 20:26:28浏览次数:18  
标签:浏览器 进阶 渲染 前端 线程 进程 架构 页面

 浏览器如何工作(一)进程架构 

浏览器的工作过程复杂而高效,其核心在于其进程架构的设计。以下是对浏览器进程架构的详细解析:

一、浏览器的主要进程

现代浏览器大多采用多进程多线程的架构,以Chrome浏览器为例,其主要进程包括:

  1. 浏览器进程(Browser Process)
    • 功能:作为浏览器的主进程,负责浏览器的整体控制和资源协调,包括用户界面的展示(如地址栏、书签栏等)、网络请求的管理、以及与其他进程的通信等。
    • 关键线程
      • UI线程:控制浏览器上的按钮及基础界面的展示。
      • 网络线程(Network Thread):主要用于处理网络请求,如DNS解析、建立TLS连接等。
      • 存储线程(Storage Thread):用于控制文件访问。
      • IO线程:主要用于进程间通信。
  2. 渲染进程(Renderer Process)
    • 功能:负责页面的渲染工作,包括HTML、CSS的解析,JavaScript的执行,以及页面的布局和绘制等。
    • 数量:通常每个标签页对应一个渲染进程,但也可能根据浏览器的优化策略有所不同(如Process-per-site-instance、Process-per-site等模式)。
    • 关键线程
      • GUI渲染线程:负责页面的渲染工作,如解析HTML和CSS、构建DOM树、CSSOM树、Render树,以及绘制页面等。
      • JavaScript引擎线程:负责解析和执行JavaScript代码,与GUI渲染线程互斥。
      • 定时器线程:处理setIntervalsetTimeout等定时器任务,计时完毕后将任务添加到事件队列中等待JavaScript引擎线程执行。
      • 异步HTTP请求线程:当发起网络请求时,浏览器会新开一个线程来处理这些请求,并在请求状态变化时将回调放入事件队列中。
      • 事件触发线程:用于控制事件循环,将任务添加到事件队列中,并在适当的时候将其分发给JavaScript引擎线程执行。
  3. GPU进程(GPU Process)
    • 功能:负责处理与图形渲染相关的任务,如将渲染进程计算出的图像帧绘制在屏幕上。
  4. 插件进程(Plugin Process)
    • 功能:负责运行浏览器插件,如Flash插件等。这些插件通常运行在独立的进程中,以提高安全性和稳定性。

二、浏览器的工作流程

从用户输入URL到页面展示的过程大致如下:

  1. 处理输入:用户在地址栏输入URL并按下回车后,UI线程会判断输入内容是否为URL,并交给网络线程处理。

  2. 网络请求:网络线程进行DNS解析、建立TLS连接等网络操作来请求对应资源。如果收到服务器重定向头部,则与UI线程沟通并发起新的请求。

  3. 读取响应:网络线程收到服务器响应后,解析HTTP报文并根据响应头Content-Type确定响应主体类型。如果是HTML文件,则交给渲染进程处理;如果是其他文件,则交给下载管理器或相应处理模块。

  4. 页面渲染:渲染进程接收到HTML数据后,开始解析HTML内容并构建DOM树和Render树。随后进行页面布局和绘制,并将图像帧交给GPU进程绘制在屏幕上。

  5. 事件处理:在渲染过程中,如果遇到JavaScript代码或用户交互事件(如点击、滚动等),则会将这些事件添加到事件队列中等待JavaScript引擎线程处理。

  6. 页面更新:当JavaScript引擎线程空闲时,会从事件队列中取出任务执行,并可能导致DOM树的更新和页面的重新渲染。

通过以上进程和线程的协同工作,浏览器能够高效地处理用户的网络请求并展示丰富的网页内容。

下面搬运自前端大佬(偶像cos02)©归cos02,若有侵权,立即删除

浏览器的核心功能

浏览器,“浏览” 是这个产品的核心,浏览无非分为两步:

  1. 获取想浏览的资源
  1. 展示得到的资源

现代浏览器还增加了交互功能,这涉及到脚本运行。因此,理解浏览器的核心就是理解其三大引擎如何工作:

  • 网络引擎
  • 渲染引擎
  • 脚本引擎

浏览器架构的选择:单进程 vs 多进程

在设计浏览器这样复杂的程序时,我们面临两种基本结构的选择:

  1. 单进程 + 多线程:所有功能集中在一个进程中,通过多线程实现各个功能。
  1. 多进程 + 每个进程少量线程 + IPC 通信:核心服务被抽离成独立进程,进程间通过 IPC 通信。

选择哪种结构,这是一个值得考虑的问题。我们可以想想各自的优缺点:

单进程结构:

优点:

  1. 内存效率高,多个线程共享一个进程的内存开销
  1. 通信效率高,线程之间由于可以访问公共内存,通信开销较小

缺点:

  1. 稳定性差,一个线程挂掉可能引起整个进程挂掉(对于浏览器而言,这是致命的,比如一个页面挂掉,可能导致整个浏览器挂掉)
  1. 安全性差,进程之间可以访问公共内存,页面之间难以实现有效的沙箱隔离
  1. 可拓展性差,功能越多,意味着一个进程越来越大庞大,耦合难以避免的变多

多进程结构:

优点:

多进程程序解决了单进程的一些缺点

  1. 稳定性:一个进程挂了不会引起其他进程(一个页面挂了不会影响其他页面)
  1. 安全性:进程之间天然隔离,可以实现更严格的沙箱
  1. 利用现代 CPU:多进程可以更好的使用现代多核 CPU
  1. 拓展性:将各个模块抽离成一些独立的进程,实现解藕,单独维护

缺点:

  1. 更多的资源(内存,I/O,CPU时钟)消耗
  1. 更多的进程通信(IPC)开销

浏览器架构的历史演变

在回看一个产品时,不要脱离其历史背景。

早期的浏览器,功能简单,且计算机内存资源昂贵,此时单进程的设计也许更合理。

但随着人类社会的发展,计算资源相对宽裕,计算能力大幅度提升,且用户的复杂了很多,此时,多进程的结构更加合理。

1990年代单进程架构内存资源昂贵简单的网页内容2000年代初单进程多线程网页开始复杂化多核处理器出现2008年Chrome发布多进程架构硬件性能提升内存成本下降2010年代多进程架构普及移动设备兴起网页应用复杂度大增现在持续优化的多进程架构智能资源管理云计算和边缘计算的影响浏览器架构的演变

浏览器架构的选择与其所处的时代背景密切相关:

  • 早期:功能简单,计算机资源昂贵,单进程设计更合理。
  • 现代:计算资源丰富,用户需求复杂,多进程结构更加适合。

现代多进程浏览器架构

前面提到,现代浏览器使用多进程的架构模式。

以我的 Chrome 浏览器举例:

  • 浏览器主进程:
    • 程序 UI(地址栏,书签栏,前进后退按钮)
    • 管理标签和窗口
    • 协调其他进程
    • 网络请求相关
  • GPU 进程:
    • 处理 GPU 任务,加速渲染
    • 处理 OpenGL 和 2D 绘图操作
    • 将渲染进程的绘制命令转为 GPU 命令
  • 实用工具进程:
    • 浏览器将一些特定的任务封装为了独立的进程,比如音频处理,文件解压,存储
  • 渲染进程
    • 浏览器会尽力为每个标签页提供一个独立的渲染进程
    • 解析和渲染网页资源
  • 拓展进程
    • 现代浏览器通过插件扩展功能,为了安全性,每个插件运行在一个独立的进程中

 

Chrome架构进化的目标是将整个浏览器程序的不同部分服务化,便于分割或合并。

前面提到,多进程架构会引起更多的内存和计算开销,所以 chrome 选择了更灵活的方式:

基本思路是:

  • 在高配设备中,每个服务独立开进程,保证稳定;
  • 在低配设备中,多个服务合并为一个进程,节约资源。同样的思路也应用到了Android上。

结语

一个应用的设计与其时代背景有关,技术的推进本质是用户需求的推进。而 Chrome 架构设计也充分体现了一个灵活的架构的优势。

 

标签:浏览器,进阶,渲染,前端,线程,进程,架构,页面
From: https://blog.csdn.net/m0_55049655/article/details/141230905

相关文章

  • 浏览器后门:保护影子 IT 的新前线
    浏览器扩展是网络犯罪分子的主要目标。这不仅仅是消费者的问题,也是企业对抗影子IT的新领域。最终,扩展权限越多,攻击面就越大。研究表明,平均每个企业的生态系统中都有近1500个浏览器扩展程序-即使是一个不良插件也可能导致声誉、财务和隐私问题。展望未来,管理员需要加......
  • 普元EOS-微前端项目创建
    1前言普元EOS采用微服务和微前端的思想来进行项目架构管理。核心是Afcenter,这是框架的基座。Afcenter叫做应用联邦中心,提供了最核心的功能和服务,比如组织架构管理、人员账号管理、权限管理等等。其他各功能都被开发为微服务(后端)和微前端(前端),然后整合到AFCenter中,最终形......
  • SQL进阶技巧:数据清洗如何利用组内最近不为空的数据填充缺失值。【埋点日志事件缺失值
    目录0引言1问题描述2数据准备 3问题分析4小结0引言  在用户行为分析中,我们往往需要对用户浏览行为进行分析或获客的渠道进行分析,在埋点日志中用户一个session中会浏览不同的界面,会进行url的跳转,在前端埋点时,往往将用户刚进入界面时的url进行存储,后续在当前......
  • axios访问后端,及后端返回前端报错跨域问题
    packagecom.example.demo.test.config;importorg.springframework.util.StringUtils;importjavax.servlet.*;importjavax.servlet.annotation.WebFilter;importjavax.servlet.http.HttpServletRequest;importjavax.servlet.http.HttpServletResponse;importjav......
  • Selenium 操作已打开的浏览器
    偶尔要用到,startwriting实现步骤先启动Chrome,打开任务管理器,找到chrome.exe,地址栏输入cmd,然后执行chrome.exe--remote-debugging-port=12345看!!!12345端口开了没netstat-aon|findstr"12345"开了,你就连呗~开始指挥你的浏览器~~~往左走,往右走from......
  • 前后端分离但人不分离:IDEA+VUE创建springboot项目和对应的前端项目
    参考链接:尚硅谷IDEA安装idea实战教程(百万播放,新版来袭)_哔哩哔哩_bilibiliIntelliJIDEA的使用指南,最简单的idea使用教程【适合初学者小白】_哔哩哔哩_bilibiliSpringBoot项目后端开发逻辑梳理总结_一个springboot项目,解释目录bean、controller、dao、service-CSDN博客Sp......
  • MemFire Cloud,前端开发新纪元
    在前端开发的世界里,每年都会涌现出各种各样的新技术和工具,但真正能够改变游戏规则的却寥寥无几。而MemFireCloud,就是这样一款能够引领前端开发新纪元的工具。一站式开发神器,懒人的福音对于开发者来说,最烦人的事情莫过于不断地搭建服务、配置环境和开发接口API。这些繁琐......
  • nginx的功能?部署前端代码的步骤?负载均衡的功能,说一下。
    nginx的功能?部署前端代码的步骤?负载均衡的功能,说一下。使用Nginx部署前端项目的详细步骤作者:rousong2024.01.2920:50浏览量:423使用Nginx部署前端项目的详细步骤(baidu.com)简介:本文将介绍使用Nginx部署前端项目的详细步骤,包括下载和安装Nginx、配置Nginx、部署前端项目等。......
  • 【二叉树进阶】--- 二叉搜索树转双向链表 && 最近公共祖先
     Welcometo9ilk'sCodeWorld    (๑•́₃•̀๑) 个人主页:     9ilk(๑•́₃•̀๑) 文章专栏:   数据结构本篇博客我们继续了解一些二叉树的进阶算法。......
  • 进阶 Java冒泡排序递归法 有点难度哦
    简介这里有用到递归的冒泡排序思路,难度对新手很大,不明白递归和冒泡排序的小伙子可以先看看我的其他两个文章。连接在这里:Java冒泡排序https://blog.csdn.net/ouhexie/article/details/140985984?spm=1001.2014.3001.5501Java递归算法https://blog.csdn.net/ouhexie/articl......