1
Exception in thread "main" clojure.lang.ExceptionInfo: clj-http: status 405 
{:status 405, 
:headers {"Allow" "GET,PUT,HEAD,DELETE", "content-type" "application/json; charset=UTF-8", "content-length" "146"}, 
:body "{\"error\":\
"Incorrect HTTP method for uri [/slack_lens_20160820] and method [POST], allowed: [GET, PUT, HEAD, DELETE]\",\"status\":405}", 
:request-time 244, :trace-redirects ["http://127.0.0.1:9200/slack_lens_20160820"], 
:orig-content-encoding "gzip"}, compiling:(/tmp/form-init1822303649317959720.clj:1:73)
        at clojure.lang.Compiler.load(Compiler.java:7239)                                                                                               
        at clojure.lang.Compiler.loadFile(Compiler.java:7165)                                                                                           
        at clojure.main$load_script.invoke(main.clj:275)                                                                                                
        at clojure.main$init_opt.invoke(main.clj:280)                                                                                                   
        at clojure.main$initialize.invoke(main.clj:308)                                                                                                 
        at clojure.main$null_opt.invoke(main.clj:343)                                                                                                   
        at clojure.main$main.doInvoke(main.clj:421)                                                                                                     
        at clojure.lang.RestFn.invoke(RestFn.java:421)                                                                                                  
        at clojure.lang.Var.invoke(Var.java:383)                                                                                                        
        at clojure.lang.AFn.applyToHelper(AFn.java:156)                                                                                                 
        at clojure.lang.Var.applyTo(Var.java:700)                                                                                                       
        at clojure.main.main(main.java:37) 

索引尚未创建,可能是导致它的代码。

(esi/create conn index-name :settings settings :mappings mappings)

在 elasticsearch:1.7 中它工作正常,但在较新的版本 6.0 clj-http 中它失败了。

4

1 回答 1

0

在 Elasticsearch 6.0+ 中,客户端需要发送一个PUT /myindex请求来显式创建一个索引,而不仅仅是一个POST /myindex. 您正在使用的 ES 客户端似乎需要更新。

您可以从响应的正文中看到:

"Incorrect HTTP method for uri [/slack_lens_20160820] and method [POST], allowed: [GET, PUT, HEAD, DELETE]"

POST不允许,您需要使用不同的动词。您可以通过以下方式确认它是否有效:

(require '[clj-http.client :as http])
(http/put "http://localhost:9200/slack_lens_20160820")
于 2018-02-13T04:51:49.470 回答