From 527370c7debce440ce1c174d4f6cc1b035c5d047 Mon Sep 17 00:00:00 2001 From: Guillaume Smet Date: Thu, 28 Nov 2024 11:55:04 +0100 Subject: [PATCH] Drop mentions of quarkus.ssl.native=false in Hibernate Search guides I don't think it's a good idea to promote disabling SSL globally and it has been causing issues for users as evidenced in: https://quarkusio.zulipchat.com/#narrow/channel/187030-users/topic/Hibernate.20Search.20-.20Failed.20to.20start.20quarkus Note that the issue was due to a bug in another area but still. --- .../hibernate-search-orm-elasticsearch.adoc | 25 ++++++++----------- ...rnate-search-standalone-elasticsearch.adoc | 19 ++++++-------- 2 files changed, 19 insertions(+), 25 deletions(-) diff --git a/docs/src/main/asciidoc/hibernate-search-orm-elasticsearch.adoc b/docs/src/main/asciidoc/hibernate-search-orm-elasticsearch.adoc index 674de2b0c9248..c856125afe886 100644 --- a/docs/src/main/asciidoc/hibernate-search-orm-elasticsearch.adoc +++ b/docs/src/main/asciidoc/hibernate-search-orm-elasticsearch.adoc @@ -627,32 +627,29 @@ Edit `src/main/resources/application.properties` and inject the following config [source,properties] ---- -quarkus.ssl.native=false <1> +quarkus.datasource.db-kind=postgresql <1> -quarkus.datasource.db-kind=postgresql <2> +quarkus.hibernate-orm.sql-load-script=import.sql <2> -quarkus.hibernate-orm.sql-load-script=import.sql <3> +quarkus.hibernate-search-orm.elasticsearch.version=8 <3> +quarkus.hibernate-search-orm.indexing.plan.synchronization.strategy=sync <4> -quarkus.hibernate-search-orm.elasticsearch.version=8 <4> -quarkus.hibernate-search-orm.indexing.plan.synchronization.strategy=sync <5> - -%prod.quarkus.datasource.jdbc.url=jdbc:postgresql://localhost/quarkus_test <6> +%prod.quarkus.datasource.jdbc.url=jdbc:postgresql://localhost/quarkus_test %prod.quarkus.datasource.username=quarkus_test %prod.quarkus.datasource.password=quarkus_test %prod.quarkus.hibernate-orm.database.generation=create -%prod.quarkus.hibernate-search-orm.elasticsearch.hosts=localhost:9200 <6> +%prod.quarkus.hibernate-search-orm.elasticsearch.hosts=localhost:9200 <5> ---- -<1> We won't use SSL, so we disable it to have a more compact native executable. -<2> Let's create a PostgreSQL datasource. -<3> We load some initial data on startup (see <>). -<4> We need to tell Hibernate Search about the version of Elasticsearch we will use. +<1> Let's create a PostgreSQL datasource. +<2> We load some initial data on startup (see <>). +<3> We need to tell Hibernate Search about the version of Elasticsearch we will use. It is important because there are significant differences between Elasticsearch mapping syntax depending on the version. Since the mapping is created at build time to reduce startup time, Hibernate Search cannot connect to the cluster to automatically detect the version. Note that, for OpenSearch, you need to prefix the version with `opensearch:`; see <>. -<5> This means that we wait for the entities to be searchable before considering a write complete. +<4> This means that we wait for the entities to be searchable before considering a write complete. On a production setup, the `write-sync` default will provide better performance. Using `sync` is especially important when testing as you need the entities to be searchable immediately. -<6> For development and tests, we rely on <>, +<5> For development and tests, we rely on <>, which means Quarkus will start a PostgreSQL database and Elasticsearch cluster automatically. In production mode, however, we will want to start a PostgreSQL database and Elasticsearch cluster manually, diff --git a/docs/src/main/asciidoc/hibernate-search-standalone-elasticsearch.adoc b/docs/src/main/asciidoc/hibernate-search-standalone-elasticsearch.adoc index bf2b4ef7dd14c..fc4f742d8c1c1 100644 --- a/docs/src/main/asciidoc/hibernate-search-standalone-elasticsearch.adoc +++ b/docs/src/main/asciidoc/hibernate-search-standalone-elasticsearch.adoc @@ -559,31 +559,28 @@ Edit `src/main/resources/application.properties` and inject the following config [source,properties] ---- -quarkus.ssl.native=false <1> +quarkus.hibernate-search-standalone.mapping.structure=document <1> +quarkus.hibernate-search-standalone.elasticsearch.version=8 <2> +quarkus.hibernate-search-standalone.indexing.plan.synchronization.strategy=sync <3> -quarkus.hibernate-search-standalone.mapping.structure=document <2> -quarkus.hibernate-search-standalone.elasticsearch.version=8 <3> -quarkus.hibernate-search-standalone.indexing.plan.synchronization.strategy=sync <4> - -%prod.quarkus.hibernate-search-standalone.elasticsearch.hosts=localhost:9200 <5> +%prod.quarkus.hibernate-search-standalone.elasticsearch.hosts=localhost:9200 <4> ---- -<1> We won't use SSL, so we disable it to have a more compact native executable. -<2> We need to tell Hibernate Search about the structure of our entities. +<1> We need to tell Hibernate Search about the structure of our entities. + In this application we consider an indexed entity (the author) is the root of a "document": the author "owns" books it references through associations, which *cannot* be updated independently of the author. + See <> for other options and more details. -<3> We need to tell Hibernate Search about the version of Elasticsearch we will use. +<2> We need to tell Hibernate Search about the version of Elasticsearch we will use. + It is important because there are significant differences between Elasticsearch mapping syntax depending on the version. Since the mapping is created at build time to reduce startup time, Hibernate Search cannot connect to the cluster to automatically detect the version. Note that, for OpenSearch, you need to prefix the version with `opensearch:`; see <>. -<4> This means that we wait for the entities to be searchable before considering a write complete. +<3> This means that we wait for the entities to be searchable before considering a write complete. On a production setup, the `write-sync` default will provide better performance. Using `sync` is especially important when testing as you need the entities to be searchable immediately. -<5> For development and tests, we rely on <>, +<4> For development and tests, we rely on <>, which means Quarkus will start an Elasticsearch cluster automatically. In production mode, however, we will want to start an Elasticsearch cluster manually,