读《Chrome源码剖析》,对其架构设计有感
【摘要】 愿打开此篇对你有所帮助。嗯,站在巨人的肩膀上,虽然是十年前的巨人吧。在那篇长达两万多字加几十张图片的文章中,我看到了两个很熟悉的身影:nginx采用的多进程模型和moduo网络库采用的reactor模型,果然技术都是互通有无的。@[toc] 前言它是如何利用多进程(其实也会有多线程一起)做并发的,又是如何解决多进程间的一些问题的,比如进程间通信,进程的开销;它的整体框架是怎样,有没有很NB的...
愿打开此篇对你有所帮助。
嗯,站在巨人的肩膀上,虽然是十年前的巨人吧。
在那篇长达两万多字加几十张图片的文章中,我看到了两个很熟悉的身影:nginx采用的多进程模型和moduo网络库采用的reactor模型,果然技术都是互通有无的。
@[toc]
前言
- 它是如何利用多进程(其实也会有多线程一起)做并发的,又是如何解决多进程间的一些问题的,比如进程间通信,进程的开销;
- 它的整体框架是怎样,有没有很NB的架构思想;
- 它如何实现跨平台的UI控件系统;
谷歌Chrome/Chromium的多进程架构
此外,通过out of process plugins(OOPP)功能将所有的插件进程(如Flash、Java、PDF阅读器等)与的浏览器进程隔离,进而提升Chrome浏览器的安全性。
有没有一种 nginx 架构的感觉。
Chrome 的线程模型
reactor 了解一下。宗旨为:尽量少加锁!!!
Task 的执行模型:
如果你熟悉设计模式,你会发现这是一个Command模式,将创建于执行的环境相分离,在一个线程中创建行为,在另一个线程中执行行为。
进程间通信方式
有名管道。
Chrome的进程通信,最核心的特点,就是利用消息循环来检查信号量,而不是直接让管道阻塞在某信号量上。
就说到这儿吧,其实我就是觉得跟nginx和muduo有点熟悉,这俩模型是挺常用哈,性能也摆在明面上了。
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)