Tableau Online
Tableau Online 可以使用官方 MySQL 数据源,通过 MySQL 接口连接到 ClickHouse Cloud 或本地部署的 ClickHouse 集群。
ClickHouse Cloud 配置
启用 MySQL 接口
切换开关以为该特定服务启用 MySQL 接口。
这将为该服务开放端口 3306,并显示一个 MySQL 连接页面,其中包含您专属的 MySQL 用户名。

或者,如需为现有服务启用 MySQL 接口:
启用 MySQL 接口
切换开关以为该特定服务启用 MySQL 接口。
这将为该服务开放端口 3306,并显示 MySQL 连接页面,其中包含您专属的 MySQL 用户名。

在 ClickHouse Cloud 中创建只读 MySQL 用户
ClickHouse Cloud 会自动创建一个 mysql4<subdomain> 用户,该用户与默认用户共享相同的密码。
<subdomain> 部分对应于你 ClickHouse Cloud 主机名的第一段。
这种用户名格式是为了兼容某些工具而必需的,这类工具会建立安全连接,但在其 TLS 握手中不包含 SNI (Server Name Indication) 数据。 在缺少 SNI 信息的情况下,系统无法执行正确的内部路由,因此嵌入在用户名中的子域名提示提供了所需的路由信息。 MySQL 控制台客户端就是此类工具的一个示例。
推荐的最佳实践是创建一个新的只读 MySQL 用户。
对于像 foobar.us-east1.aws.clickhouse.cloud 这样的 ClickHouse Cloud 主机名,<subdomain> 部分等于 foobar,自定义 MySQL 用户名可以类似于 mysql4foobar_team1。
在 ClickHouse Cloud 中排查多个 MySQL 用户相关问题
如果您创建了一个新的 MySQL 用户,并且在通过 MySQL CLI 客户端进行连接时看到如下错误:
在这种情况下,请确保用户名符合 mysql4<subdomain>_<username> 格式,具体说明见(上文)。
本地部署 ClickHouse 服务器的设置
请参阅官方文档,了解如何设置启用 MySQL 接口的 ClickHouse 服务器。
除了在服务器的 config.xml 中添加一项配置之外
同时,还必须为将使用 MySQL 接口的用户使用 Double SHA1 密码加密。
从 shell 生成一个使用 Double SHA1 加密的随机密码:
输出结果应类似如下:
第一行是生成的密码,第二行是我们可以用来配置 ClickHouse 的哈希。
下面是一个使用该生成哈希的 mysql_user 配置示例:
/etc/clickhouse-server/users.d/mysql_user.xml
将 password_double_sha1_hex 条目替换为你自己生成的双重 SHA1 哈希值。
另外,建议启用 use_mysql_types_in_show_columns,
以便在 SHOW [FULL] COLUMNS 查询结果中显示原生的 MySQL 类型,而不是 ClickHouse 类型,
从而在使用 MySQL 连接器时,让 BI 工具能够正确解析数据库模式(schema)。
例如:
/etc/clickhouse-server/users.d/mysql_user.xml
或者将其分配给其他配置文件,而不是使用默认的配置文件。
如果你已经安装了 mysql 可执行文件,可以在命令行中测试连接。
使用上面示例中的用户名(mysql_user)和密码(LZOQYnqQN4L/T6L0),命令行命令如下:
最后,配置 ClickHouse Server 监听所需的 IP 地址。例如,在 config.xml 中,取消注释以下配置项,使其监听所有地址:
将 Tableau Online 连接到 ClickHouse(本地部署且不使用 SSL)
登录 Tableau Cloud 站点并添加一个新的已发布数据源(Published Data Source)。

从可用连接器列表中选择“MySQL”。

填写在 ClickHouse 配置过程中收集到的连接信息。

Tableau Online 会自动分析数据库并提供可用表的列表。将所需的表拖动到右侧画布中。此外,你可以点击“Update Now”预览数据,并对分析得到的字段类型或名称进行微调。

之后,只需要点击右上角的“Publish As”,你就可以像往常一样在 Tableau Online 中使用新创建的数据集。
注意:如果你希望将 Tableau Online 与 Tableau Desktop 配合使用并在它们之间共享 ClickHouse 数据集,请确保在 Tableau Desktop 中同样使用默认的 MySQL 连接器,并按照在数据源下拉框中选择 MySQL 时显示的此设置指南进行配置。如果你使用的是 M1 Mac,请参阅此故障排查讨论帖以获取驱动安装的替代安装方法。
将 Tableau Online 连接到 ClickHouse(Cloud 或本地部署,使用 SSL)
由于无法通过 Tableau Online 的 MySQL 连接设置向导提供 SSL 证书, 唯一的方法是先使用 Tableau Desktop 完成连接设置,然后将其导出并发布到 Tableau Online。不过,这个流程相对比较简单。
在一台 Windows 或 Mac 机器上运行 Tableau Desktop,然后选择 "Connect" -> "To a Server" -> "MySQL"。 通常需要先在本机安装 MySQL 驱动。 可以在 Data Source 下拉菜单中选择 MySQL 后,按照此处显示的安装指南进行操作。 如果你使用的是 M1 Mac,请参考这个故障排查讨论帖获取安装驱动的替代方案。

在 MySQL 连接设置界面中,确保启用了 "SSL" 选项。 ClickHouse Cloud 的 SSL 证书由 Let's Encrypt 签发。 你可以在这里下载该根证书。
填写 ClickHouse Cloud 实例的 MySQL 用户凭据,以及刚刚下载的根证书路径。

像平常一样选择所需的表(与在 Tableau Online 中类似), 然后选择 "Server" -> "Publish Data Source" -> Tableau Cloud。

重要:在 "Authentication" 选项中,需要选择 "Embedded password"。

此外,勾选 "Update workbook to use the published data source"。

最后,点击 "Publish",带有内嵌凭据的数据源会在 Tableau Online 中自动打开。
已知限制(ClickHouse 23.11)
所有已知限制均已在 ClickHouse 23.11 中修复。如果您遇到任何其他不兼容问题,请随时联系我们或创建一个新的 issue。


