繁体   English   中英

在CRDT数据类型上进行Riak搜索-内存后端

[英]Riak search on CRDT data types - memory backend

我正在使用riak2.2.3,并尝试在地图存储桶类型中进行搜索,但从未返回任何内容。

我在内存后端配置了存储桶类型“ dist_cache”:

# riak-admin bucket-type status dist_cache
dist_cache is active

active: true
allow_mult: true
backend: <<"memory_mult">>
basic_quorum: false
big_vclock: 50
chash_keyfun: {riak_core_util,chash_std_keyfun}
claimant: 'riak@127.0.0.1'
datatype: map
dvv_enabled: true
dw: quorum
last_write_wins: false
linkfun: {modfun,riak_kv_wm_link_walker,mapreduce_linkfun}
n_val: 3
notfound_ok: true
old_vclock: 86400
postcommit: []
pr: 0
precommit: []
pw: 0
r: quorum
rw: quorum
search_index: <<"expirable_token">>
small_vclock: 50
w: quorum
young_vclock: 20

然后,我在/ etc / riak /中启用搜索:

search = on

然后,我使用默认架构配置了一个索引,并将其与存储桶类型相关联(请参见上文)。

我可以在该存储桶中使用键成功存储和检索值。 我在寄存器中存储了3个值:二进制数据,整数(时间戳)和字符串:

[
  {{"attrs", :register}, <<131, 97, 111>>},
  {{"iat_i", :register}, "1540923453"},
  {{"test_s", :register}, "paul"}
]

(使用Elixir的Riak库从Elixir shell格式化后显示。)

但是,当我尝试搜索这些值时,什么都没有找到:

iex(74)> :riakc_pb_socket.search(pid, "expirable_token", "iat_i:[0 TO *]")
{:ok, {:search_results, [], 0.0, 0}}
iex(75)> :riakc_pb_socket.search(pid, "expirable_token", "iat_i:1540923453")
{:ok, {:search_results, [], 0.0, 0}}
iex(76)> :riakc_pb_socket.search(pid, "expirable_token", "test_s:paul")     
{:ok, {:search_results, [], 0.0, 0}}
iex(77)> :riakc_pb_socket.search(pid, "expirable_token", "test_s:*")   
{:ok, {:search_results, [], 0.0, 0}}

此外,/ var / log / riak / solr.log不会显示这些请求的任何错误消息。

我想念什么吗? 我需要从Java启动选项中删除一些选项,但现在看来Java已启动并正在运行,并且在尝试格式错误的请求时solr.log确实显示错误消息。

编辑:

在尝试@vempo的解决方案后:

我已在_register后缀字段,但是仍然无法正常工作。 字段如下:

iex(12)> APISexAuthBearerCacheRiak.get("ddd", opts)                 
[
  {{"attrs", :register}, <<131, 98, 0, 0, 1, 188>>},
  {{"iat_i", :register}, "1542217847"},
  {{"test_flag", :flag}, true},
  {{"test_register", :register}, "pierre"}
]

但搜索请求仍未返回结果:

iex(15)> :riakc_pb_socket.search(pid, "expirable_token", "test_register:*")   
{:ok, {:search_results, [], 0.0, 0}}
iex(16)> :riakc_pb_socket.search(pid, "expirable_token", "test_register:pierre")   
{:ok, {:search_results, [], 0.0, 0}}
iex(17)> :riakc_pb_socket.search(pid, "expirable_token", "test_register:*")        
{:ok, {:search_results, [], 0.0, 0}}
iex(18)> :riakc_pb_socket.search(pid, "expirable_token", "test_flag:true")    
{:ok, {:search_results, [], 0.0, 0}}
iex(19)> :riakc_pb_socket.search(pid, "expirable_token", "test_flag:*")  

仍然知道/var/log/riak/solr.log中的输出,并且索引似乎已正确设置:

iex(14)> :riakc_pb_socket.list_search_indexes(pid)                       
{:ok,
 [
   [index: "expirable_token", schema: "_yz_default", n_val: 3],
   [index: "famous", schema: "_yz_default", n_val: 3]
 ]}

对于在地图内搜索,规则是不同的。 根据根据数据类型进行搜索,地图有四种模式,每种嵌入式类型都有一种:

  • *_旗
  • *_计数器
  • *_寄存器
  • *_组

因此,在您的情况下,您应该搜索attrs_registeriat_i_registertest_s_register

附带说明一下,后缀_s_i可能是多余的。 默认模式使用它们来决定常规字段的类型,但对于嵌入式数据类型则没有用。

UPDATE

并总结一下规则:

  • 一个名为test的标志字段将被索引为test_flag (查询test_flag:*
  • 一个名为test的寄存器字段将被索引为test_register (查询test_register:*
  • 一个名为test的计数器字段将被索引为test_counter (查询test_counter:*
  • 一个名为test的集合字段将被索引为test_set (查询test_set:*

这在“ 搜索数据类型:嵌入式模式”的表中很好地显示了。

另请参见默认模式中嵌入数据类型的动态字段的定义, <!-- Riak datatypes embedded fields -->

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM