opensearch java实例_Elasticsearch Client(JAVA API) JAVA实例

本文提供了一个Java操作OpenSearch/Elasticsearch的实例,包括创建索引、定义字段属性、插入数据和查询数据。示例代码详细展示了如何通过TransportClient连接到服务端,以及执行各种操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

需要依赖,版本号视具体服务端版本

org.elasticsearch

elasticsearch

2.2.1

以下为java操作类

import org.elasticsearch.action.admin.cluster.health.ClusterHealthResponse;

import org.elasticsearch.action.admin.indices.create.CreateIndexResponse;

import org.elasticsearch.action.admin.indices.mapping.put.PutMappingRequest;

import org.elasticsearch.action.get.GetResponse;

import org.elasticsearch.action.index.IndexResponse;

import org.elasticsearch.client.Client;

import org.elasticsearch.client.ClusterAdminClient;

import org.elasticsearch.client.Requests;

import org.elasticsearch.client.transport.TransportClient;

import org.elasticsearch.cluster.health.ClusterHealthStatus;

import org.elasticsearch.common.settings.Settings;

import org.elasticsearch.common.transport.InetSocketTransportAddress;

import org.elasticsearch.common.xcontent.XContentBuilder;

import org.elasticsearch.common.xcontent.XContentFactory;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import java.io.IOException;

import java.net.InetAddress;

import java.net.UnknownHostException;

import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;

/**

* Created by yangsj on 2016/6/3.

* ESclient 工具类

*/

public class EsClient {

static Logger logger = LoggerFactory.getLogger(EsClient.class);

static final String host = "192.168.0.128"; //节点IP

public static Client client;

static {

//设置集群名称和自动感知节点 集群名称为"my-application"

Settings settings = Settings.settingsBuilder()

.put("cluster.name", "my-application").put("client.transport.sniff", true).build();

try {

//创建节点客户端,9300位节点的端口,不是集群端口

client = TransportClient.builder().settings(settings).build()

.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName(host), 9300));

} catch (UnknownHostException e) {

e.printStackTrace();

logger.info("unknownHost={}",host);

}

}

/**

* 通过ID查询数据,

* test为索引库,blog为类型,id为标识

*/

public static GetResponse get(String id){

return client.prepareGet("test", "blog",id ).get();

}

/**

* 创建索引,indexName 索引名称

* */

public static CreateIndexResponse createIndex(String indexName) throws IOException {

return client.admin().indices().prepareCreate(indexName).execute().actionGet();

}

//集群状态

public static void clusterStatus(){

//注意集群的client获取方式略有不同,

ClusterAdminClient clusterAdminClient = client.admin().cluster();

ClusterHealthResponse healths = clusterAdminClient.prepareHealth().get();

String clusterName = healths.getClusterName();

int numberOfDataNodes = healths.getNumberOfDataNodes();

int numberOfNodes = healths.getNumberOfNodes();

ClusterHealthStatus status = healths.getStatus();

System.out.println(clusterName+"###"+numberOfDataNodes+"###"+status.name());

}

public static void addType() throws IOException {

// 定义索引字段属性,其实这里就是组合json,可以参考curl 方式创建索引的json格式 此处blog 和执行时blog必须一致

XContentBuilder builder=XContentFactory.jsonBuilder()

.startObject()

.startObject("blog")

.startObject("properties")

.startObject("id").field("type", "integer").field("store", "yes").endObject()

.startObject("title").field("type", "string").field("store", "yes").endObject()

.startObject("content").field("type", "string").field("store", "yes").endObject()

.endObject()

.endObject()

.endObject();

PutMappingRequest mappingRequest = Requests.putMappingRequest("test").type("blog").source(builder);

client.admin().indices().putMapping(mappingRequest).actionGet();

}

/**

* 创建数据

* */

public static void createData() throws IOException {

// 创建数据json 注意此ID是一个字段不是上面查询的id

XContentBuilder builder = jsonBuilder()

.startObject()

.field("id", "2")

.field("title", "我是标题")

.field("content", "我是内容")

.endObject();

IndexResponse indexResponse = client.prepareIndex("test","blog").setSource(builder).execute().actionGet();

System.out.println(indexResponse.isCreated());

}

}

java调用

import org.elasticsearch.action.get.GetResponse;

import java.io.IOException;

/**

* Created by yangsj on 2016/6/3.

*/

public class ElasticTest {

public static void main(String[] args){

try {

EsClient.createIndex("test"); //创建索引 相当于关系型数据库的 数据库

EsClient.addType(); // 创建类型,相当于关系型数据库的 表

EsClient.createData(); //插入数据,相当于关系数据库的 记录

GetResponse getResponse = EsClient.get("AVUde1S5xIEMNjXAMyx4"); //获取数据

System.out.println(getResponse.getSourceAsString());

} catch (IOException e) {

e.printStackTrace();

}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值