在cloud9中运行elasticsearch / searchkick的Searchkick :: InvalidQueryError 400错误?

时间:2017-12-29 14:33:33

标签: ruby-on-rails ruby elasticsearch searchkick

我使用命令

在cloud9中运行弹性搜索
./elasticsearch -E http.port=8081

然后我通过运行curl检查状态

 curl 127.0.0.1:8081

返回

{
  "name" : "JgfOdbe",
  "cluster_name" : "elasticsearch",
  "cluster_uuid" : "zELSmBAIStOB1VNaOz1C-Q",
  "version" : {
    "number" : "6.1.1",
    "build_hash" : "bd92e7f",
    "build_date" : "2017-12-17T20:23:25.338Z",
    "build_snapshot" : false,
    "lucene_version" : "7.1.0",
    "minimum_wire_compatibility_version" : "5.6.0",
    "minimum_index_compatibility_version" : "5.0.0"
  },
  "tagline" : "You Know, for Search"
}

现在我创建书籍支架并创建几本书

在书籍控制器中,我创建了一种测试方法

def index
    @books = Book.search("test", fields: [:title])
end

当我调用index action时,它会返回错误

Searchkick::InvalidQueryError in BooksController#index

我粘贴在错误图片下方

enter image description here

我想知道这个错误的原因。看来语法是正确的。我感谢任何帮助!谢谢!

1 个答案:

答案 0 :(得分:1)

我认为您需要解决两个问题:

配置Elasticsearch端点

由于您使用的是与默认端口(9200)不同的端口(8081),因此应将ELASTICSEARCH_URL环境变量设置为该端口:

ENV["ELASTICSEARCH_URL"] = "http://localhost:8081"

有关该文档的文档位于:https://github.com/ankane/searchkick#deployment

导入数据

之后,您需要通过重新索引将模型中的数据传输到Elasticsearch:

Book.reindex

文档也在这里:https://github.com/ankane/searchkick#getting-started