天天看点

java链接es,springboot集成es

springboot项目,某日同事说,这个接口的数据不插mysql了,存到es里面了,改一下吧,什么是es?怎么改?什么是es我就不写了,直接来代码吧

1、查看es版本

怎么查看你的es版本,访问http://ip:port/  换成你自己的,如果有账密的会让你输入账密,里面的number就是版本号

java链接es,springboot集成es

 2.根据版本导入依赖

<dependency>
            <groupId>org.elasticsearch</groupId>
            <artifactId>elasticsearch</artifactId>
            <version>6.5.2</version>
        </dependency>

        <dependency>
            <groupId>org.elasticsearch.client</groupId>
            <artifactId>elasticsearch-rest-high-level-client</artifactId>
            <version>6.5.2</version>
        </dependency>
           

3.写单测

import com.alibaba.fastjson.JSON;
import org.apache.http.HttpHost;
import org.apache.http.auth.AuthScope;
import org.apache.http.auth.UsernamePasswordCredentials;
import org.apache.http.client.CredentialsProvider;
import org.apache.http.impl.client.BasicCredentialsProvider;
import org.apache.http.impl.nio.client.HttpAsyncClientBuilder;
import org.elasticsearch.action.index.IndexRequest;
import org.elasticsearch.action.index.IndexResponse;
import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestClientBuilder;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.index.query.QueryBuilders;
import org.junit.Test;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

/**
 * @Author: lxx
 * @Date: 2022/7/13 上午10:00
 */
public class TestE {
//查询
    @Test
    public void highClient() throws IOException {
        final CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
        credentialsProvider.setCredentials(AuthScope.ANY,
                new UsernamePasswordCredentials("USER_NAME", "PASSWORD"));  //es账号密码(默认用户名为elastic)
        RestHighLevelClient client = new RestHighLevelClient(
                RestClient.builder(
                        new HttpHost("IP", 9200, "http"))
                        .setHttpClientConfigCallback(new RestClientBuilder.HttpClientConfigCallback() {
                            public HttpAsyncClientBuilder customizeHttpClient(HttpAsyncClientBuilder httpClientBuilder) {
                                httpClientBuilder.disableAuthCaching();
                                return httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
                            }
                        }));
        SearchRequest request = new SearchRequest("INDEX_NAME");
        request.source().query(QueryBuilders.matchQuery("user_id","000UC020000130481"));
//        request.source().query(QueryBuilders.matchAllQuery());
        //发起请求,得到响应结果
        SearchResponse response = client.search(request, RequestOptions.DEFAULT);
        //输出响应结果
        System.out.println(JSON.toJSONString(response));
    }
//插入

    @Test
    public void testInsert() {
        final CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
        credentialsProvider.setCredentials(AuthScope.ANY,
                new UsernamePasswordCredentials("USER_NAME", "PASSWORD"));  //es账号密码(默认用户名为elastic)
        RestHighLevelClient client = new RestHighLevelClient(
                RestClient.builder(
                        new HttpHost("IP", 9200, "http"))
                        .setHttpClientConfigCallback(new RestClientBuilder.HttpClientConfigCallback() {
                            public HttpAsyncClientBuilder customizeHttpClient(HttpAsyncClientBuilder httpClientBuilder) {
                                httpClientBuilder.disableAuthCaching();
                                return httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
                            }
                        }));
        IndexRequest request = new IndexRequest("INDEX","TYPE","IP");
        Map<String, Object> jsonMap = new HashMap<>();
        jsonMap.put("age", "10");
        jsonMap.put("class_name", "2");
        jsonMap.put("teacher", "Elly");

        request.source(jsonMap);
        IndexResponse response = null;
        try {
            response = client.index(request, RequestOptions.DEFAULT);
            if(response.getResult().name().equalsIgnoreCase("created")){

                System.out.println("OK");
            }else {
                System.out.println("ERROR");
            }

        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

           

注意把里面的相关信息改成你自己的啊,ps我链接es的版本是6.5.2如果你的版本,由于版本差太多代码可能也会无效的。

继续阅读