SpringBoot整合Elasticsearch

Elasticsearch Java客戶端官網(wǎng)地址:https://www.elastic.co/guide/en/elasticsearch/client/java-rest/current/java-rest-high-getting-started-maven.html

1挚币、導入依賴

這里的版本號要與Elasticsearch版本一致摄职,后面測試需要用到fastjson砾嫉,所以也添加了fastjson依賴疾层。

<dependency>
    <groupId>org.elasticsearch.client</groupId>
    <artifactId>elasticsearch-rest-high-level-client</artifactId>
    <version>7.10.1</version>
</dependency>
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.75</version>
</dependency>

依賴包下載完成以后崔挖,發(fā)現(xiàn)elasticsearch包的版本是7.9.3的


整合1.png

此時需要在pom.xml文件中的properties標簽下串塑,添加elasticsearch的版本

    <properties>
        <java.version>1.8</java.version>
        <elasticsearch.version>7.10.1</elasticsearch.version>
    </properties>

重新下載依賴包以后碱工,elasticsearch的版本已經(jīng)改成7.10.1了


整合2.png
2娃承、新建ElasticSearch配置類
import org.apache.http.HttpHost;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * @author ZhaoBW
 * @version 1.0
 * @date 2021/1/22 16:21
 */
@Configuration
public class ElasticSearchConfig {

    @Bean
    public RestHighLevelClient esClient(){
        RestHighLevelClient client = new RestHighLevelClient(
                RestClient.builder(
                        new HttpHost("192.168.43.129", 9200, "http")));
        return client;
    }

}
3、測試新增

test包下新建測試類ESTest

import com.alibaba.fastjson.JSON;
import lombok.Data;
import org.elasticsearch.action.index.IndexRequest;
import org.elasticsearch.action.index.IndexResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.common.xcontent.XContentType;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.io.IOException;


/**
 * @author ZhaoBW
 * @version 1.0
 * @date 2021/1/22 16:32
 */
@SpringBootTest
public class ESTest {

    @Autowired
    private RestHighLevelClient client;

    /**
     * 測試存儲數(shù)據(jù)到Elasticsearch中
     */
    @Test
    void saveData() throws IOException {
        //構造index請求
        IndexRequest request = new IndexRequest("es_test");
        //設置id怕篷,如果不傳历筝,則會自動生成一個id
        request.id("2");
        //第一種傳數(shù)據(jù)方法
//        request.source("name","張三","age",18,"gender","男");

        //第二種,將對象轉為json字符串作為傳輸內容
        User user = new User();
        user.setName("Jessie");
        user.setAge(18);
        user.setGender("男");
        String userString = JSON.toJSONString(user);
        request.source(userString, XContentType.JSON);

        IndexResponse index = client.index(request, RequestOptions.DEFAULT);
        System.out.println(index);
    }

    @Data
    class User{
        String name;
        String gender;
        int age;
    }
    
}

打印結果

IndexResponse[index=es_test,type=_doc,id=2,version=1,result=created,seqNo=1,primaryTerm=1,shards={"total":2,"successful":1,"failed":0}]

使用Kibana查看Elasticsearch中es_test索引下的數(shù)據(jù)


整合3.jpg
4廊谓、查詢數(shù)據(jù)
    @Test
    void getData() throws IOException {
        //第一個參數(shù)是index漫谷,第二個參數(shù)是id
        GetRequest getRequest = new GetRequest("es_test","2");
        GetResponse response = client.get(getRequest, RequestOptions.DEFAULT);
        System.out.println(response);
    }

運行結果:

{"_index":"es_test","_type":"_doc","_id":"2","_version":1,"_seq_no":1,"_primary_term":1,"found":true,"_source":{"age":18,"gender":"男","name":"Jessie"}}

更多增刪改查操作,請參考官方文檔:https://www.elastic.co/guide/en/elasticsearch/client/java-rest/current/java-rest-high-supported-apis.html

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末蹂析,一起剝皮案震驚了整個濱河市舔示,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌电抚,老刑警劉巖惕稻,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異蝙叛,居然都是意外死亡俺祠,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進店門借帘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蜘渣,“玉大人,你說我怎么就攤上這事肺然∧韪祝” “怎么了?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵际起,是天一觀的道長拾碌。 經(jīng)常有香客問我,道長街望,這世上最難降的妖魔是什么校翔? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮灾前,結果婚禮上防症,老公的妹妹穿的比我還像新娘。我一直安慰自己哎甲,他們只是感情好蔫敲,可當我...
    茶點故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著烧给,像睡著了一般燕偶。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上础嫡,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天指么,我揣著相機與錄音,去河邊找鬼榴鼎。 笑死伯诬,一個胖子當著我的面吹牛,可吹牛的內容都是我干的巫财。 我是一名探鬼主播盗似,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼平项!你這毒婦竟也來了赫舒?” 一聲冷哼從身側響起悍及,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎接癌,沒想到半個月后心赶,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡缺猛,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年缨叫,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片荔燎。...
    茶點故事閱讀 38,161評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡耻姥,死狀恐怖,靈堂內的尸體忽然破棺而出有咨,到底是詐尸還是另有隱情琐簇,我是刑警寧澤,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布摔吏,位于F島的核電站鸽嫂,受9級特大地震影響,放射性物質發(fā)生泄漏征讲。R本人自食惡果不足惜据某,卻給世界環(huán)境...
    茶點故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望诗箍。 院中可真熱鬧癣籽,春花似錦、人聲如沸滤祖。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽匠童。三九已至埂材,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間汤求,已是汗流浹背俏险。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留扬绪,地道東北人竖独。 一個月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像挤牛,于是被迫代替她去往敵國和親莹痢。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,916評論 2 344

推薦閱讀更多精彩內容