elasticsearch java//创建客户端对象 TransportClient client = new TransportClient(settings);
答案:1 悬赏:10 手机版
解决时间 2021-11-22 00:39
- 提问者网友:蓝莓格格巫
- 2021-11-21 03:13
elasticsearch java//创建客户端对象 TransportClient client = new TransportClient(settings);
最佳答案
- 五星知识达人网友:玩家
- 2021-11-21 04:49
方法/步骤
建立客户端连接
集群名称默认为elasticsearch,没有修改过无需setting可以建立连接:
Client client = new TransportClient().addTransportAddress(new InetSocketTransportAddress("172.20.0.196", 9300));
如果修改过集群的名称:
Settings settings = ImmutableSettings.settingsBuilder()
.put("cluster.name", "elasticsearch_01").build();
Client client = new TransportClient(settings)
.addTransportAddress(new InetSocketTransportAddress("172.20.0.196", 9300));
创建索引
public void createIndex(String index){
client.admin().indices().create(new CreateIndexRequest(index)).actionGet();
// waitForYellow
client.admin().cluster().health(new ClusterHealthRequest(index)
.waitForYellowStatus())
.actionGet();
}
创建mapping,和curl中完全对应,同样指定分析器为ik
public void createMapping(String index,String type) throws IOException{
XContentBuilder builder = XContentFactory.jsonBuilder()
.startObject()
.startObject(type)
.startObject("_all")
.field("indexAnalyzer", "ik")
.field("searchAnalyzer", "ik")
.field("term_vector", "no")
.field("store", "false")
.endObject()
.startObject("properties")
.startObject("content")
.field("type", "string")
.field("store", "no")
.field("term_vector", "with_positions_offsets")
.field("indexAnalyzer", "ik")
.field("searchAnalyzer", "ik")
.field("include_in_all", "true")
.field("boost", 9)
.endObject()
.endObject()
.endObject()
.endObject();
PutMappingRequest mapping = Requests.putMappingRequest(index).type(type).source(builder);
client.admin().indices().putMapping(mapping).actionGet();
}
索引一些数据,创建成功isCreated()返回true
public void createData(String index,String type){
List jsondata = ElasticsearchTest.getInitJsonData();
for(int i=0; i IndexResponse indexResp = client.prepareIndex()
.setIndex(index).setType(type).setId(i+1+"")
.setSource(jsondata.get(i)).execute().actionGet();
boolean isCreated = indexResp.isCreated();
System.out.println("是否成功创建数据isCreated:"+isCreated);
}
}
查询数据方法
public void queryData(String index,String type){
QueryBuilder queryBuilder = QueryBuilders.termQuery("content", "中国");
SearchResponse searchResponse = client.prepareSearch(index).setTypes(type)
.setQuery(queryBuilder)
.execute()
.actionGet();
SearchHits hits = searchResponse.getHits();
System.out.println("查询到记录数:" + hits.getTotalHits());
SearchHit[] searchHists = hits.getHits();
for(SearchHit sh : searchHists){
System.out.println("content:"+sh.getSource().get("content"));
}
}
在main方法中调用
创建索引、mapping、数据
按条件查询,显示查询结果。
同时可以打开head界面查看下执行效果
建立客户端连接
集群名称默认为elasticsearch,没有修改过无需setting可以建立连接:
Client client = new TransportClient().addTransportAddress(new InetSocketTransportAddress("172.20.0.196", 9300));
如果修改过集群的名称:
Settings settings = ImmutableSettings.settingsBuilder()
.put("cluster.name", "elasticsearch_01").build();
Client client = new TransportClient(settings)
.addTransportAddress(new InetSocketTransportAddress("172.20.0.196", 9300));
创建索引
public void createIndex(String index){
client.admin().indices().create(new CreateIndexRequest(index)).actionGet();
// waitForYellow
client.admin().cluster().health(new ClusterHealthRequest(index)
.waitForYellowStatus())
.actionGet();
}
创建mapping,和curl中完全对应,同样指定分析器为ik
public void createMapping(String index,String type) throws IOException{
XContentBuilder builder = XContentFactory.jsonBuilder()
.startObject()
.startObject(type)
.startObject("_all")
.field("indexAnalyzer", "ik")
.field("searchAnalyzer", "ik")
.field("term_vector", "no")
.field("store", "false")
.endObject()
.startObject("properties")
.startObject("content")
.field("type", "string")
.field("store", "no")
.field("term_vector", "with_positions_offsets")
.field("indexAnalyzer", "ik")
.field("searchAnalyzer", "ik")
.field("include_in_all", "true")
.field("boost", 9)
.endObject()
.endObject()
.endObject()
.endObject();
PutMappingRequest mapping = Requests.putMappingRequest(index).type(type).source(builder);
client.admin().indices().putMapping(mapping).actionGet();
}
索引一些数据,创建成功isCreated()返回true
public void createData(String index,String type){
List
for(int i=0; i
.setIndex(index).setType(type).setId(i+1+"")
.setSource(jsondata.get(i)).execute().actionGet();
boolean isCreated = indexResp.isCreated();
System.out.println("是否成功创建数据isCreated:"+isCreated);
}
}
查询数据方法
public void queryData(String index,String type){
QueryBuilder queryBuilder = QueryBuilders.termQuery("content", "中国");
SearchResponse searchResponse = client.prepareSearch(index).setTypes(type)
.setQuery(queryBuilder)
.execute()
.actionGet();
SearchHits hits = searchResponse.getHits();
System.out.println("查询到记录数:" + hits.getTotalHits());
SearchHit[] searchHists = hits.getHits();
for(SearchHit sh : searchHists){
System.out.println("content:"+sh.getSource().get("content"));
}
}
在main方法中调用
创建索引、mapping、数据
按条件查询,显示查询结果。
同时可以打开head界面查看下执行效果
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯