部署Raft listener

全文索引的数据是异步写入Elasticsearch集群的。流程是通过Storage服务的 Raft listener(简称listener)这个单独部署的进程,从Storage服务读取数据,然后将它们写入Elasticsearch集群。

前提条件

注意事项

  • 请保证Nebula 各组件(Metad、Storaged、Graphd、listener)有相同的版本。

  • 只能为一个图空间“一次性添加所有的 listener 机器”。尝试向已经存在有 listener 的图空间再添加新 listener 会失败。因此,需在一个命令语句里完整地添加全部的 listener。

部署流程

第一步:准备listener的配置文件

你必须在各需要部署 listener 的机器上准备对应的配置文件。文件名称必须为nebula-storaged-listener.conf。用户可以参考提供的模板。注意去掉文件后缀.production

第二步:启动listener

执行如下命令启动启动listener:

  1. ./bin/nebula-storaged --flagfile <listener_config_path>/nebula-storaged-listener.conf

listener_config_path是存放 listener 配置文件的路径。

第三步:添加 listener 到 Nebula Graph 集群

用命令行连接到Nebula Graph,然后执行USE <space>进入需要创建全文索引的图空间。然后执行如下命令添加 listener:

  1. ADD LISTENER ELASTICSEARCH <listener_ip:port> [,<listener_ip:port>, ...]
  1. nebula> ADD LISTENER ELASTICSEARCH 192.168.8.5:46780,192.168.8.6:46780;

查看 listener

执行SHOW LISTENER语句可以列出所有的 listener。

示例

  1. nebula> SHOW LISTENER;
  2. +--------+-----------------+-----------------------+----------+
  3. | PartId | Type | Host | Status |
  4. +--------+-----------------+-----------------------+----------+
  5. | 1 | "ELASTICSEARCH" | "[192.168.8.5:46780]" | "ONLINE" |
  6. +--------+-----------------+-----------------------+----------+
  7. | 2 | "ELASTICSEARCH" | "[192.168.8.5:46780]" | "ONLINE" |
  8. +--------+-----------------+-----------------------+----------+
  9. | 3 | "ELASTICSEARCH" | "[192.168.8.5:46780]" | "ONLINE" |
  10. +--------+-----------------+-----------------------+----------+

删除listener

执行REMOVE LISTENER ELASTICSEARCH语句可以删除图空间的所有listener。

示例

  1. nebula> REMOVE LISTENER ELASTICSEARCH;

下一步

部署全文索引和 listener 后,全文索引会在 Elasticsearch 集群中自动创建,用户可以开始进行全文搜索。详情请参见全文搜索