欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

SpringBoot整合ElasticSearch實(shí)現(xiàn)多版本的兼容

前言

本篇主要是介紹和使用目前最火的搜索引擎ElastiSearch,并和SpringBoot進(jìn)行結(jié)合使用。

在壽縣等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專(zhuān)注、極致的服務(wù)理念,為客戶(hù)提供成都做網(wǎng)站、成都網(wǎng)站制作 網(wǎng)站設(shè)計(jì)制作定制設(shè)計(jì),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計(jì),網(wǎng)絡(luò)營(yíng)銷(xiāo)推廣,成都外貿(mào)網(wǎng)站建設(shè),壽縣網(wǎng)站建設(shè)費(fèi)用合理。

ElasticSearch介紹

ElasticSearch是一個(gè)基于Lucene的搜索服務(wù)器,其實(shí)就是對(duì)Lucene進(jìn)行封裝,提供了 REST API 的操作接口?ElasticSearch作為一個(gè)高度可拓展的開(kāi)源全文搜索和分析引擎,可用于快速地對(duì)大數(shù)據(jù)進(jìn)行存儲(chǔ),搜索和分析。
ElasticSearch主要特點(diǎn):分布式、高可用、異步寫(xiě)入、多API、面向文檔 。
ElasticSearch核心概念:近實(shí)時(shí),集群,節(jié)點(diǎn)(保存數(shù)據(jù)),索引,分片(將索引分片),副本(分片可設(shè)置多個(gè)副本) 。它可以快速地儲(chǔ)存、搜索和分析海量數(shù)據(jù)。
ElasticSearch使用案例:維基百科、Stack Overflow、Github 等等。

SpringBoot整合Elasticsearch

在使用SpringBoot整合Elasticsearch?之前,我們應(yīng)該了解下它們之間對(duì)應(yīng)版本的關(guān)系。

Spring Boot Version (x)Spring Data Elasticsearch Version (y)Elasticsearch Version (z)
x <= 1.3.5y <= 1.3.4z <= 1.7.2*
x >= 1.4.x2.0.0 <=y < 5.0.0**2.0.0 <= z < 5.0.0**

這里我們使用的SpringBoot的版本是1.5.9,Elasticsearch的版本是2.3.5。

使用SpringBoot整合Elasticsearch,一般都是使用?SpringData?進(jìn)行封裝的,然后再dao層接口繼承ElasticsearchRepository?類(lèi),該類(lèi)實(shí)現(xiàn)了很多的方法,比如常用的CRUD方法。

SpringData的使用

首先,在使用之前,先做好相關(guān)的準(zhǔn)備。

Maven的配置如下:
<dependency>
????????????<groupId>org.springframework.boot</groupId>
????????????<artifactId>spring-boot-starter-web</artifactId>
?????????????<version>1.5.9.RELEASE</version>
????????</dependency>
??<dependency>
????????????<groupId>org.springframework.boot</groupId>
????????????<artifactId>spring-boot-starter-data-elasticsearch</artifactId>
?????????????<version>1.5.9.RELEASE</version>
????????</dependency>
application.properties的配置
spring.data.elasticsearch.repositories.enabled?=?truespring.data.elasticsearch.cluster-nodes?=127.0.0.1\:9300

注: 9300 是 Java 客戶(hù)端的端口。9200 是支持 Restful HTTP 的接口。

更多的配置:

spring.data.elasticsearch.cluster-name?Elasticsearch?集群名。(默認(rèn)值:?elasticsearch)spring.data.elasticsearch.cluster-nodes?集群節(jié)點(diǎn)地址列表,用逗號(hào)分隔。如果沒(méi)有指定,就啟動(dòng)一個(gè)客戶(hù)端節(jié)點(diǎn)。spring.data.elasticsearch.propertie?用來(lái)配置客戶(hù)端的額外屬性。spring.data.elasticsearch.repositories.enabled?開(kāi)啟?Elasticsearch?倉(cāng)庫(kù)。(默認(rèn)值:true。)
代碼編寫(xiě)

實(shí)體類(lèi)

@Document(indexName?=?"userindex",?type?=?"user")
public?class?User?implements?Serializable{?????/**?????*??????*/
????private?static?final?long?serialVersionUID?=?1L;????/**?編號(hào)?*/
?????private?Long?id;?????/**?姓名?*/
?????private?String?name;?????
?????/**?年齡?*/
?????private?Integer?age;?????
?????/**?描述?*/??
?????private?String?description;?????
?????/**?創(chuàng)建時(shí)間?*/
?????private?String?createtm;????//?getter和setter?略}

使用SpringData的時(shí)候,它需要在實(shí)體類(lèi)中設(shè)置indexName?和type?,如果和傳統(tǒng)型數(shù)據(jù)庫(kù)比較的話,就相當(dāng)于庫(kù)。需要注意的是indexNametype都必須是小寫(xiě)!!!

dao層

public?interface?UserDao?extends?ElasticsearchRepository<User,?Long>{}

dao層這里就比較簡(jiǎn)單了,只需繼承ElasticsearchRepository該類(lèi)就行了。其中主要的方法就是 save、delete和search。其中save方法相當(dāng)如insert和update,沒(méi)有就新增,有就覆蓋。delete方法主要就是刪除數(shù)據(jù)以及索引庫(kù)。至于search就是查詢(xún)了,包括一些常用的查詢(xún),如分頁(yè)、權(quán)重之類(lèi)的。

Service層

@Servicepublic?class?UserServiceImpl?implements?UserService?{????@Autowired
????private?UserDao?userDao;????@Override
????public?boolean?insert(User?user)?{????????boolean?falg=false;????????try{
????????????userDao.save(user);
????????????falg=true;
????????}catch(Exception?e){
????????????e.printStackTrace();
????????}????????return?falg;
????}????@Override
????public?List<User>?search(String?searchContent)?{
??????????QueryStringQueryBuilder?builder?=?new?QueryStringQueryBuilder(searchContent);
??????????System.out.println("查詢(xún)的語(yǔ)句:"+builder);
??????????Iterable<User>?searchResult?=?userDao.search(builder);
??????????Iterator<User>?iterator?=?searchResult.iterator();
??????????List<User>?list=new?ArrayList<User>();??????????while?(iterator.hasNext())?{
????????????list.add(iterator.next());
??????????}???????return?list;
????}????
????
????
????@Override
????public?List<User>?searchUser(Integer?pageNumber,?Integer?pageSize,String?searchContent)?{?????????//?分頁(yè)參數(shù)
????????Pageable?pageable?=?new?PageRequest(pageNumber,?pageSize);
????????QueryStringQueryBuilder?builder?=?new?QueryStringQueryBuilder(searchContent);
????????SearchQuery?searchQuery?=?new?NativeSearchQueryBuilder().withPageable(pageable).withQuery(builder).build();
????????System.out.println("查詢(xún)的語(yǔ)句:"?+?searchQuery.getQuery().toString());
????????Page<User>?searchPageResults?=?userDao.search(searchQuery);????????return?searchPageResults.getContent();
????}????

????@Override
????public?List<User>?searchUserByWeight(String?searchContent)?{?????//?根據(jù)權(quán)重進(jìn)行查詢(xún)
????????FunctionScoreQueryBuilder?functionScoreQueryBuilder?=?QueryBuilders.functionScoreQuery()
????????????????.add(QueryBuilders.boolQuery().should(QueryBuilders.matchQuery("name",?searchContent)),
????????????????????ScoreFunctionBuilders.weightFactorFunction(10))
????????????????.add(QueryBuilders.boolQuery().should(QueryBuilders.matchQuery("description",?searchContent)),
????????????????????????ScoreFunctionBuilders.weightFactorFunction(100)).setMinScore(2);
????????System.out.println("查詢(xún)的語(yǔ)句:"?+?functionScoreQueryBuilder.toString());
????????Iterable<User>?searchResult?=?userDao.search(functionScoreQueryBuilder);
????????Iterator<User>?iterator?=?searchResult.iterator();
????????List<User>?list=new?ArrayList<User>();????????while?(iterator.hasNext())?{
????????????list.add(iterator.next());
????????}????????return?list;
????}
}

這里我就簡(jiǎn)單的寫(xiě)了幾個(gè)方法,其中主要的方法是查詢(xún)。查詢(xún)包括全文搜索,分頁(yè)查詢(xún)和權(quán)重查詢(xún)。其中需要說(shuō)明的是權(quán)重查詢(xún)這塊,權(quán)重的分值越高,查詢(xún)的結(jié)果也越靠前,如果沒(méi)有對(duì)其它的數(shù)據(jù)設(shè)置分值,它們默認(rèn)的分值就是1,如果不想查詢(xún)這些語(yǔ)句,只需使用setMinScore將其設(shè)為大于1即可。

代碼測(cè)試

調(diào)用接口進(jìn)行添加數(shù)據(jù)

新增數(shù)據(jù):

POST?http://localhost:8086/api/user{"id":1,"name":"張三","age":20,"description":"張三是個(gè)Java開(kāi)發(fā)工程師","createtm":"2018-4-25?11:07:42"}
{"id":2,"name":"李四","age":24,"description":"李四是個(gè)測(cè)試工程師","createtm":"1980-2-15?19:01:32"}
{"id":3,"name":"王五","age":25,"description":"王五是個(gè)運(yùn)維工程師","createtm":"2016-8-21?06:11:32"}

進(jìn)行全文查詢(xún)
請(qǐng)求

http://localhost:8086/api/user?searchContent=工程師

返回

[{"id":2,"name":"李四","age":14,"description":"李四是個(gè)測(cè)試工程師","createtm":?"1980-2-15?19:01:32"},
{"id":1,"name":"張三","age":20,"description":"張三是個(gè)Java開(kāi)發(fā)工程師",?"createtm":?"2018-4-25?11:07:42"},
{"id":3,"name":"王五","age":25,"description":"王五是個(gè)運(yùn)維工程師","createtm":?"2016-8-21?06:11:32"}]

進(jìn)行分頁(yè)查詢(xún)
請(qǐng)求

http://localhost:8086/api/user?pageNumber=0&pageSize=2&searchContent=工程師

返回

[{"id":2,"name":"李四","age":14,"description":"李四是個(gè)測(cè)試工程師"},{"id":1,"name":"張三","age":20,"description":"張三是個(gè)Java開(kāi)發(fā)工程師"}]

進(jìn)行權(quán)重查詢(xún)
請(qǐng)求

http://localhost:8086/api/user2?searchContent=李四

返回

[{"id":2,"name":"李四","age":24,"description":"李四是個(gè)測(cè)試工程師","createtm":"1980-2-15?19:01:32"}]

權(quán)重查詢(xún)打印的語(yǔ)句:

查詢(xún)的語(yǔ)句:{{??"function_score"?:?{????"functions"?:?[?{??????"filter"?:?{????????"bool"?:?{??????????"should"?:?{????????????"match"?:?{??????????????"name"?:?{????????????????"query"?:?"李四",????????????????"type"?:?"boolean"
??????????????}
????????????}
??????????}
????????}
??????},??????"weight"?:?10.0
????},?{??????"filter"?:?{????????"bool"?:?{??????????"should"?:?{????????????"match"?:?{??????????????"description"?:?{????????????????"query"?:?"李四",????????????????"type"?:?"boolean"
??????????????}
????????????}
??????????}
????????}
??????},??????"weight"?:?100.0
????}?],????"min_score"?:?2.0
??}
}

注:測(cè)試中,因?yàn)樵O(shè)置了setMinScore最小權(quán)重分為2的,所以無(wú)關(guān)的數(shù)據(jù)是不會(huì)顯示出來(lái)的。如果想顯示的話,在代碼中去掉即可。

新增完數(shù)據(jù)之后,可以在瀏覽器輸入:http://localhost:9200/_plugin/head/
然后點(diǎn)擊基本查詢(xún),便可以查看添加的數(shù)據(jù)。如果想用語(yǔ)句查詢(xún),可以將程序中控制臺(tái)打印的查詢(xún)語(yǔ)句粘貼到查詢(xún)界面上進(jìn)行查詢(xún)!
SpringBoot整合ElasticSearch實(shí)現(xiàn)多版本的兼容

注:這里的ElasticSearch是我在windows上安裝的,并安裝了ES插件head,具體安裝步驟在文章末尾。

除了SpringData之外,其實(shí)還有其它的方法操作ElasticSearch的。
比如使用原生ElasticSearch的Api,使用TransportClient類(lèi)實(shí)現(xiàn)。
或者使用由Spring封裝,只需在Service層,進(jìn)行注入Bean即可。
示例:

@Autowired
?ElasticsearchTemplate?elasticsearchTemplate;

但是,上述方法中都有其局限性,也就是隨著ElasticSearch的版本變更,相關(guān)的Java API也在做不斷的調(diào)整,就是ElasticSearch服務(wù)端版本進(jìn)行更改之后,客戶(hù)端的代碼可能需要重新編寫(xiě)。
因此介紹一個(gè)相當(dāng)好用的第三方工具JestClient,它對(duì)ElasticSearch進(jìn)行封裝,填補(bǔ)了?ElasticSearch?HttpRest接口 客戶(hù)端的空白,它適用于ElasticSearch2.x以上的版本,無(wú)需因?yàn)?strong>ElasticSearch服務(wù)端版本更改而對(duì)代碼進(jìn)行更改!

JestClient

首先在Maven中添加如下依賴(lài):

????<dependency>
????????<groupId>io.searchbox</groupId>?
?????????<artifactId>jest</artifactId>
????????<version>5.3.3</version>
????</dependency>

然后編寫(xiě)相關(guān)的測(cè)試代碼。
代碼中的注釋?xiě)?yīng)該很完整,所以這里就不再對(duì)代碼過(guò)多的講述了。

import?java.util.ArrayList;import?java.util.List;import?org.elasticsearch.index.query.QueryBuilders;import?org.elasticsearch.search.builder.SearchSourceBuilder;import?com.pancm.pojo.User;import?io.searchbox.client.JestClient;import?io.searchbox.client.JestClientFactory;import?io.searchbox.client.JestResult;import?io.searchbox.client.config.HttpClientConfig;import?io.searchbox.core.Bulk;import?io.searchbox.core.BulkResult;import?io.searchbox.core.Delete;import?io.searchbox.core.DocumentResult;import?io.searchbox.core.Index;import?io.searchbox.core.Search;import?io.searchbox.indices.CreateIndex;import?io.searchbox.indices.DeleteIndex;import?io.searchbox.indices.mapping.GetMapping;import?io.searchbox.indices.mapping.PutMapping;public?class?JestTest?{??
????????private?static?JestClient?jestClient;??
????????private?static?String?indexName?=?"userindex";??
//??????private?static?String?indexName?=?"userindex2";??
????????private?static?String?typeName?=?"user";??
????????private?static?String?elasticIps="http://192.169.2.98:9200";//??????private?static?String?elasticIps="http://127.0.0.1:9200";
????????
????????
????????public?static?void?main(String[]?args)?throws?Exception?{
????????????jestClient?=?getJestClient();??
????????????insertBatch();
????????????serach2();
????????????serach3();
????????????serach4();
????????????jestClient.close();??
????????????
????????}????????
????????private?static??JestClient?getJestClient()?{??
????????????JestClientFactory?factory?=?new?JestClientFactory();??
????????????factory.setHttpClientConfig(new?HttpClientConfig.Builder(elasticIps).connTimeout(60000).readTimeout(60000).multiThreaded(true).build());??
????????????return?factory.getObject();??
????????}??
????????
????????public?static?void?insertBatch()?{
????????????List<Object>?objs?=?new?ArrayList<Object>();
????????????objs.add(new?User(1L,?"張三",?20,?"張三是個(gè)Java開(kāi)發(fā)工程師","2018-4-25?11:07:42"));
????????????objs.add(new?User(2L,?"李四",?24,?"李四是個(gè)測(cè)試工程師","1980-2-15?19:01:32"));
????????????objs.add(new?User(3L,?"王五",?25,?"王五是個(gè)運(yùn)維工程師","2016-8-21?06:11:32"));????????????boolean?result?=?false;????????????try?{
????????????????result?=?insertBatch(jestClient,indexName,?typeName,objs);
????????????}?catch?(Exception?e)?{
????????????????e.printStackTrace();
????????????}
????????????System.out.println("批量新增:"+result);
????????}????????
????????
????????/**
?????????*?全文搜索
?????????*/
????????public?static?void?serach2()?{
????????????String?query?="工程師";????????????try?{
????????????????SearchSourceBuilder?searchSourceBuilder?=?new?SearchSourceBuilder();?
?????????????????searchSourceBuilder.query(QueryBuilders.queryStringQuery(query));?
?????????????????//分頁(yè)設(shè)置
?????????????????searchSourceBuilder.from(0).size(2);?
????????????????System.out.println("全文搜索查詢(xún)語(yǔ)句:"+searchSourceBuilder.toString());
????????????????System.out.println("全文搜索返回結(jié)果:"+search(jestClient,indexName,?typeName,?searchSourceBuilder.toString()));
????????????}?catch?(Exception?e)?{
????????????????e.printStackTrace();
????????????}
????????}????????
????????/**
?????????*?精確搜索
?????????*/
????????public?static?void?serach3()?{????????????try?{
????????????????SearchSourceBuilder?searchSourceBuilder?=?new?SearchSourceBuilder();?
????????????????searchSourceBuilder.query(QueryBuilders.termQuery("age",?24));?
????????????????System.out.println("精確搜索查詢(xún)語(yǔ)句:"+searchSourceBuilder.toString());
????????????????System.out.println("精確搜索返回結(jié)果:"+search(jestClient,indexName,?typeName,?searchSourceBuilder.toString()));
????????????}?catch?(Exception?e)?{
????????????????e.printStackTrace();
????????????}
????????}????????
????????
????????/**
?????????*?區(qū)間搜索
?????????*/
????????public?static?void?serach4()?{
????????????String?createtm="createtm";
????????????String?from="2016-8-21?06:11:32";
????????????String?to="2018-8-21?06:11:32";????????????
????????????try?{
????????????????SearchSourceBuilder?searchSourceBuilder?=?new?SearchSourceBuilder();?
????????????????searchSourceBuilder.query(QueryBuilders.rangeQuery(createtm).gte(from).lte(to));?
????????????????System.out.println("區(qū)間搜索語(yǔ)句:"+searchSourceBuilder.toString());
????????????????System.out.println("區(qū)間搜索返回結(jié)果:"+search(jestClient,indexName,?typeName,?searchSourceBuilder.toString()));
????????????}?catch?(Exception?e)?{
????????????????e.printStackTrace();
????????????}
????????}????????
????????
????????/**
?????????*?創(chuàng)建索引
?????????*?@param?indexName
?????????*?@return
?????????*?@throws?Exception
?????????*/
????????public?boolean?createIndex(JestClient?jestClient,String?indexName)?throws?Exception?{??
????????????JestResult?jr?=?jestClient.execute(new?CreateIndex.Builder(indexName).build());??
????????????return?jr.isSucceeded();??
????????}??
??????????
????????/**
?????????*?新增數(shù)據(jù)
?????????*?@param?indexName
?????????*?@param?typeName
?????????*?@param?source
?????????*?@return
?????????*?@throws?Exception
?????????*/
????????public?boolean?insert(JestClient?jestClient,String?indexName,?String?typeName,?String?source)?throws?Exception?{??
????????????PutMapping?putMapping?=?new?PutMapping.Builder(indexName,?typeName,?source).build();??
????????????JestResult?jr?=?jestClient.execute(putMapping);??
????????????return?jr.isSucceeded();??
????????}??
??????????
????????
?????????/**
??????????*?查詢(xún)數(shù)據(jù)
??????????*?@param?indexName
??????????*?@param?typeName
??????????*?@return
??????????*?@throws?Exception
??????????*/
????????public?static?String?getIndexMapping(JestClient?jestClient,String?indexName,?String?typeName)?throws?Exception?{??
????????????GetMapping?getMapping?=?new?GetMapping.Builder().addIndex(indexName).addType(typeName).build();??
????????????JestResult?jr?=jestClient.execute(getMapping);??
????????????return?jr.getJsonString();??
?????????}??
??????????
????????
????????
???????/**
????????*?批量新增數(shù)據(jù)
????????*?@param?indexName
????????*?@param?typeName
????????*?@param?objs
????????*?@return
????????*?@throws?Exception
????????*/
????????public?static?boolean?insertBatch(JestClient?jestClient,String?indexName,?String?typeName,?List<Object>?objs)?throws?Exception?{??
????????????Bulk.Builder?bulk?=?new?Bulk.Builder().defaultIndex(indexName).defaultType(typeName);??
????????????for?(Object?obj?:?objs)?{??
????????????????Index?index?=?new?Index.Builder(obj).build();??
?????????????????bulk.addAction(index);??
????????????}??
????????????BulkResult?br?=?jestClient.execute(bulk.build());??
????????????return?br.isSucceeded();??
???????????}??
??????????
????????/**
?????????*?全文搜索
?????????*?@param?indexName
?????????*?@param?typeName
?????????*?@param?query
?????????*?@return
?????????*?@throws?Exception
?????????*/
????????public?static?String?search(JestClient?jestClient,String?indexName,?String?typeName,?String?query)?throws?Exception?{??
?????????????Search?search?=?new?Search.Builder(query)
?????????????.addIndex(indexName)
?????????????.addType(typeName)??
?????????????.build();?
????????????JestResult?jr?=?jestClient.execute(search);??
//??????????System.out.println("--"+jr.getJsonString());//??????????System.out.println("--"+jr.getSourceAsObject(User.class));
????????????return?jr.getSourceAsString();??
?????????}??
??????????
??????????
????????
???????
??????????
???????/**
????????*?刪除索引
????????*?@param?indexName
????????*?@return
????????*?@throws?Exception
????????*/
????????public?boolean?delete(JestClient?jestClient,String?indexName)?throws?Exception?{??
????????????JestResult?jr?=?jestClient.execute(new?DeleteIndex.Builder(indexName).build());??
????????????return?jr.isSucceeded();??
????????}??
??????????
???????/**
????????*?刪除數(shù)據(jù)
????????*?@param?indexName
????????*?@param?typeName
????????*?@param?id
????????*?@return
????????*?@throws?Exception
????????*/
????????public?boolean?delete(JestClient?jestClient,String?indexName,?String?typeName,?String?id)?throws?Exception?{??
????????????DocumentResult?dr?=?jestClient.execute(new?Delete.Builder(id).index(indexName).type(typeName).build());??
????????????return?dr.isSucceeded();??
????????}

注:測(cè)試之前先說(shuō)明下,本地windows系統(tǒng)安裝的是ElasticSearch版本是2.3.5,linux服務(wù)器上安裝的ElasticSearch版本是6.2。

測(cè)試結(jié)果

全文搜索

全文搜索查詢(xún)語(yǔ)句:{??"from"?:?0,??"size"?:?2,??"query"?:?{????"query_string"?:?{??????"query"?:?"工程師"
????}
??}
}

全文搜索返回結(jié)果:{"id":1,"name":"張三","age":20,"description":"張三是個(gè)Java開(kāi)發(fā)工程師","createtm":"2018-4-25?11:07:42"},{"id":2,"name":"李四","age":24,"description":"李四是個(gè)測(cè)試工程師","createtm":"1980-2-15?19:01:32"}

匹配搜索

精確搜索查詢(xún)語(yǔ)句:{??"query"?:?{????"term"?:?{??????"age"?:?24
????}
??}
}

精確搜索返回結(jié)果:{"id":2,"name":"李四","age":24,"description":"李四是個(gè)測(cè)試工程師","createtm":"1980-2-15?19:01:32"}

時(shí)間區(qū)間搜索

區(qū)間搜索語(yǔ)句:{??"query"?:?{????"range"?:?{??????"createtm"?:?{????????"from"?:?"2016-8-21?06:11:32",????????"to"?:?"2018-8-21?06:11:32",????????"include_lower"?:?true,????????"include_upper"?:?true
??????}
????}
??}
}
區(qū)間搜索返回結(jié)果:{"id":1,"name":"張三","age":20,"description":"張三是個(gè)Java開(kāi)發(fā)工程師","createtm":"2018-4-25?11:07:42"}

新增完數(shù)據(jù)之后,我們可以上linux的?Kibana中進(jìn)行相關(guān)的查詢(xún),查詢(xún)結(jié)果如下:

SpringBoot整合ElasticSearch實(shí)現(xiàn)多版本的兼容

注:Kibana 是屬于ELK中一個(gè)開(kāi)源軟件。Kibana可以為 Logstash 和 ElasticSearch 提供的日志分析友好的 Web 界面,可以幫助匯總、分析和搜索重要數(shù)據(jù)日志。

上述代碼中測(cè)試返回的結(jié)果符合我們的預(yù)期。其中關(guān)于JestClient只是用到了很少的一部分,更多的使用可以查看JestClient的官方文檔。

Windows安裝ElasticSearch

1,文件準(zhǔn)備
下載地址:
https://www.elastic.co/downloads
選擇ElasticSearch相關(guān)版本, 然后選擇后綴名為ZIP文件進(jìn)行下載,下載之后進(jìn)行解壓。

2,啟動(dòng)Elasticsearch
進(jìn)入bin目錄下,運(yùn)行 elasticsearch.bat
然后在瀏覽上輸入: localhost:9200
成功顯示一下界面表示成功!
SpringBoot整合ElasticSearch實(shí)現(xiàn)多版本的兼容

3,安裝ES插件
web管理界面head 安裝
進(jìn)入bin目錄下,打開(kāi)cmd,進(jìn)入dos界面
輸入:plugin install mobz/elasticsearch-head
進(jìn)行下載
成功下載之后,在瀏覽器輸入:http://localhost:9200/_plugin/head/
若顯示一下界面,則安裝成功!
SpringBoot整合ElasticSearch實(shí)現(xiàn)多版本的兼容

4,注冊(cè)服務(wù)
進(jìn)入bin目錄下,打開(kāi)cmd,進(jìn)入dos界面
依次輸入:
service.bat install
service.bat start
成功之后,再輸入
services.msc
跳轉(zhuǎn)到Service服務(wù)界面,可以直接查看es的運(yùn)行狀態(tài)!

歡迎工作一到五年的Java工程師朋友們加入Java技術(shù)交流:659270626
群內(nèi)提供免費(fèi)的Java架構(gòu)學(xué)習(xí)資料(里面有高可用、高并發(fā)、高性能及分布式、Jvm性能調(diào)優(yōu)、Spring源碼,MyBatis,Netty,redis,Kafka,MySQL,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多個(gè)知識(shí)點(diǎn)的架構(gòu)資料)合理利用自己每一分每一秒的時(shí)間來(lái)學(xué)習(xí)提升自己,不要再用"沒(méi)有時(shí)間“來(lái)掩飾自己思想上的懶惰!趁年輕,使勁拼,給未來(lái)的自己一個(gè)交代!

網(wǎng)站名稱(chēng):SpringBoot整合ElasticSearch實(shí)現(xiàn)多版本的兼容
地址分享:http://aaarwkj.com/article14/peigge.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供、定制網(wǎng)站軟件開(kāi)發(fā)、小程序開(kāi)發(fā)、營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營(yíng)
日本大片一区二区免费看| 黑人爆操中国女孩在线观看| 亚洲av第一区综合激情久久久| 激情五月天色婷婷久久| 日韩视频一区二区三区系列| 亚洲国产日韩中文字幕| 97色伦综合在线欧美视频| 国产69精品久久一级| 国产精品久久护士96| 午夜影院免费在线观看五分钟| 久久亚洲中文字幕精品熟女| 黄色av福利在线网站| 日本一区二区三区免费看视频| 亚洲午夜经典一区二区日韩 | 精品国产一区二区三区精品日韩| 亚洲国产精品中文字幕一区久久| 成人免费大片在线观看视频| 亚洲成人自拍视频在线观看| 美女丝袜诱惑国产91| 国产高清毛片区1区二区三区| 亚洲成人午夜激情的三级网| 在线观看中文字幕日韩精品| 亚洲av成人一区二区三区| 日韩国产欧美一区二区在线视频| 亚洲天堂毛片在线观看| 午夜视频在线观看91| 国产熟女一区二区三区正在| 欧美一区二区三区久久妇| 亚洲美女毛茸茸的逼逼| 国产伦国产一区二区三区在线观看| 老色鬼久久亚洲av综合| 国内外成人皇色视频| 色悠悠粉嫩一区二区三区| 精品久久久久久亚洲野狼| 丝袜美腿亚洲综合第一区| 视频播放一区二区三区毛片| 亚洲精品一区二区三区网站| 日本乱码中文字幕在线观看| 丰满人妻的诱惑中文字幕| 亚洲国产精品一区二区av| 后入蜜桃臀美女在线观看|