您的位置:首页 > 编程语言 > Java开发

使用Java操作ElasticSearch1.7程序

2015-08-19 10:30 656 查看
    ElasticSearch是一个基于Lucene的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口。Elasticsearch是用Java开发的,并作为Apache许可条款下的开放源码发布,是第二流行的企业搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。

   最近学习了一下ElasticSearch的Java API使用,简易代码如下:

package com.learn.test;

import org.elasticsearch.client.Client;
import org.elasticsearch.client.transport.TransportClient;
import org.elasticsearch.common.transport.InetSocketTransportAddress;
import org.elasticsearch.common.settings.ImmutableSettings;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.action.index.IndexResponse;

import java.io.IOException;

import org.codehaus.jackson.JsonProcessingException;
import org.codehaus.jackson.map.ObjectMapper;

public class TestElastic
{
public static void main(String[] args)
{
UserModel user = new UserModel();
user.setId(1);
user.setName("李四");
user.setAge("101");
user.setSex("1231");
user.setTel("Tel");
String jsondata = toJson(user);
System.out.println("封装的json:"+jsondata);

Settings settings = ImmutableSettings.settingsBuilder().put("cluster.name", "tang-elasticsearch").build();
Client client = new TransportClient(settings).addTransportAddress(
new<span style="font-family: Arial, Helvetica, sans-serif;"> InetSocketTransportAddress("192.168.15.1", 9300));</span>
IndexResponse res = client.prepareIndex().setIndex("school").setType("class").setId("10").setSource(
jsondata).execute().actionGet();
System.out.println("索引创建成功,版本号:"+res.getVersion());

client.close();
}

public static String toJson(Object o)
{
try
{
ObjectMapper objectMapper = new ObjectMapper();
return objectMapper.writeValueAsString(o);
}
catch (JsonProcessingException e)
{
e.printStackTrace();
}
catch (IOException e)
{
e.printStackTrace();
}

return "";
}

}

class UserModel
{
private int id;
private String name;
private String age;
private String sex;
private String tel;

public int getId()
{
return id;
}

public void setId(int id)
{
this.id = id;
}

public String getName()
{
return name;
}

public void setName(String name)
{
this.name = name;
}

public String getAge()
{
return age;
}

public void setAge(String age)
{
this.age = age;
}

public String getSex()
{
return sex;
}

public void setSex(String sex)
{
this.sex = sex;
}

public String getTel()
{
return tel;
}

public void setTel(String tel)
{
this.tel = tel;
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java ElasticSearch API