Riak在OSX上安装了100%的CPU

时间:2013-10-11 07:24:32

标签: macos erlang riak

这个问题与:

有关

Riak node not working, but using 100% cpu

但由于海报似乎已经离开,我在这里发布我的案例。

昨晚我使用Riak网站的配置选项从源代码安装了erlang(R15B01):

http://docs.basho.com/riak/1.2.1/tutorials/installation/Installing-Erlang/#Installing-on-Mac-OS-X

我的2013 MacBook Pro上的

和Riak(1.4.1)(2.8GHz i7,16GB ram,OSX 10.8.3)。我没有改变ulimit,因为我认为它对于香草运行会很好。

安装顺利;警告,但没有错误,我能够运行玩具示例没问题。

然而,空实例快速通过所有4个核心,我的机器开始抱怨和过热。

查看日志,我看到以下错误重复了数千次:


2013-10-11 09:04:04.266 [error]  CRASH REPORT ¥
 Process  with 0 neighbours exited with reason: ¥
 call to undefined function eleveldb:o

还有大量的崩溃报告:


2013-10-11 09:14:47 =CRASH REPORT====
  crasher:
    initial call: riak_kv_index_hashtree:init/1
    pid: 
    registered_name: []
    exception exit: {{undef,[{eleveldb,open,
["./data/anti_entropy/479555224749202520035584085735030365824602865664",
[{create_if_missing,true},{max_open_files,20},{write_buffer_size,12886952}]],[]},
{hashtree,new_segment_store,2,[{file,"src/hashtree.erl"},{line,499}]},{hashtree,new,2,
[{file,"src/hashtree.erl"},{line,215}]},{riak_kv_index_hashtree,do_new_tree,2,
[{file,"src/riak_kv_index_hashtree.erl"},{line,421}]},{lists,foldl,3,[{file,"lists.erl"},
{line,1197}]},{riak_kv_index_hashtree,init_trees,2,[{file,"src/riak_kv_index_hashtree.erl"},
{line,366}]},{riak_kv_index_hashtree,init,1,[{file,"src/riak_kv_index_hashtree.erl"},
{line,226}]},{gen_server,init_it,6,[{file,"gen_server.erl"},{line,304}]}]},
[{gen_server,init_it,6,[{file,"gen_server.erl"},{line,328}]},{proc_lib,init_p_do_apply,3,
[{file,"proc_lib.erl"},{line,227}]}]}
    ancestors: [,riak_core_vnode_sup,riak_core_sup,]
    messages: []
    links: []
    dictionary: []
    trap_exit: false
    status: running
    heap_size: 987
    stack_size: 24
    reductions: 492
  neighbours:

erlang.log说


=====
===== LOGGING STARTED Fri Oct 11 09:04:01 CEST 2013
=====
Node 'riak@127.0.0.1' not responding to pings.
config is OK
!!!!
!!!! WARNING: ulimit -n is 2560; 4096 is the recommended minimum.
!!!!
Exec: /tmp/riak-1.4.1/rel/riak/bin/../erts-5.9.1/bin/erlexec 
-boot /tmp/riak-1.4.1/rel/riak/bin/../releases/1.4.1/riak
-config /tmp/riak-1.4.1/rel/riak/bin/../etc/app.config
-pa /tmp/riak-1.4.1/rel/riak/bin/../lib/basho-patches
-args_file /tmp/riak-1.4.1/rel/riak/bin/../etc/vm.args -- console
Root: /tmp/riak-1.4.1/rel/riak/bin/..
Erlang R15B01 (erts-5.9.1) [source] [64-bit] [smp:8:8] [async-threads:64]
 [kernel-poll:true]

Eshell V5.9.1  (abort with ^G)
(riak@127.0.0.1)1>

在不到10米的时间内,已有144MB的日志文件与上述内容有所不同。

2 个答案:

答案 0 :(得分:3)

通过从源代码构建riak 1.4.6,我遇到了同样的问题。

我将文件etc / app.config中的行更改为

{anti_entropy, {off, []}},

AAE使用Leveldb。请参阅config参数anti_entropy_leveldb_opts。

答案 1 :(得分:0)

使用消除过程:

  

没有更多信息,很难说。是否正在使用200%   beam.smp?你在console.log,error.log或crash.log中看到了什么   这表明发生了奇怪的事情?有客户吗?   那时与群集通信?如果是,那么客户端/协议是什么   他们使用和执行什么类型的操作(例如   get / put / map reduce / etc)?

<强>参考