`
mryufeng
  • 浏览: 982319 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

erlang定时器的强度测试

阅读更多
erlang的定时器在做网络程序的时候几乎无所不在, 语法层面的receive after,IO操作超时,driver内部等都大量使用timer,特别是tcp 在发送接收都有个超时。 如果你有大量的tcp链接, 就意味着大量的定时器。 那么定时器的性能就是个很大的考验。erts的定时器是个timer_wheel实现, 和linux内核用的差不多,大概支持百万级别的规模。 测试如下:

并发开N个进程 每个进程里面0-10秒的随机定时,模拟tcp超时的情况。每个定时器事件的流程是这样的 进程检查消息队列 没消息 注册定时器事件 进程换出 定时器超时 进程换入 处理定时器事件。

root@nd-desktop:~/test# cat ttimer.erl
-module(ttimer).
-export([start/1]).

upmap(F, L) ->
    Parent = self(),
    Ref = make_ref(),
    [receive {Ref, Result} -> Result end
     || _ <- [spawn(fun() -> Parent ! {Ref, F(X)} end) || X <- L]].

loop(0)->
    ok;

loop(Cnt)->
        receive after random:uniform(10000) -> cont end,
        loop(Cnt-1).

start([A1, A2]) ->
         Start= now(),
         N= list_to_integer(atom_to_list(A1)),
         Cnt = list_to_integer(atom_to_list(A2)),
         io:format("spawn ~w process, loop ~w~n", [N, Cnt]),
         upmap(fun loop/1, lists:duplicate(N, Cnt)),
         io:format("run ~w ms~n", [round(timer:now_diff(now(), Start) /1000)]),
         done.


root@nd-desktop:~/test# erl -smp disable -noshell +P 9999999 -s ttimer start 500000 10 -s erlang halt
spawn 500000 process, loop 10
run 63201 ms

单cpu保持在70-80%, 63秒处理了500W个定时器事件, 大概每秒8W.

root@nd-desktop:~/test# cat /proc/cpuinfo
model name      : Pentium(R) Dual-Core  CPU      E5200  @ 2.50GHz
bogomips        : 4987.08

结论: 定时器处理还是比较费时间的。
分享到:
评论
6 楼 mryufeng 2009-09-22  
% Returns Ref, sends event {timeout,Ref,Msg} after Time                                                                                                                          
%% to the (then) current state.                                                                                                                                                   
start_timer(Time, Msg) ->
    erlang:start_timer(Time, self(), {'$gen_timer', Msg}).

%% Returns Ref, sends Event after Time to the (then) current state.                                                                                                               
send_event_after(Time, Event) ->
    erlang:start_timer(Time, self(), {'$gen_event', Event}).

%% Returns the remaing time for the timer if Ref referred to                                                                                                                      
%% an active timer/send_event_after, false otherwise.                                                                                                                             
cancel_timer(Ref) ->
    case erlang:cancel_timer(Ref) of
        false ->
            receive {timeout, Ref, _} -> 0
            after 0 -> false
            end;
        RemainingTime ->
            RemainingTime
    end.



timer是单进程设计 会有很大的性能瓶颈,gen_fsm的就没有问题。
5 楼 美洲豹 2009-09-22  
我现在在用 gen_fsm:send_event_after 来实现游戏中的恢复体力的逻辑

不知道它和 erlang:send_after,timer:send_after 有啥区别?
看它的说明都是创建一个 timer, 为啥在很多模块里面都有 类似的函数?
4 楼 mryufeng 2009-09-16  
每个定时器事件的流程是这样的 进程检查消息队列 没消息 注册定时器事件 进程换出 定时器超时 进程换入 处理定时器事件。 所以有大量的消息拷贝 进程调度。 erlang的进程给另一个进程发送消息的流程是这样的:消息放到对端的队列 同时如果对端不是可运行的,加入运行队列。 调度器最终调度对端, 对端取出消息,进行处理。
3 楼 bachmozart 2009-09-16  
我这边程序发现,启动大量erlang进程,估计一万吧,然后每个进程receive after end,after 是2分钟,结果,如果有其他进程去给这一万个进程的某个发消息,就会不断timeout了,我理解 调度器 会把recieve等待消息的进程挂起,收到消息时,再重新转入调度队列,从我程序的结果看,erlang调度器处理这上万进程,还是有问题的
2 楼 mryufeng 2009-09-16  
还是你家CPU cool点。。。
1 楼 马伟 2009-09-16  
E2160 超频至 2.25GHz
leopard 10.5.7
erlang 5.6.5

-my-workstation-:erlangs peter$ erl -smp disable -noshell +P 9999999 -s ttimer start 500000 10 -s erlang halt
spawn 500000 process, loop 10
run 61181 ms

相关推荐

    erlang的timer和实现机制

    Erlang中的每个定时器都是一个单独的进程,当设置定时器时,实际上是创建了一个新的进程,并将其加入到时间表中。这个时间表由Erlang虚拟机(VM)维护,负责监控所有已激活的定时器。 定时器进程的工作原理如下: 1...

    使用erlang进行UDP测试

    使用erlang进行UDP测试,这几个是为了凑够20字。

    erlang节点连通测试

    现在我们来深入探讨如何进行Erlang节点的连通测试以及如何在需要通信时建立连接。 ### 1. Erlang节点的连接原理 在Erlang中,节点之间的连接是基于TCP/IP协议的。每个Erlang节点都有一个唯一的名称,通常格式为`...

    erlang eunit

    《Erlang的单元测试文档,eunit》这一资料深入探讨了Erlang编程语言中的单元测试框架——EUnit,为开发者提供了详尽的指导与实践建议。 ### Erlang与EUnit Erlang是一种通用的、并发的、容错的编程语言,由...

    erlang编程 Introducing Erlang

    函数式编程强调数据不可变性和函数的数学属性,使代码更易于理解、测试和并行处理。 ### 2. 并发与轻量级进程 Erlang的一大亮点是其内置的并发机制。它使用轻量级进程(Lightweight Processes, LWP)来实现并发,...

    erlang_版本24.3.4.4

    4. **构建和测试**:执行`make`命令开始编译Erlang。这个过程可能需要一些时间,因为它会编译整个Erlang虚拟机和标准库。编译完成后,你可以通过运行`make tests`来验证Erlang的正确性。 5. **安装**:最后,使用`...

    erlang资源

    5. **REPL(Read-Eval-Print Loop)**:Erlang shell的使用,它是学习和测试Erlang代码的重要工具。 6. **实际应用案例**:可能包含Erlang在实时系统、网络通信、数据库或Web服务等领域的应用示例。 这两本书结合...

    berk:Erlang 的基准测试库

    **伯克:Erlang基准测试库** 伯克(Berk)是一个专为Erlang编程语言设计的基准测试库。Erlang是一种强大的并行计算和分布式系统开发语言,以其在高可用性、容错性和实时性方面的优势而闻名。伯克库的出现,旨在帮助...

    erlang port driver test

    标签 "erlang post driver test" 强调了测试的焦点是关于 Erlang 的 Port Driver,可能包括性能测试、兼容性测试和功能测试。 至于压缩包中的 "driver" 文件,这可能是测试项目中的核心部分,即实际实现了 Port ...

    erlang25.0 windows版本

    Erlang是一种高级编程语言,特别适用于并发、分布式和实时系统。它由Ericsson公司开发,主要用于构建高可用性、容错性和可扩展性的软实时系统。Erlang的25.0版本是该语言的一个更新,针对Windows操作系统进行了优化...

    erlang程序设计相关例子程序

    9. **clock.beam** - 该模块可能实现了计时或定时器功能,Erlang的进程可以用来创建定时器,通过接收特定的消息来触发某些操作。 10. **stimer.beam** - "stimer"可能指的是“系统定时器”,这可能是一个用于管理...

    erlang22最新下载包

    Erlang是一种面向并发的、函数式编程语言,由瑞典电信设备制造商Ericsson为了实现分布式实时、高可靠性系统而开发。Erlang以其强大的并行处理能力、容错性和易于构建大规模分布式系统的特点,在电信、金融和互联网等...

    Erlang/OTP 26.2.1

    Erlang/OTP 26.2.1,Erlang,OTP,26.2.1

    erlang9.rar

    在使用Erlang进行开发时,了解Erlang的REPL(Read-Eval-Print Loop)是很有帮助的,通过erl命令启动,可以快速测试代码和调试问题。Erlang还有强大的模块系统,每个文件对应一个模块,模块内包含函数定义。 OTP库...

    Erlang官网下载过慢

    Erlang是一种面向并发的、函数式编程语言,主要用于构建高度可扩展的、容错性强的分布式系统。在IT行业中,Erlang因其强大的实时性和处理大量并发连接的能力而被广泛应用于电信、互联网基础设施和实时系统。RabbitMQ...

    ErlangB和ErlangC计算工具(exe可执行文件+excel两个)

    Erlang B和Erlang C是电信领域中两种重要的流量模型,用于预测和分析通信系统中的呼叫处理能力和拥塞情况。这两个模型由丹麦工程师Agner Krarup Erlang在20世纪初提出,至今仍广泛应用于现代通信网络的设计与优化。 ...

    inside Erlang VM3

    - **商用产品的验证**:Erlang已经被众多商业产品采用,并经过了长时间的实际测试。 #### 高级网络程序要素与ERTS实现 - **CPU管理**:ERTS支持多核CPU,每个核心有一个调度器,实现负载均衡。每个调度器有自己的...

    erlang23.2版windows64位.zip

    5. **函数式编程**:Erlang是函数式的,强调无副作用的纯函数,以及数据不可变性,这有助于编写简洁、易于理解和测试的代码。 6. **模式匹配**:Erlang的模式匹配机制使得解构复杂数据结构和条件分支变得简单。 7....

Global site tag (gtag.js) - Google Analytics