使用Java API获取Elasticsearch版本

Mei*_*ign 5 java api elasticsearch

我正在寻找Java API挂件 curl -XGET http://localhost:9200

结果如下:

{
  "ok" : true, 
  "status" : 200,
  "name" : "Kierrok",
  "version" : {
    "number" : "0.90.7",
    "build_hash" : "36897d07dadcb70886db7f149e645ed3d44eb5f2",
    "build_timestamp" : "2013-11-13T12:06:54Z",
    "build_snapshot" : false,
    "lucene_version" : "4.5.1"
  },
  "tagline" : "You Know, for Search"
}
Run Code Online (Sandbox Code Playgroud)

我希望它在Java api的admin()部分的某个地方吗?我找不到

Mei*_*ign 5

我找到了这个解决方案(Scala代码但Java API)

case class GetEsVersionQuery(esClient: Client) {
  lazy val p = promise[NodesInfoResponse]()

  esClient
    .admin()
    .cluster()
    .prepareNodesInfo()
    .all()
    .execute()
    .addListener(new ActionListener[NodesInfoResponse] {

    def onFailure(e: Throwable) = {
      p failure e
    }

    def onResponse(response: NodesInfoResponse) = p success response
  })

  def execute: Future[NodesInfoResponse] = p.future
}

def testElasticsearchVersion: Future[Boolean] = {
    GetEsVersionQuery(esClient).execute map {
      esVersion => {
        val nodes = esVersion.iterator().toList
        nodes forall(node => node.getVersion.after(Version.V_0_90_5))
      }
    } recover {
      case e: Throwable => false
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

感谢来自 elasticsearch 用户组的 David Pilato。