开发者社区> 行者武松> 正文

如何选择一个适合自己的开源项目来阅读

简介:
+关注继续查看

人们都说, 阅读源码是提高编程水平的一个极好的方法, 但是如何找到一个适合自己阅读的源码, 就蛋疼的很。 优秀的开源项目非常多, 肯定是看不完的。 而且如果没有一个明确的目的, 只是因为火就看, 则事倍功半。

我更像一个后台开发程序员, 所以以下观点都基于后台程序员的视角出发。

从 Node.js 和 Tornado 出发

在几个月前, 我学习了 Tornado 框架并用来做了一个项目; 而 Node.js 则是最近几天才开始学的。 所以很可能会有说的不严谨的地方。

Tornado 是一个异步非阻塞服务器应用与轻量级Web框架的结合体。 Node.js 则是一个开源跨平台的运行环境(runtime environment)。 在我看来, Node.js 基本上就是一个服务器应用了, 因为这一部分和 Tornado 的服务器部分几乎是一模一样。

我们的问题主要是应该选择什么样的开源代码来阅读, 目前为止, 我们可以选择的项目有Tornado和Node.js了。 先不着急做出决定, 继续向深处探索一番。 首先化简问题, 因为 Node.js 的优势并非仅仅是异步非阻塞提供的高性能, 还有很多其他的东西, 我们暂时不管那些其他的部分。

  • Tornado = AIO Server + Web Framework

  • Node.js = AIO Server

如果学习过操作系统, 就会知道 Linux 下这两个程序之所以达到如此高性能的效果, 归功于 Linux 2。6 Kernel 提供的epoll。 我的思路是, Node.js 如果在 Linux 下运行, 一定会调用操作系统提供的 epoll; 如果在 Windows 下运行, 一定会调用操作系统提供的 IOCP。

顺着这个思路, 我发现了 libuv 和 pyuv 这两个开源项目。

  • libuv: 一般认为, libuv 是因 nodejs 而生。 libuv的作用是对用户隐藏操作系统的差异, 封装Linux的libev和 windows 的 IOCP 等等, 提供跨平台的异步操作库。

  • pyuv: 给 Python 提供一个调用 libuv 的接口

屡清关系

上面提到了nodejs, tornado, libuv, pyuv, libev, IOCP 这些概念(项目), 他们中大部分都可以找到开源代码, 如果想要从中选择出合适自己学习的项目, 最好的办法是先缕清他们的关系。

首先, Tornado 和 Node.js 都可以用来做网站后台服务器应用。 而 Tornado 更是提供了一个 Web 框架。

Tornado 的 Web 框架提供了视图和路由功能, 利用这一点我们可以很容易写出一个 MVC 模式的 Web 应用。 对于Web框架来说, 他直接从服务器应用拿到用户的 request, 处理完毕后得到一个 response, 直接给回服务器就可以了, 是不需要了解 request 如何传输过来以及 response 如何返回给用户的细节的。

图片: web框架与服务器的关系

图片: web框架与服务器的关系

由于同时会有很多客户端向服务器发起请求, 服务器要尽快处理这些请求, 提高性能一般是让cpu在单位时间里面尽量可以处理更多的I/O请求, 方法一般就是采用阻塞的多线程, 或者非阻塞的单线程(当然也可以多线程或者多进程)。

图片: 服务器与客户端的关系

图片: 服务器与客户端的关系

无论是采用哪一种I/O模型, 都要有操作系统的支持, 如果CPU没有中断功能, 操作系统就没有锁的功能, 也就没有信号量, 没有Monitor等一系列同步机制。

对于 Tornado 来说, Python 解释器提供了上述一系列的同步机制。 因此 Tornado 到底能用什么样的 I/O 模型, 直接取决于 Python 解释器。

而 Python 解释器是运行在操作系统之上, 如果操作系统不提供锁, 那么解释器也无法做出一把锁。 因此 Tornado 到底能用什么样的 I/O 模型, 间接取决于操作系统。

我想 Node.js 也是一样的道理。

图片: 服务器与操作系统的关系

图片: 服务器与操作系统的关系

得出结论

  • 如果想知道一个网站的框架是如何将路由, 视图(html, css, js之类), 数据处理拼在一起的, 那么可以阅读 Tornado 源码中的 Web 框架部分。

  • 如果想知道同时有很多很多的 request 到来, 服务器应用是如何利用操作系统提供的接口来完成高并发处理的, 可以阅读 Tornado 的服务器部分或者 Node.js的源码

  • 如果想知道, 不同的操作系统提供了不同的接口, 如何在这个基础上构建出一个跨平台的统一接口, 可以阅读 libuv 的源码

  • 如果想知道在 Linux 操作系统下, 到底是如何实现这些I/O接口的, 可以阅读 libev 的源码

  • 如果想知道如何利用 libuv, 在 Python 下也可以调用跨平台 I/O 接口, 可以阅读 pyuv 的源码

不仅如此, 我们由结论还可以知道更多: 如果想看 libuv 的源码, 知道 libuv 是如何实现的, 首先得会用它。 只有知道它的作用, 看起源码来才有一个目的性。 要想知道如何使用 libuv, 得参考其上面一层的 Tornado 源码中的很小一部分, 或者查阅 libuv 的文档。

选择源码的一般方法

  1. 列出一些感兴趣的关键字

  2. 对关键字的上层和下层进行了解

  3. 梳理出整个关系图

  4. 得出结论, 做出选择

经过刚刚几个步骤, 我们由对 Tornado 和 Node.js 的一些模糊的认识, 逐渐梳理出从用户发起请求, 到操作系统甚至硬件层面的一条比较清晰的路线。 虽然一行源码都还没看, 已经知道了我们看不同的源码, 分别能学到什么知识。 在这个基础上, 选择适合自己当前需求的源码来阅读, 就能事半功倍了。


作者:Jecvay

来源:51CTO

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
如何写好技术文档——来自Google十多年的文档经验
如何写好技术文档——来自Google十多年的文档经验
85 0
今天来讨论很简单的问题:如何选择编程语言呢?
今天来讨论很简单的问题:如何选择编程语言呢?
33 0
阿里云的个人使用体验与关于阿里云个人博客搭建的补充
简单快速,通俗易懂易上手,体验满分10分给9.9分吧!!!
61 0
免费、强大的开源笔记软件Joplin综合评测 —印象笔记的开源替代
Joplin 介绍 绝大部分开源工具都是免费的。如果寻找免费的笔记应用,自然需要考虑开源笔记软件。 在我的视野范围内,常见开源笔记软件包括Boostnote、GitNote、Joplin. 其中,前两者都是面向开发人员,全平台、支持中文、支持浏览器插件和扩展。而 Joplin 则面向一般用户。下面主要介绍 Joplin.
627 0
免费开源的 HelloDjango 系列教程,结束还是开始?
我们已经成功地开发了一个功能比较完备的个人博客,是时候来总结一下我们的工作了。 在教程的前两篇,我们介绍了如何搭建 django 开发环境,如何创建 django 项目以及 django 应用,这是我们进行 django 项目开发的基础。 第 3、4 篇:讲了 django ORM 的基础操作。ORM 是 django 核心中的核心,不仅 django 自带的应用底层全都依赖于 ORM,大部分使用 django 构建的应用基本也离不开 django ORM 的操作,所以能否熟练掌握 django 的 ORM API
64 0
提升代码质量的几点小技巧 | 开发者社区精选文章合集(三十七)
软件研发过程中如何让工作变得更简单高效?来看这些提升代码质量的小技巧!
149 0
看完你就明白一对一直播源码为什么要选择开源
一对一直播系统在今年上半年逐渐深入我们的生活中,它涉及到了很多的方向,无论是教育、工作还是娱乐,已成为互联网直播的新风口,许多做软件开发的人也纷纷加入直播系统的开发中,对于一对一直播源码的选择上为何大家都选择开源呢?看完这篇你就明白了。
240 0
阿里云服务器怎么样?怎么用?全方位评测附教程
最近有好几个做网站的朋友跑来问我在用的阿里云主机服务器怎么样,说的多了,也就想专门写一篇文章来说说我这半年来的感受,供大家参考。阿里云 活动:阿里云服务器低至366元一年我是大概去年一月份把我的网站迁移到了阿里云,差不多刚好半年的样子,虽然用的时间不长,但是作为一个爱折腾的Linuxer,我觉得分享点经验也是必须的:) 当时买了一个双核四GB 5M带宽的服务器,系统是CentOS5.8的Linux发行版地点在北京,一个月的费用大概是500块钱左右,现在这个配置价格 大概在1500元一年 活动比以前用的服务器便宜了点,这一年的使用来看,这个钱花的还算是值得的。
2105 0
阿里云入门搭建小细节
前言实习生涯还在继续,这两天倒腾了一下阿里云。下面来分享一下。 云服务器我觉得就是一台电脑,只不过你可以用,但是不能摸到,拿来挂QQ,挂个人网站,等等都行。 所以接下来开始入云端吧。   一、云服务器ECS购买 首先是买服务器,由于我还是学生,所以可以在阿里云便宜的买到一个服务器(配置比较低)。
3629 0
+关注
行者武松
杀人者,打虎武松也。
文章
问答
文章排行榜
最热
最新
相关电子书
更多
《阿里巴巴Java开发手册(详尽版)1.4.0》
立即下载
《网站性能与体验优化实践指北》
立即下载
从《阿里巴巴Java开发手册》编写推广谈技术成长
立即下载