文档

使用 Certbot 为 MinIO 生成 Let’s Encrypt 证书 Slack

Let’s Encrypt 是一个新的免费、自动且开源的证书颁发机构。

Certbot 是一个基于控制台的 Let’s Encrypt 证书生成工具。

在本指南中,我们将使用 Certbot 生成 Let’s Encrypt 证书。然后,此证书将被部署以供 MinIO 服务器使用。

1. 先决条件

  • 此处 安装 MinIO 服务器。

  • 此处 安装 Certbot

2. 依赖项

  • 执行 certbot 时,需要端口 443(用于 https)处于打开并可用的状态。

  • 执行 Certbot 需要 root 权限,因为只有 root 才能绑定到 1024 以下的任何端口。

  • 在本指南中,我们将使用我们自己的域名 myminio.com 作为示例。请根据您的设置替换为您自己的域名。

3. 指南步骤

步骤 1:安装 Certbot

按照 https://certbot.openssl.ac.cn/ 上的文档安装 Certbot。

步骤 2:生成 Let’s Encrypt 证书

# certbot certonly --standalone -d myminio.com --staple-ocsp -m [email protected] --agree-tos

步骤 3:验证证书

列出保存在 /etc/letsencrypt/live/myminio.com 目录中的证书。

$ ls -l /etc/letsencrypt/live/myminio.com
total 4
lrwxrwxrwx 1 root root  37 Aug  2 09:58 cert.pem -> ../../archive/myminio.com/cert4.pem
lrwxrwxrwx 1 root root  38 Aug  2 09:58 chain.pem -> ../../archive/myminio.com/chain4.pem
lrwxrwxrwx 1 root root  42 Aug  2 09:58 fullchain.pem -> ../../archive/myminio.com/fullchain4.pem
lrwxrwxrwx 1 root root  40 Aug  2 09:58 privkey.pem -> ../../archive/myminio.com/privkey4.pem
-rw-r--r-- 1 root root 543 May 10 22:07 README

步骤 4:使用证书在 MinIO 服务器上设置 SSL。

通过 Certbot 生成的证书和密钥需要放置在用户的 home 目录中。

$ cp /etc/letsencrypt/live/myminio.com/fullchain.pem /home/user/.minio/certs/public.crt
$ cp /etc/letsencrypt/live/myminio.com/privkey.pem /home/user/.minio/certs/private.key

步骤 5:更改证书的所有者。

$ sudo chown user:user /home/user/.minio/certs/private.key
$ sudo chown user:user /home/user/.minio/certs/public.crt

步骤 6:使用 HTTPS 启动 MinIO 服务器。

如果您不打算使用 root 权限运行 MinIO,则需要使用以下命令授予 MinIO 监听 1024 以下端口的能力

sudo setcap 'cap_net_bind_service=+ep' ./minio

现在,您可以在端口“443”上启动 MinIO 服务器。

$ ./minio server --address ":443" /mnt/data

如果您使用的是 MinIO 的 Docker 版本,则需要

$ sudo docker run -p 443:443 -v /home/user/.minio:/root/.minio/ -v /home/user/data:/data minio/minio server --address ":443" /data

步骤 7:在浏览器中访问 https://myminio.com

Letsencrypt