浏览 3689 次
锁定老帖子 主题:ets 到底有多快
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2009-07-30
最后修改:2009-07-30
我们来测试下这个性能: root@nd-desktop:~# cat ets_test.erl -module(ets_test). -export([new/0, test_insert/2, test_lookup/2, test_update/2]). new()-> ets:new(?MODULE, [public, {write_concurrency, true}]). test_insert(E, N)-> Start = erlang:now(), dotimes(N, fun (I) -> ets:insert(E, {I, hello}) end), Stop = erlang:now(), N / time_diff(Start, Stop). test_lookup(E, N)-> Start = erlang:now(), dotimes(N, fun (I) -> ets:lookup(E, I) end), Stop = erlang:now(), N / time_diff(Start, Stop). test_update(E, N)-> Start = erlang:now(), P = self(), spawn(fun ()-> dotimes(N, fun (I) -> ets:insert(E, {I, hello}) end), P!done end), dotimes(N, fun (I) -> ets:insert(E, {I, hello}) end), %% /*2个进程一起写 要比一个要快哦*/ receive X -> X end, Stop = erlang:now(), N / time_diff(Start, Stop). dotimes(0, _) -> done; dotimes(N, F) -> F(N), dotimes(N - 1, F). time_diff({A1,A2,A3}, {B1,B2,B3}) -> (B1 - A1) * 1000000 + (B2 - A2) + (B3 - A3) / 1000000.0 . root@nd-desktop:~# erl -smp disable +h 9999999 Erlang R13B01 (erts-5.7.2) [source] [rq:1] [async-threads:0] [hipe] [kernel-poll:false] Eshell V5.7.2 (abort with ^G) 1> E = ets_test:new(). 16397 2> ets_test:test_insert(E, 1000000). 855202.2809955239 3> ets_test:test_lookup(E, 1000000). 1584148.3776736464 4> ets_test:test_update(E, 1000000). 1068965.36979788 5> ets:info(E, size). 1000000 ^Croot@nd-desktop:~# erl +h 9999999 Erlang R13B01 (erts-5.7.2) [source] [smp:2:2] [rq:2] [async-threads:0] [hipe] [kernel-poll:false] Eshell V5.7.2 (abort with ^G) 1> E = ets_test:new(). 16397 2> 2> ets_test:test_insert(E, 1000000). 673841.2793820066 3> ets_test:test_lookup(E, 1000000). 1250201.595007195 4> ets_test:test_update(E, 1000000). 896912.4685183724 5> ets:info(E, size). 1000000 可以看到ets的插入和查询操作基本上是在1us左右的级别,相对于process dict的几十ns, 还是差别很大的,因为ets要用2把锁, 一把保护meta table, 一把保护数据表,锁是系统的读写锁。所以这个开销是不容忽视的。 结论: 相比于无锁的数据结构, ets不是非常的快,不过对于一般的应用是够的。 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2009-08-05
好数据~
呵呵,从process dict, ets,到mnesia,各个阶段的设施都有阿。。 |
|
返回顶楼 | |
发表时间:2009-08-05
最后修改:2009-08-05
1。进程内数据dict
2. 跨进程 ets(public,named) 3. 跨节点 mnesia 速度依次差1个数量级。。。相当于硬件的L1, L2, Ram 无敌哦。。。 |
|
返回顶楼 | |
发表时间:2009-08-11
ets并发写的讨论:
http://www.nabble.com/Is-ets:insert-2-(with-multiple-objects)-isolated-with-respect-to--concurrent-readers--td24277077.html |
|
返回顶楼 | |
发表时间:2009-11-27
确实非常的快阿!
|
|
返回顶楼 | |
发表时间:2009-11-27
ets是erlang系统的核心服务,当然要不遗余力的让她快。。。
|
|
返回顶楼 | |