Erlang提高ETS并发读写性能

本文深入探讨Erlang的ETS内存数据库的并发读写性能,重点关注write_concurrency和read_concurrency参数。并发写可以提高多进程写效率,但可能降低连续写入性能;并发读在多核环境中提升读性能,但在读写频繁切换时增加消耗。适用场景包括:高并发读写、读多于写或写多于读的情况。同时使用两个参数会带来一定开销,适用于大量并发读写操作。
摘要由CSDN通过智能技术生成
ETS是Erlang内置的内存数据库,可用于多进程共享数据,具有并发读写的性能,文章就这点展开探讨,重点说说ets并发读写两个参数的优缺点及适用场合。

比如新建一个person的ets表:
ets:new(person, [set, public, named_table, {write_concurrency, true}, {read_concurrency, true} ]).

说说ets并发读写的两个参数:write_concurrency / read_concurrency

write_concurrency(并发写)
可以提高多进程并发写ets的效率。通常来说,ets写数据时整张表是锁定的,其他进程不能进行读写直到前面的操作完成。并发写可以改变这个情况,同一个表
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值