在riak-erlang客户端中执行Mapreduce时出错

时间:2014-05-17 14:15:04

标签: erlang riak erlang-shell

我已经完成了以下操作。我已经存储了如下的详细信息,但即使我在mapreduce中收到错误,请帮助我。我想要test_age存储桶的数据。显示{gopi,1}。

1> {ok, Pid} = riakc_pb_socket:start_link('127.0.0.1',10017).
{ok,<0.34.0>}
2> Object = riakc_obj:new(<<"test_age">>, <<"test1">>, <<"gopi & 1">>). 
{riakc_obj,<<"test_age">>,<<"test1">>,undefined,[],
       undefined,<<"gopi & 1">>}
3> riakc_pb_socket:put(Pid,Object).
ok 
4> Mapf = fun(Obj,_,_) -> [{I,1}|| I <- binary_to_term(riak_object:get_value(Object))]   end. 
#Fun<erl_eval.18.82930912>
5> {ok, [{0,[R]}]} = riakc_pb_socket:mapred(Pid,<<"test_age">>,[{map,{qfun,Mapf},none,true}])
5> .
** exception error: no match of right hand side value {error,<<"{\"phase\":0,\"error\":\"function_clause\",\"input\":\"{ok,{r_object,<<\\\"test_age\\\">>,<<\\\"test1\\\">>,[{r_content,{dict"...>>}

我做错了,我无法理解。请

1 个答案:

答案 0 :(得分:0)

问题在于您的地图功能:

Mapf = fun(Obj,_,_) -> [{I,1}|| I <- binary_to_term(riak_object:get_value(Object))] end.

执行此操作时,Obj将包含r_object记录,但Object将不确定。您可能打算使用:

Mapf = fun(Obj,_,_) -> [{I,1}|| I <- binary_to_term(riak_object:get_value(Obj))] end.

您存储的值是二进制<<"gopi & 1">>,它是binary_to_term调用返回的值。然后列表推导有效[{I,1}|| I <- <<"gopi & 1">>]会导致bad_generator错误。为了使用这个map函数,所有的值都需要是Erlang列表。