国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > Java > 正文

Spring Boot與Kotlin 整合全文搜索引擎Elasticsearch的示例代碼

2024-07-13 10:17:25
字體:
來源:轉載
供稿:網友

Elasticsearch 在全文搜索里面基本是無敵的,在大數據里面也很有建樹,完全可以當nosql(本來也是nosql)使用。

這篇文章簡單介紹Spring Boot使用Kotlin語言連接操作 Elasticsearch。但是不會做很詳細的介紹,如果要深入了解Elasticsearch在Java/kotlin中的使用,請參考我之前編寫的《Elasticsearch Java API 手冊》 https://gitee.com/quanke/elasticsearch-java/ 里面包含使用實例,包含我們使用踩過的坑。

如果完全不了解Elasticsearch請先了解,安裝好Elasticsearch服務

有多種方式連接Elasticsearch

  1. Spring Data Elasticsearch
  2. elasticsearch Java client
  3. 其他第三方庫

需要注意的是,如果使用Spring Data Elasticsearch,spring boot 1.5++版本的不支持最新版本的elasticsearch。

下面是spring data elasticsearch 和elasticsearch對應的版本

 

spring data elasticsearch elasticsearch
3.0.0.RC2 5.5.0
3.0.0.M4 5.4.0
2.0.4.RELEASE 2.4.0
2.0.0.RELEASE 2.2.0
1.4.0.M1 1.7.3
1.3.0.RELEASE 1.5.2
1.2.0.RELEASE 1.4.4
1.1.0.RELEASE 1.3.2
1.0.0.RELEASE 1.1.1

 

我們使用的 Elasticsearch 版本是 5.5.6 , spring boot 使用的版本是 1.5.6 而且支持 Elasticsearch5.0 以上的版本的 spring data elasticsearch 還不是 RELEASE 版本,所有我們采用的是 elasticsearch Java client 的方式,但是現在官方推薦更好的方式可以參考我寫的《Elasticsearch Java Rest API 手冊》 https://gitee.com/quanke/elasticsearch-java-rest ,但是這篇文章還是使用 elasticsearch Java client

構建Spring Boot Kotlin 項目

如果構建項目有問題的您,可以參考我之前的文章《使用Spring Boot和Kotlin創建RESTfull API》

使用 Gradle 構建,在 build.gradle 文件中添加

dependencies { compile "org.elasticsearch:elasticsearch:$elasticsearch_version" compile "org.elasticsearch.client:transport:$elasticsearch_version"}

完整的 build.gradle 文件

group 'name.quanke.kotlin'version '1.0-SNAPSHOT'buildscript { ext.kotlin_version = '1.2.10' ext.spring_boot_version = '1.5.4.RELEASE' ext.springfox_swagger2_version = '2.7.0' ext.mysql_version = '5.1.21' ext.mybatis_version = '1.1.1' ext.elasticsearch_version = '5.5.1' ext.fastjson_version = '1.2.7' repositories {  mavenCentral() } dependencies {  classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"  classpath("org.springframework.boot:spring-boot-gradle-plugin:$spring_boot_version")//  Kotlin整合SpringBoot的默認無參構造函數,默認把所有的類設置open類插件  classpath("org.jetbrains.kotlin:kotlin-noarg:$kotlin_version")  classpath("org.jetbrains.kotlin:kotlin-allopen:$kotlin_version") }}apply plugin: 'kotlin'apply plugin: "kotlin-spring" // See https://kotlinlang.org/docs/reference/compiler-plugins.html#kotlin-spring-compiler-pluginapply plugin: 'org.springframework.boot'apply plugin: "kotlin-jpa" //https://stackoverflow.com/questions/32038177/kotlin-with-jpa-default-constructor-helljar { baseName = 'chapter11-6-8-service' version = '0.1.0'}repositories { mavenCentral()}dependencies { compile "org.jetbrains.kotlin:kotlin-stdlib-jre8:$kotlin_version" compile("org.jetbrains.kotlin:kotlin-reflect:${kotlin_version}") compile "org.springframework.boot:spring-boot-starter-web:$spring_boot_version" compile "org.elasticsearch:elasticsearch:$elasticsearch_version" compile "org.elasticsearch.client:transport:$elasticsearch_version" compile "com.alibaba:fastjson:$fastjson_version" compile "org.apache.commons:commons-lang3:3.6" testCompile "org.springframework.boot:spring-boot-starter-test:$spring_boot_version" testCompile "org.jetbrains.kotlin:kotlin-test-junit:$kotlin_version"}compileKotlin { kotlinOptions.jvmTarget = "1.8"}compileTestKotlin { kotlinOptions.jvmTarget = "1.8"}

先寫測試基類 ElasticsearchClient

import com.alibaba.fastjson.JSONimport com.alibaba.fastjson.serializer.SerializerFeatureimport org.elasticsearch.action.search.SearchResponseimport org.elasticsearch.client.transport.TransportClientimport org.elasticsearch.common.settings.Settingsimport org.elasticsearch.common.transport.InetSocketTransportAddressimport org.elasticsearch.transport.client.PreBuiltTransportClientimport org.junit.Afterimport org.junit.Beforeimport java.net.InetAddress/** * Elasticsearch 5.5.1 的client 和 ElasticsearchTemplate的初始化 * 作為一個外部訪問者,請求ES的集群,對于集群而言,它是一個外部因素。 * Created by http://quanke.name on 2017/11/10. */open class ElasticsearchClient { protected var client: TransportClient? = null @Before @Throws(Exception::class) fun setUp() {  val esSettings = Settings.builder()    .put("cluster.name", "utan-es") //設置ES實例的名稱    .put("client.transport.sniff", true) //自動嗅探整個集群的狀態,把集群中其他ES節點的ip添加到本地的客戶端列表中    .build()  /**   * 這里的連接方式指的是沒有安裝x-pack插件,如果安裝了x-pack則參考 [ElasticsearchXPackClient]   * 1. java客戶端的方式是以tcp協議在9300端口上進行通信   * 2. http客戶端的方式是以http協議在9200端口上進行通信   */  client = PreBuiltTransportClient(esSettings)    .addTransportAddress(InetSocketTransportAddress(InetAddress.getByName("192.168.1.10"), 9300))  println("ElasticsearchClient 連接成功") } @After @Throws(Exception::class) fun tearDown() {  if (client != null) {   client!!.close()  } } protected fun println(searchResponse: SearchResponse) {  val searchHits = searchResponse.hits.hits  for (searchHit in searchHits) {   println(JSON.toJSONString(searchHit.source, SerializerFeature.PrettyFormat))  } }}

運行單元測試

import org.elasticsearch.index.query.QueryBuilders.matchAllQueryimport org.junit.Testimport org.junit.runner.RunWithimport org.springframework.boot.test.context.SpringBootTestimport org.springframework.test.context.junit4.SpringRunner/** * Created by http://quanke.name on 2018/1/9. */@RunWith(SpringRunner::class)@SpringBootTestclass ApplicationTests : ElasticsearchClient() { @Test fun `es test"`() {  val qb = matchAllQuery()  val response = client!!.prepareSearch("twitter")//可以是多個index    .setTypes("tweet")//可以是多個類型    .setQuery(qb) // Query 查詢條件    .get()  println(response) }}

我們寫了一個 dayu-spring-boot-starter-es ,有機會開源出來

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宣汉县| 汽车| 宁陵县| 嘉善县| 康定县| 河间市| 炎陵县| 岳西县| 新建县| 闻喜县| 连州市| 青神县| 鄢陵县| 马尔康县| 三门峡市| 辽阳市| 崇明县| 丽水市| 类乌齐县| 彭阳县| 承德市| 勃利县| 通州市| 万全县| 沿河| 阳山县| 乌苏市| 郑州市| 峨眉山市| 咸宁市| 大连市| 临潭县| 白朗县| 周口市| 通榆县| 抚松县| 巩留县| 泸溪县| 那曲县| 南汇区| 和林格尔县|