博客
关于我
Chromium与CEF的多进程模型及相关参数
阅读量:123 次
发布时间:2019-02-26

本文共 1936 字,大约阅读时间需要 6 分钟。

CEF进程模型概述

CEF(Chromium Embedded Framework)基于Chromium引擎,采用多进程模型进行渲染和处理。关于其进程模型的实现,可以参考Chromium源码中的content/public/common/content_switches.cccontent/app/content_main_runner.cc文件。

在CEF中,进程类型主要包括:

  • browser(浏览器进程):默认情况下,当没有指定type参数时,CEF会创建一个浏览器进程来处理主渲染任务。
  • renderer(渲染进程):负责实际的渲染操作,通常与kRendererProcess相关联。
  • plugin(插件进程):用于处理特定类型的插件,如kPluginProcess
  • ppapi-broker(PPAPI中间件进程):用于管理和协调PPAPI插件的运行,通常与kPpapiBrokerProcess相关。
  • ppapi(PPAPI插件进程):负责具体的PPAPI插件实现,通常与kPpapiPluginProcess相关。
  • sandbox-ipc(沙盒IPC进程):用于跨进程通信,通常与kSandboxIPCProcess相关。
  • utility(实用进程):用于运行时间依赖的低层服务,通常与kUtilityProcess相关。
  • zygote(zygote进程,仅在Linux上使用):用于启动Chromium嵌入式框架的初始进程,通常与kZygoteProcess相关。
  • gpu-process(GPU进程):负责GPU渲染任务,通常与kGpuProcess相关。

在实际应用中,除了browserppapirenderer进程外,其他进程类型(如pluginppapi-brokersandbox-ipc等)的具体功能和作用可能会因项目需求而有所不同。

关于CEF的命令行参数,可以参考以下相关文件:

  • tests/cefclient/common/client_switches.cc
  • base/base_switches.cc
  • cef/libcef/common/cef_switches.cc
  • chrome/common/chrome_switches.cc(部分参数不适用)
  • content/public/common/content_switches.cc

CEF支持的多数Chromium命令行参数也适用于CEF,可以参考 Chromium官方文档以获取详细信息。

进程模型命令行参数

在使用CEF时,进程模型相关的命令行参数可以帮助你对不同进程的行为进行细粒度控制。以下是一些常见的进程模型参数:

  • –ppapi-in-process:在渲染进程内运行PPAPI插件。
  • –ppapi-out-of-process:将PPAPI插件运行在独立的PPAPI进程中。
  • –process-per-site:为每个网站分配独立的渲染进程。
  • –process-per-tab:为每个标签分配独立的渲染进程。
  • –site-per-process:强制为特定网站分配独立的渲染进程。
  • –force-in-process:在多进程模式下,强制某些服务在主进程运行,支持逗号分隔的服务列表。
  • –single-process:启用单进程模式,所有相关进程(如渲染进程、GPU进程等)合并在一个主进程中,但PPAPI插件仍会运行在独立的PPAPI进程中。
  • –renderer-process-limit:限制渲染进程的最大数量。

需要注意的是,在使用–single-process时,PPAPI插件仍会运行在独立的进程中。这意味着即使所有渲染相关的进程合并在一个主进程中,PPAPI插件仍然会作为独立的ppapi进程运行。

进程模型参数的组合使用

如果你需要在CEF中同时使用单进程模式和Chromium的新特性,可以通过组合命令行参数来实现。例如:

  • 为了实现rendererbrowserppapi三者合一,可以传递以下参数:
  • –single-process –ppapi-in-process
  • 如果需要rendererbrowser合一,而ppapi插件运行在独立的PPAPI进程中,可以传递以下参数:
  • –single-process –ppapi-out-of-process

需要注意的是,在使用–ppapi-out-of-process时,CEF会默认为type=ppapi参数。如果需要自定义PPAPI进程的类型,可以参考Chromium源码中的相关实现。

关于CEF3的多进程模型的稳定性问题,可以参考相关技术讨论和官方文档以获取更多信息。

转载地址:http://qhey.baihongyu.com/

你可能感兴趣的文章
NUUO网络视频录像机 css_parser.php 任意文件读取漏洞复现
查看>>
NVelocity标签使用详解
查看>>
nvidia-htop 使用教程
查看>>
oauth2-shiro 添加 redis 实现版本
查看>>
OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
查看>>
OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
查看>>
OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
查看>>
OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
查看>>
OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
查看>>
OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
查看>>
OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
查看>>
OAuth2.0_授权服务配置_密码模式及其他模式_Spring Security OAuth2.0认证授权---springcloud工作笔记145
查看>>
OAuth2.0_授权服务配置_资源服务测试_Spring Security OAuth2.0认证授权---springcloud工作笔记146
查看>>
OAuth2.0_环境介绍_授权服务和资源服务_Spring Security OAuth2.0认证授权---springcloud工作笔记138
查看>>
OAuth2.0_环境搭建_Spring Security OAuth2.0认证授权---springcloud工作笔记139
查看>>
oauth2.0协议介绍,核心概念和角色,工作流程,概念和用途
查看>>
OAuth2授权码模式详细流程(一)——站在OAuth2设计者的角度来理解code
查看>>
oauth2登录认证之SpringSecurity源码分析
查看>>
OAuth2:项目演示-模拟微信授权登录京东
查看>>
OA系统多少钱?OA办公系统中的价格选型
查看>>