最近工作需要,需要先测试一下erlang启动进程的时间开销:
  看了一片博客,感觉挺好的,学习erlang推荐http://www.blogjava.net/yongboy/
  于是参照他的文章里面的一个部分,(当然erlang程序设计一书的107页也有这个代码),自己着手做了下面的测试,看看erlang 创建100万个进程,每一个进程花费多少时间呢?
  我的系统是OS X , 8G内存,双核四线程~
  废话少说,先上代码,在代码中已经做了相关备注:
-module(processes).
-export([max/1]). max(N) ->
% Returns the maximum number of simultaneously
% existing processes at the local node as an integer.
% This limit can be configured at startup
% by using the +P command line flag of erl(1).
Max = erlang:system_info(process_limit),
io:format("Max=:~p~n", [Max]),
% 下述statistics函数可用来统计某段代码的执行时间
% Note that the run-time is the sum of the run-time for
% all threads in the Erlang run-time system
% and may therefore be greater than the wall-clock time.
erlang:statistics(runtime),
% wall_clock can be used in the same manner as runtime,except
% that real time is measured as opposed to runtime or CPU time.
erlang:statistics(wall_clock),
% 被统计的代码区
L = for(1, N, fun() -> spawn(fun() -> wait() end) end),
{_, Time1} = erlang:statistics(runtime),
{_, Time2} = erlang:statistics(wall_clock),
% 进程杀死
lists:foreach(fun(Pid) -> Pid ! die end, L),
% 判断启动一个进程所需时间(系统时间和消耗的真实时间)
U1 = Time1 * 1000 / N,
U2 = Time2 * 1000 / N,
io:format("process spawn time = ~p(~p) microseconds ~n",
[U1, U2]). wait() ->
receive
die -> void
end. for(_N, _N, F) ->
[F()];
for(I, N, F) ->
[F() | for(I + 1, N, F)].
OliviatekiMac-mini:web_test_practice olivia$ erl
Erlang R15B02 (erts-5.9.2) [source] [64-bit] [smp:4:4] [async-threads:0] [hipe] [kernel-poll:false] [dtrace]
Eshell V5.9.2 (abort with ^G)
1> c(processes).
{ok,processes}
2> processes:max(10000000).
Max=:32768
=ERROR REPORT==== 13-May-2013::15:20:47 ===
Too many processes
这说明我的版本默认支持32768个进程,
所以,为了支持更多, 
OliviatekiMac-mini:~ olivia$ cd web_test_practice/
OliviatekiMac-mini:web_test_practice olivia$ erl +P 10240000
Erlang R15B02 (erts-5.9.2) [source] [64-bit] [smp:4:4] [async-threads:0] [hipe] [kernel-poll:false] [dtrace]
Eshell V5.9.2  (abort with ^G)
1> c(processes).
{ok,processes}
2> processes:max(1000000).
Max=:10240000
process spawn time = 3.93(4.221) mocroseconds 
ok
3> processes:max(1000000).
Max=:10240000
process spawn time = 3.82(4.067) mocroseconds 
ok
4> processes:max(1000000).
Max=:10240000
process spawn time = 3.79(4.012) mocroseconds 
ok
5> processes:max(1000000).
Max=:10240000
process spawn time = 3.79(4.04) mocroseconds 
ok
6> processes:max(1000000).
Max=:10240000
process spawn time = 3.8(4.058) mocroseconds 
ok
7> processes:max(1000000).
Max=:10240000
process spawn time = 3.81(4.079) mocroseconds 
ok
8> processes:max(1000000).
Max=:10240000
process spawn time = 3.85(4.146) mocroseconds 
ok
9> processes:max(1000000).
Max=:10240000
process spawn time = 3.8(4.091) mocroseconds 
ok
10> processes:max(1000000).
Max=:10240000
process spawn time = 3.84(4.164) mocroseconds 
ok
11> processes:max(1000000).
Max=:10240000
process spawn time = 3.94(4.365) mocroseconds 
ok
也就是说,
创建100万个进程,每一个进程花费3.87微秒(μs)的CPU时间,相当于4.124微秒(μs)的消耗时间(亦即消耗的真实时间),当然在一定量的区间内,其值会在一定范围内波动。要是想知道erlang到底能够并发起多少系统调用,可以参考褚霸这篇博客,http://blog.yufeng.info/archives/18

erlang创建100万个进程,每一个进程花费多少时间呢?的更多相关文章

  1. Stackful 协程库 libgo(单机100万协程)

    libgo 是一个使用 C++ 编写的协作式调度的stackful协程库, 同时也是一个强大的并行编程库. 设计之初是为高并发分布式Linux服务端程序开发提供底层框架支持,可以让链接进程序的同步的第 ...

  2. 创建进程,join方法,进程对象相关属性和方法,僵尸进程和孤儿进程,守护进程,互斥锁

    创建进程 在python中提供了一个multiprocessing模块可以帮助我们使用多进程解决问题.在multiprocessing 模块中有一个类Process. from multiproces ...

  3. 并发编程(二)--利用Process类开启进程、僵尸进程、孤儿进程、守护进程、互斥锁、队列与管道

    一.multiprocessing模块 1.multiprocessing模块用来开启子进程,并在子进程中执行我们定制的任务(比如函数),该模块与多线程模块threading的编程接口类似. 2.mu ...

  4. 并发编程(二)——利用Process类开启进程、僵尸进程、孤儿进程、守护进程、互斥锁、队列与管道

    Process类与开启进程.守护进程.互斥锁 一.multiprocessing模块 1.multiprocessing模块用来开启子进程,并在子进程中执行我们定制的任务(比如函数),该模块与多线程模 ...

  5. Learn day9 粘包\struct用法\hashlib校验\socketserver并发\模块引入\进程\join\守护进程

    1.粘包现象 总结 : 导致黏包现象的两种情况 hello,worl d (1) 在发送端,发送数据太快,频繁发送 (2) 在接收端,接收数据太慢,延迟截取 # ### 服务端 import sock ...

  6. Linux 普通进程 后台进程 守护进程

    一.普通进程与后台进程 默认情况下,进程是在前台运行的,这时就把shell给占据了,我们无法进行其它操作.对于那些没有交互的进程,很多时候,我们希望将其在后台启动,可以在启动参数的时候加一个'& ...

  7. [Linux] 孤儿进程与僵尸进程[总结]

    转载: http://www.cnblogs.com/Anker/p/3271773.html 1.前言 之前在看<unix环境高级编程>第八章进程时候,提到孤儿进程和僵尸进程,一直对这两 ...

  8. Linux-进程描述(3)之进程状态僵尸进程与孤儿进程

    进程状态 进程状态反映进程执行过程的变化.这些状态随着进程的执行和外界条件的变化而转换.为了弄明正正在运行的进程是什么意思,我们需要知道进程的不同状态.一个进程可以有多个状态(在Linux内核中,进程 ...

  9. 020_Linux的孤儿进程与僵尸进程(Unix系统编程)

    1.前言 之前在看<unix环境高级编程>第八章进程时候,提到孤儿进程和僵尸进程,一直对这两个概念比较模糊.今天被人问到什么是孤儿进程和僵尸进程,会带来什么问题,怎么解决,我只停留在概念上 ...

随机推荐

  1. vue-router实现原理

    vue-router实现原理 近期面试,遇到关于vue-router实现原理的问题,在查阅了相关资料后,根据自己理解,来记录下.我们知道vue-router是vue的核心插件,而当前vue项目一般都是 ...

  2. X-Forwarded-For伪造及防御

    使用x-Forward_for插件或者burpsuit可以改包,伪造任意的IP地址,使一些管理员后台绕过对IP地址限制的访问. 防护策略: 1.对于直接使用的 Web 应用,必须使用从TCP连接中得到 ...

  3. 在iPhone开发中实现解压缩gzip

    在iPhone开发中实现解压缩gzip是本文要介绍的内容,最近做的一个东西中,需要从网络获取xml文件,但是该文件用了gzip压缩的.搜索一 下有人说gzip压缩的用urlrequest可以自己解压, ...

  4. charles 安装使用教程及弱网设置

    1.安装jdk环境 2.下载charles 3.打开直接使用 4.手机端安装相关证书 5.手机端网络设置代理 6.分析查看数据 点击sequane中的值查看app中的数据返回与请求值.   charl ...

  5. shell脚本中的数组

    以下命令,都是以数组array=("20150417" "20150416" "20150415")为例. 注意bash中只支持一维数组,没 ...

  6. Python enumerate 使用技巧

    enumerate() 是Python内建的函数,能让打印的结果更清晰,不管是列表,元组,字典,enumerate()都可以帮你完成,在某些需求下还是非常好用的. >>> a = [ ...

  7. Java文档查看

    对于Java学习者来说,阅读Java文档是必不可少的步骤,比如我现在想知道List接口的retianAll()方法,该怎么办呢? 当然是百度了!!! 皮一下,当然是查找Java文档了,以JDK1.7版 ...

  8. file命令和readlink命令

    6. 如何软链接设备文件 设备文件比较特殊,如果要创建设备文件的链接,需要用到mknod命令: 1 2 3 4 5 [root@centos7 etc]# ll /dev/sda brw-rw---- ...

  9. python之ORM

    pymysql python操作数据库的基本步骤: 导入相应的python模块: 使用connect函数连接数据库,并返回一个connection对象: 通过connection对象的cursor方法 ...

  10. k8s命令集锦

    集群环境相关命令$kubectl vertion --short=true #显示当前使用的客户端及服务端程序版本信息$kubectl cluster-info #获取集群信息$kubectl api ...