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"
}
我希望它在Java api的admin()部分的某个地方吗?我找不到
我找到了这个解决方案(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
    }
  }
}
感谢来自 elasticsearch 用户组的 David Pilato。
| 归档时间: | 
 | 
| 查看次数: | 3691 次 | 
| 最近记录: |