diff --git a/docs/src/main/sphinx/connector/clickhouse.md b/docs/src/main/sphinx/connector/clickhouse.md
index 0da7a863bb28..4164f1647f27 100644
--- a/docs/src/main/sphinx/connector/clickhouse.md
+++ b/docs/src/main/sphinx/connector/clickhouse.md
@@ -19,7 +19,7 @@ from different catalogs accessing ClickHouse or any other supported data source.
To connect to a ClickHouse server, you need:
-- ClickHouse (version 23.8 or higher) or Altinity (version 21.8 or higher).
+- ClickHouse (version 24.3 or higher) or Altinity (version 22.3 or higher).
- Network access from the Trino coordinator and workers to the ClickHouse
server. Port 8123 is the default port.
diff --git a/plugin/trino-clickhouse/pom.xml b/plugin/trino-clickhouse/pom.xml
index 860d259d6fb0..7b2cebdc056c 100644
--- a/plugin/trino-clickhouse/pom.xml
+++ b/plugin/trino-clickhouse/pom.xml
@@ -21,7 +21,6 @@
com.clickhouse
clickhouse-jdbc
- all
@@ -113,6 +112,14 @@
runtime
+
+
+
+ org.lz4
+ lz4-java
+ runtime
+
+
io.airlift
junit-extensions
diff --git a/plugin/trino-clickhouse/src/test/java/io/trino/plugin/clickhouse/TestClickHouseConnectorTest.java b/plugin/trino-clickhouse/src/test/java/io/trino/plugin/clickhouse/TestClickHouseConnectorTest.java
index 4069feced7f8..44035e20c684 100644
--- a/plugin/trino-clickhouse/src/test/java/io/trino/plugin/clickhouse/TestClickHouseConnectorTest.java
+++ b/plugin/trino-clickhouse/src/test/java/io/trino/plugin/clickhouse/TestClickHouseConnectorTest.java
@@ -709,24 +709,11 @@ protected TestTable simpleTable()
return new TestTable(onRemoteDatabase(), "tpch.simple_table", "(col BIGINT) Engine=Log", ImmutableList.of("1", "2"));
}
- @Test
@Override
- public void testCreateTableWithLongTableName()
+ protected void verifyTableNameLengthFailurePermissible(Throwable e)
{
- // Override because ClickHouse connector can create a table which can't be dropped
- String baseTableName = "test_create_" + randomNameSuffix();
- String validTableName = baseTableName + "z".repeat(maxTableNameLength().orElseThrow() - baseTableName.length());
-
- assertUpdate("CREATE TABLE " + validTableName + " (a bigint)");
- assertThat(getQueryRunner().tableExists(getSession(), validTableName)).isTrue();
- assertThatThrownBy(() -> assertUpdate("DROP TABLE " + validTableName))
- .hasMessageMatching("(?s).*(Bad path syntax|File name too long).*");
-
- String invalidTableName = baseTableName + "z".repeat(maxTableNameLength().orElseThrow() - baseTableName.length() + 1);
- assertThat(query("CREATE TABLE " + invalidTableName + " (a bigint)"))
- .failure().hasMessageMatching("(?s).*(Cannot open file|File name too long).*");
- // ClickHouse lefts a table even if the above statement failed
- assertThat(getQueryRunner().tableExists(getSession(), validTableName)).isTrue();
+ assertThat(e).hasMessageContaining("The max length of table name for database tpch is %d, current length is %d"
+ .formatted(maxTableNameLength().orElseThrow(), maxTableNameLength().orElseThrow() + 1));
}
@Test
@@ -767,31 +754,6 @@ protected void verifySchemaNameLengthFailurePermissible(Throwable e)
assertThat(e).hasMessageContaining("File name too long");
}
- @Test
- @Override
- public void testRenameTableToLongTableName()
- {
- // Override because ClickHouse connector can rename to a table which can't be dropped
- String sourceTableName = "test_source_long_table_name_" + randomNameSuffix();
- assertUpdate("CREATE TABLE " + sourceTableName + " AS SELECT 123 x", 1);
-
- String baseTableName = "test_target_long_table_name_" + randomNameSuffix();
- // The max length is different from CREATE TABLE case
- String validTargetTableName = baseTableName + "z".repeat(255 - ".sql".length() - baseTableName.length());
-
- assertUpdate("ALTER TABLE " + sourceTableName + " RENAME TO " + validTargetTableName);
- assertThat(getQueryRunner().tableExists(getSession(), validTargetTableName)).isTrue();
- assertQuery("SELECT x FROM " + validTargetTableName, "VALUES 123");
- assertThatThrownBy(() -> assertUpdate("DROP TABLE " + validTargetTableName))
- .hasMessageMatching("(?s).*(Bad path syntax|File name too long).*");
-
- assertUpdate("CREATE TABLE " + sourceTableName + " AS SELECT 123 x", 1);
- String invalidTargetTableName = validTargetTableName + "z";
- assertThatThrownBy(() -> assertUpdate("ALTER TABLE " + sourceTableName + " RENAME TO " + invalidTargetTableName))
- .hasMessageMatching("(?s).*(Cannot rename|File name too long).*");
- assertThat(getQueryRunner().tableExists(getSession(), invalidTargetTableName)).isFalse();
- }
-
@Test
@Override // Override because the failure message differs
public void testNativeQueryIncorrectSyntax()
@@ -1179,7 +1141,7 @@ public void testExecuteProcedureWithInvalidQuery()
protected OptionalInt maxTableNameLength()
{
// The numeric value depends on file system
- return OptionalInt.of(255 - ".sql.detached".length());
+ return OptionalInt.of(209);
}
@Override
diff --git a/plugin/trino-clickhouse/src/test/java/io/trino/plugin/clickhouse/TestingClickHouseServer.java b/plugin/trino-clickhouse/src/test/java/io/trino/plugin/clickhouse/TestingClickHouseServer.java
index 1b1d843e1acf..4d017b2a8120 100644
--- a/plugin/trino-clickhouse/src/test/java/io/trino/plugin/clickhouse/TestingClickHouseServer.java
+++ b/plugin/trino-clickhouse/src/test/java/io/trino/plugin/clickhouse/TestingClickHouseServer.java
@@ -27,15 +27,23 @@
public class TestingClickHouseServer
implements Closeable
{
+ // https://clickhouse.com/docs/en/faq/operations/production#how-to-choose-between-clickhouse-releases
+ // * stable is the kind of package we recommend by default.
+ // They are released roughly monthly (and thus provide new features with reasonable delay)
+ // and three latest stable releases are supported in terms of diagnostics and backporting of bugfixes.
+ // * lts are released twice a year and are supported for a year after their initial release.
+ // versioning schema: https://kb.altinity.com/altinity-kb-setup-and-maintenance/clickhouse-versions/
private static final DockerImageName CLICKHOUSE_IMAGE = DockerImageName.parse("clickhouse/clickhouse-server");
- public static final DockerImageName CLICKHOUSE_LATEST_IMAGE = CLICKHOUSE_IMAGE.withTag("24.1.8.22"); // EOL by Apr 2025
- public static final DockerImageName CLICKHOUSE_DEFAULT_IMAGE = CLICKHOUSE_IMAGE.withTag("23.8.12.13"); // EOL by Jun 2024
+ // https://clickhouse.com/docs/en/whats-new/changelog#-clickhouse-release-2412-2024-12-19
+ public static final DockerImageName CLICKHOUSE_LATEST_IMAGE = CLICKHOUSE_IMAGE.withTag("24.12.1.1614"); // EOL in 3 releases after 2024-12-19
+ // https://clickhouse.com/docs/en/whats-new/changelog#-clickhouse-release-243-lts-2024-03-27
+ public static final DockerImageName CLICKHOUSE_DEFAULT_IMAGE = CLICKHOUSE_IMAGE.withTag("24.3.14.35"); // EOL in 1 year after 2024-03-27
// Altinity Stable Builds Life-Cycle Table https://docs.altinity.com/altinitystablebuilds/#altinity-stable-builds-life-cycle-table
- // On Mac/arm try `21.8.12.29.altinitydev.arm` instead of the specified stable build
+ // On Mac/arm 23.3.13.7.altinitystable, 23.8.8.21.altinitystable and 22.8.15.25.altinitystable and later versions available on ARM.
private static final DockerImageName ALTINITY_IMAGE = DockerImageName.parse("altinity/clickhouse-server").asCompatibleSubstituteFor("clickhouse/clickhouse-server");
- public static final DockerImageName ALTINITY_LATEST_IMAGE = ALTINITY_IMAGE.withTag("23.8.8.21.altinitystable"); // EOL is 27 Dec 2026
- public static final DockerImageName ALTINITY_DEFAULT_IMAGE = ALTINITY_IMAGE.withTag("21.8.15.15.altinitystable"); // EOL is 30 Aug 2024
+ public static final DockerImageName ALTINITY_LATEST_IMAGE = ALTINITY_IMAGE.withTag("24.3.12.76.altinitystable"); // EOL is 23 Jul 2027
+ public static final DockerImageName ALTINITY_DEFAULT_IMAGE = ALTINITY_IMAGE.withTag("22.3.15.34.altinitystable"); // EOL is 15 Jul 2025
private final ClickHouseContainer dockerContainer;
@@ -66,7 +74,10 @@ public void execute(String sql)
public String getJdbcUrl()
{
- return format("jdbc:clickhouse://%s:%s/", dockerContainer.getHost(),
+ // externalDatabase=false is needed because Schema listing fetch is extremely slow on Clickhouse-server 24.3+
+ // https://github.com/ClickHouse/clickhouse-java/issues/1245
+ // https://github.com/ClickHouse/clickhouse-java/issues/1584
+ return format("jdbc:clickhouse://%s:%s/?externalDatabase=false", dockerContainer.getHost(),
dockerContainer.getMappedPort(8123));
}
diff --git a/pom.xml b/pom.xml
index 492ba2be73c8..9bb7dae9c0a1 100644
--- a/pom.xml
+++ b/pom.xml
@@ -462,8 +462,7 @@
com.clickhouse
clickhouse-jdbc
- 0.6.3
- all
+ 0.7.1-patch1
@@ -2282,6 +2281,14 @@
+
+
+
+ org.lz4
+ lz4-java
+ 1.8.0
+
+
org.mariadb.jdbc
mariadb-java-client
@@ -2602,6 +2609,13 @@
org.basepom.maven
duplicate-finder-maven-plugin
+
+
+
+ com.clickhouse
+ clickhouse-jdbc
+
+
diff --git a/testing/trino-product-tests-launcher/src/main/java/io/trino/tests/product/launcher/env/environment/EnvMultinodeClickhouse.java b/testing/trino-product-tests-launcher/src/main/java/io/trino/tests/product/launcher/env/environment/EnvMultinodeClickhouse.java
index 0eb754dc2002..04c4ceff174c 100644
--- a/testing/trino-product-tests-launcher/src/main/java/io/trino/tests/product/launcher/env/environment/EnvMultinodeClickhouse.java
+++ b/testing/trino-product-tests-launcher/src/main/java/io/trino/tests/product/launcher/env/environment/EnvMultinodeClickhouse.java
@@ -23,6 +23,7 @@
import io.trino.tests.product.launcher.env.common.TestsEnvironment;
import io.trino.tests.product.launcher.testcontainers.PortBinder;
import org.testcontainers.containers.startupcheck.IsRunningStartupCheckStrategy;
+import org.testcontainers.utility.DockerImageName;
import java.io.IOException;
import java.io.UncheckedIOException;
@@ -47,6 +48,8 @@ public class EnvMultinodeClickhouse
{
private static final String ZOOKEEPER = "zookeeper";
+ private static final DockerImageName CLICKHOUSE_IMAGE = DockerImageName.parse("clickhouse/clickhouse-server"); // see TestingClickHouseServer for details
+ private static final DockerImageName CLICKHOUSE_DEFAULT_IMAGE = CLICKHOUSE_IMAGE.withTag("24.3.14.35"); // EOL in 1 year after 2024-03-27
private static final String CLICKHOUSE = "clickhouse";
private static final String CLICKHOUSE_NTH = CLICKHOUSE + "-";
private static final String CONTAINER_CLICKHOUSE_CONFIG_DIR = "/etc/clickhouse-server/";
@@ -109,7 +112,7 @@ private static DockerContainer createClickHouse(int number, DockerFiles dockerFi
int httpPort = CLICKHOUSE_DEFAULT_HTTP_PORT + number;
int nativePort = CLICKHOUSE_DEFAULT_NATIVE_PORT + number;
- DockerContainer container = new DockerContainer("yandex/clickhouse-server:21.3.2.5", logicalName(number))
+ DockerContainer container = new DockerContainer(CLICKHOUSE_DEFAULT_IMAGE.toString(), logicalName(number))
.withCopyFileToContainer(
forHostPath(dockerFiles.getDockerFilesHostPath("conf/environment/multinode-clickhouse/test.xml")),
CONTAINER_CLICKHOUSE_USERS_D + "test.xml")
diff --git a/testing/trino-product-tests/pom.xml b/testing/trino-product-tests/pom.xml
index b524d674de83..e7938546608a 100644
--- a/testing/trino-product-tests/pom.xml
+++ b/testing/trino-product-tests/pom.xml
@@ -230,7 +230,6 @@
com.clickhouse
clickhouse-jdbc
- all
runtime
@@ -284,6 +283,14 @@
runtime
+
+
+
+ org.lz4
+ lz4-java
+ runtime
+
+
org.mariadb.jdbc
mariadb-java-client