Webbench是一个在linux下使用的很是简单的网站压测工具。它使用fork()模拟多个客户端同时访问咱们设定的URL,测试网站在压力下工做的性能,最多能够模拟3万个并发链接去测试网站的负载能力。Webbench使用C语言编写, 代码实在太简洁,源码加起来不到600行。下载连接:http://home.tiscali.cz/~cz210552/webbench.htmlhtml
tinyhttpd是一个超轻量型Http Server,使用C语言开发,所有代码只有502行(包括注释),附带一个简单的Client,能够经过阅读这段代码理解一个 Http Server 的本质。下载连接:http://sourceforge.net/projects/tinyhttpd/linux
cJSON是C语言中的一个JSON编解码器,很是轻量级,C文件只有500多行,速度也很是理想。web
cJSON也存在几个弱点,虽然功能不是很是强大,但cJSON的小身板和速度是最值得赞扬的。其代码被很是好地维护着,结构也简单易懂,能够做为一个很是好的C语言项目进行学习。项目主页:http://sourceforge.net/projects/cjson/sql
cmockery是google发布的用于C单元测试的一个轻量级的框架。它很小巧,对其余开源包没有依赖,对被测试代码侵入性小。cmockery的源代码行数不到3K,你阅读一下will_return和mock的源代码就一目了然了。数据库
主要特色:编程
下载连接:http://code.google.com/p/cmockery/downloads/listjson
libev是一个开源的事件驱动库,基于epoll,kqueue等OS提供的基础设施。其以高效出名,它能够将IO事件,定时器,和信号统一块儿来,统一放在事件处理这一套框架下处理。基于Reactor模式,效率较高,而且代码精简(4.15版本8000多行),是学习事件驱动编程的很好的资源。下载连接:http://software.schmorp.de/pkg/libev.html缓存
Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它经过在内存中缓存数据和对象来减小读取数据库的次数,从而提供动态数据库驱动网站的速度。Memcached 基于一个存储键/值对的 hashmap。Memcached-1.4.7的代码量仍是能够接受的,只有10K行左右。下载地址:http://memcached.org/服务器
Lua很棒,Lua是巴西人发明的,这些都令我不爽,可是还不至于脸红,最多眼红。并发
让我脸红的是Lua的源代码,百分之一百的ANSI C,一点都不掺杂。在任何支持ANSI C编译器的平台上均可以轻松编译经过。我试过,真是一点废话都没有。Lua的代码数量足够小,5.1.4仅仅1.5W行,去掉空白行和注释估计能到1W行。下载地址:http://www.lua.org/
SQLite是一个开源的嵌入式关系数据库,实现自包容、零配置、支持事务的SQL数据库引擎。 其特色是高度便携、使用方便、结构紧凑、高效、可靠。足够小,大体3万行C代码,250K。 下载地址:http://www.sqlite.org/ 。
UNIX V6 的内核源代码包括设备驱动程序在内 约有1 万行,这个数量的源代码,初学者是可以充分理解的。有一种说法是一我的所能理解的代码量上限为1 万行,UNIX V6的内核源代码从数量上看正好在这个范围以内。看到这里,你们是否是也有“若是只有1万行的话没准儿我也能学会”的想法呢?
另外一方面,最近的操做系统,例如Linux 最新版的内核源代码听说超过了1000 万行。就算不是初学者,想彻底理解所有代码基本上也是不可能的。下载地址:http://minnie.tuhs.org/cgi-bin/utree.pl?file=V6
NetBSD是一个免费的,具备高度移植性的 UNIX-like 操做系统,是现行可移植平台最多的操做系统,能够在许多平台上执行,从 64bit alpha 服务器到手持设备和嵌入式设备。NetBSD计划的口号是:”Of course it runs NetBSD”。它设计简洁,代码规范,拥有众多先进特性,使得它在业界和学术界广受好评。因为简洁的设计和先进的特征,使得它在生产和研究方面,都有卓越的表现,并且它也有受使用者支持的完整的源代码。许多程序均可以很容易地经过NetBSD Packages Collection得到。下载地址:http://www.netbsd.org/