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

Erlang Halfword 测试

阅读更多
引用

OTP-8941  == erts ==
From this release, the previously experimental halfword
      emulator is now official. It can be enabled by giving the
      --enable-halfword-emulator option to the configure script.

      The halfword emulator is a 64-bit application, but uses
      halfwords (32-bit words) for all data in Erlang processes,
      therefore using less memory and being faster than the
      standard 64-bit emulator. The total size of all BEAM code and
      all process data for all processes is limited to 4Gb, but ETS
      tables and off-heap binaries are only limited by the amount
      of available memory.


看上面的Erlang的halfword描述,貌似halfword特性很给力啊。对于Processes的寻址是32位,以为着更少的内存,更快的访问,受到4Gb的限制。可是对于tables(ets/mnesia)和off-heap binaries是64位的寻址。

我们来测试一下省了多少内存:

1、 ./configure; make ; sudo make install (64bit version)

erl +A 500 +K true
1> mnesia:start(), 
1> rd(test, {k,v}), 
1> mnesia:create_table(test, [{ram_copies, [node()]}, {attributes, record_info(fields, test)}  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND            
11879 witeman   20   0 4269m  77m 2408 S    0  2.0   0:14.90 beam.smp           
]),
1> lists:foreach(fun(X) -> mnesia:d  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND            
11879 witeman   20   0 4269m  77m 2408 S    0  2.0   0:14.90 beam.smp           
irty_write(#test{k = X, v = X}) end, lists:seq(1000001,2000000)),
1> mnesia:table_info(test, memory).
8144942
2> mnesia:info().
test           : with 1000000  records occupying 8144942  words of mem
schema         : with 2        records occupying 522      words of mem
3> memory().      
[{total,116395728},
 {processes,26512432},
 {processes_used,26493672},
 {system,89883296},
 {atom,606233},
 {atom_used,578661},
 {binary,739408},
 {code,5069980},
 {ets,81482024}]


top:
PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND            
 9625 witeman   20   0  322m 113m 2424 S    0  2.9   0:29.57 beam.smp    



2、./configure --enable-halfword-emulator; make ; sudo make install (64bit halfword version)
1> mnesia:start(),
1> rd(test, {k,v}),
1> mnesia:create_table(test, [{ram_copies, [node()]}, {attributes, record_info(fields, test)}]),
1> lists:foreach(fun(X) -> mnesia:dirty_write(#test{k = X, v = X}) end, lists:seq(1000001,2000000)),mnesia:table_info(test, memory).
11289878
2> mnesia:info().8144942
test           : with 1000000  records occupying 11289878 words of mem
schema         : with 2        records occupying 822      words of mem
3> memory().
[{total,73691680},
 {processes,916040},
 {processes_used,903440},
 {system,72775640},
 {atom,602993},
 {atom_used,573864},
 {binary,70896},
 {code,4821930},
 {ets,65397888},
 {low,5418320}]
4> erlang:system_info(wordsize).  
4

  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND            
11879 witeman   20   0 4269m  77m 2408 S    0  2.0   0:14.90 beam.smp           



mnesia对比:
64bit version: 8144942 * 8 bytes = 65159536 bytes
64bit halfword version: 11289878 * 4 = 45159512 bytes

rate = 45159512 / 65159536 = 69.31%,也就是说halfword对于mnesia里的integer能减少30.69%的内存。

total memory对比:
64bit version: 116395728 bytes
64bit halfword version: 73691680 bytes

rate = 73691680 / 116395728 = 63.31%,也就是说halfword对于整个Erlang VM来说能减少36.69%的内存使用


整个VM内存使用在OS层面的对比:
64bit version: 112 m
64bit halfword version: 77 m

rate = 77 / 112 = 68.75%,也就是说halfword对于VM在OS层面上来说能减少31.25%的内存使用
分享到:
评论

相关推荐

    erlang节点连通测试

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

    使用erlang进行UDP测试

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

    erlang_版本24.3.4.4

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

    erlang编程 Introducing Erlang

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

    erlang资源

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

    erlang25.0 windows版本

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

    Erlang23_3.zip

    此外,Erlang的REPL(Read-Eval-Print Loop)环境允许开发者快速测试代码并查看结果,这对于调试和学习语言非常有用。Erlang的语法简洁明了,函数式编程风格强调无副作用的纯函数,这有助于写出易于理解和维护的代码...

    erlang port driver test

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

    erlang22最新下载包

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

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

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

    erlang23.2版windows64位.zip

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

    Erlang官网下载过慢

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

    erlang eunit

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

    <27>erlang record

    这个文件很可能是Erlang的一个测试模块,其中可能包含对Erlang内置表(ETS,Erlang Term Storage)的Record使用示例。ETS是Erlang中的一种高效、内存中的数据存储,常用于快速数据访问和共享。 `ets_test.erl`文件...

    Erlang/OTP 26.2.1

    Erlang/OTP 26.2.1,Erlang,OTP,26.2.1

    Erlang 20.3linux安装包

    Erlang是一种面向并发的、函数式编程语言,主要用于构建高度可扩展的、容错性强的分布式系统。在IT行业中,Erlang因其强大的实时性、并发性和内存管理机制而被广泛应用于网络通信、数据库系统以及消息中间件,如...

    erlang9.rar

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

    erlang 21.3

    4. **测试**: 可选地,可以运行`make tests`来执行单元测试,确保编译无误。 5. **安装**: 最后,用`sudo make install`将编译好的Erlang二进制文件安装到系统路径中。 在实际应用中,Erlang 21.3可能会带来以下...

    xiandiao_erlang_Erlang课后习题_

    【Erlang编程语言及其应用】 Erlang是一种并发式、函数式的编程语言,由瑞典电信设备制造商Ericsson开发,最初用于构建高可用性、容错性和可扩展性的分布式系统。"xiandiao_erlang_Erlang课后习题_"这个压缩包文件...

Global site tag (gtag.js) - Google Analytics