集群数据存储选项

使用 etcd 以外的数据存储运行 Kubernetes 的能力使 K3s 区别于其他 Kubernetes 发行版。该功能为 Kubernetes 操作者提供了灵活性。可用的数据存储选项允许您选择一个最适合您用例的数据存储。例如:

  • 如果你的团队没有操作 etcd 的专业知识,可以选择 MySQL 或 PostgreSQL 等企业级 SQL 数据库。
  • 如果您需要在 CI/CD 环境中运行一个简单的、短暂的集群,您可以使用嵌入式 SQLite 数据库。
  • 如果你希望在边缘部署 Kubernetes,并需要一个高可用的解决方案,但又无法承担在边缘管理数据库的操作开销,你可以使用 K3s 建立在嵌入式 etcd 之上的嵌入式 HA 数据存储(目前是实验性的)。

K3s 支持以下数据存储选项:

  • 嵌入式 SQLite
  • PostgreSQL (经过认证的版本:10.7 和 11.5)
  • MySQL (经过认证的版本:5.7)
  • MariaDB (经过认证的版本:10.3.20)
  • etcd (经过认证的版本:3.3.15)
  • 嵌入式 etcd 高可用(实验性)

外部数据存储配置参数

如果你想使用外部数据存储,如 PostgreSQL、MySQL 或 etcd,你必须设置datastore-endpoint参数,以便 K3s 知道如何连接到它。你也可以指定参数来配置连接的认证和加密。下表总结了这些参数,它们可以作为 CLI 标志或环境变量传递。

CLI Flag环境变量描述
--datastore-endpointK3S_DATASTORE_ENDPOINT指定一个 PostgresSQL、MySQL 或 etcd 连接字符串。用于描述与数据存储的连接。这个字符串的结构是特定于每个后端的,详情如下。
--datastore-cafileK3S_DATASTORE_CAFILETLS 证书颁发机构(CA)文件,用于帮助确保与数据存储的通信安全。如果你的数据存储通过 TLS 服务请求,使用由自定义证书颁发机构签署的证书,你可以使用这个参数指定该 CA,这样 K3s 客户端就可以正确验证证书。
--datastore-certfileK3S_DATASTORE_CERTFILETLS 证书文件,用于对数据存储进行基于客户端证书的验证。要使用这个功能,你的数据存储必须被配置为支持基于客户端证书的认证。如果你指定了这个参数,你还必须指定datastore-keyfile参数。
--datastore-keyfileK3S_DATASTORE_KEYFILETLS 密钥文件,用于对数据存储进行基于客户端证书的认证。更多细节请参见前面的datastore-certfile参数。

作为最佳实践,我们建议将这些参数设置为环境变量,而不是命令行参数,这样你的数据库证书或其他敏感信息就不会作为进程信息的一部分暴露出来。

数据存储端点格式和功能

如前所述,传递给datastore-endpoint参数的值的格式取决于数据存储后端。下文详细介绍了每个支持的外部数据存储的格式和功能。

PostgreSQL

最常见的 PostgreSQL 数据存储端点的参数格式:

postgres://username:password@hostname:port/database-name

更多的高级配置参数,请参见 https://godoc.org/github.com/lib/pq

如果指定的数据库名称不存在,k3s server 将尝试创建它。

如果你只提供postgres://作为端点,K3s 将尝试做如下操作:

  • 使用postgres作为用户名和密码连接到 localhost
  • 创建一个名为kubernetes的数据库

MySQL/MariaDB"

最常见的 MySQL 和 MariaDB 的datastore-endpoint参数格式如下:

mysql://username:password@tcp(hostname:3306)/database-name

更多的高级配置参数,请参见 https://github.com/go-sql-driver/mysql#dsn-data-source-name

请注意,由于 K3s 中的一个已知问题,你无法设置tls参数。支持 TLS 通信,但你不能将这个参数设置为 "skip-verify "来使 K3s 跳过证书验证。

如果指定的数据库名称不存在,k3s server 将尝试创建它。

如果你只提供mysql://作为端点,K3s 将尝试做如下操作:

  • 使用 root 用户并且不使用密码连接到/var/run/mysqld/mysqld.sock上的 MySQL 套接字
  • 创建一个名为kubernetes的数据库

etcd

最常见的 etcd 的datastore-endpoint参数的格式如下:

https://etcd-host-1:2379,https://etcd-host-2:2379,https://etcd-host-3:2379

以上假设是一个典型的三节点 etcd 集群。该参数可以再接受一个以逗号分隔的 etcd URL。


基于上述情况,可以使用下面的示例命令来启动一个连接到名为 k3s 的 PostgresSQL 数据库的 k3s server 实例:
K3S_DATASTORE_ENDPOINT='postgres://username:password@hostname:5432/k3s' k3s server

而下面的例子可以用来使用客户端证书认证连接到 MySQL 数据库:

K3S_DATASTORE_ENDPOINT='mysql://username:password@tcp(hostname:3306)/k3s' \
K3S_DATASTORE_CERTFILE='/path/to/client.crt' \
K3S_DATASTORE_KEYFILE='/path/to/client.key' \
k3s server

嵌入式 DB 的高可用(实验)

请参阅嵌入式 DB 的高可用(实验)了解如何使用该选项运行。

最后由 yzeng25更新 于