2017-12-12 5 views
0
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) 

索引が作成されていない可能性があります。elasticsearchに接続しようとするとClj-httpがスローされていますか?

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

elasticsearchでは:1.7はうまくいきましたが、新しいバージョン6.0 clj-httpでは失敗します。

答えて

0

Elasticsearch 6.0+では、クライアントはPOST /myindexではなく、PUT /myindex要求を明示的に作成する必要があります。使用しているESクライアントを更新する必要があるようです。

あなたはレスポンスの本体から見ることができます:POSTが許可されていません

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

、あなたは別の動詞を使用する必要があります。

(require '[clj-http.client :as http]) 
(http/put "http://localhost:9200/slack_lens_20160820") 
関連する問題