Linux 手动部署
对应的官方文档地址
这篇文章将引导你完成手动安装和部署 Bitwarden 到你自己的服务器的过程。
手动安装仅适合高级用户使用。仅当您非常熟悉 Docker 技术,并且希望对您的 Bitwarden 安装进行更多控制时才可以进行此操作。
手动安装缺乏自动更新 Bitwarden 安装所需的某些依赖项的能力。当你将 Bitwarden 从一个版本升级到下一个版本时,你将负责修改所需的环境变量,修改 nginx 的 default.conf
,修改 docker-compose.yml
等等。
我们会尽量在 GitHub 上的发行说明中强调这些。你也可以在 GitHub 上监控 Bitwarden 安装脚本所使用的依赖模板的更改。
要求
在继续安装之前,请确保 Docker Engine 和 Docker Compose 已安装并准备好在您的服务器上使用,并且您的机器符合以下系统规格:
系统规格要求
最低
推荐
处理器
x64, 1.4GHz
x64, 2GHz 双核
内存
2GB RAM
4GB RAM
存储
12GB
25GB
Docker 版本
Engine 19+ 以及 Compose 1.24+
Engine 19+ 以及 Compose 1.24+
安装步骤
创建 Bitwarden 本地用户和目录
Bitwarden 建议在你的 Linux 服务器上配置一个专用的 bitwarden
服务账户,用来安装和运行 Bitwarden。这样做可以将您的 Bitwarden 实例与服务器上运行的其他应用程序隔离开来。
这些步骤是 Bitwarden 推荐的最佳实践,但不是必须的。更多信息,请参阅 Docker 的用于 Linux 的后安装步骤文档。
1、创建 bitwarden 用户:
2、为 bitwarden 用户设置密码(强密码):
3、创建 docker 组(如果它不存在):
4、将 bitwarden 用户添加到 docker 组:
5、创建 bitwarden 目录:
6、授予 /opt/bitwarden
目录权限:
7、授予 bitwarden 用户对 /opt/bitwarden
目录的所有权:
下载和配置
要下载 Bitwarden 并配置 Bitwarden 服务器资产:
1、从 GitHub 上的发行页面下载 Bitwarden 依赖项的存档版本 (docker-stub.zip
)。例如:
2、创建一个名为 bwdata
的新目录,并将 docker-stub.zip
解压到其中,例如:
解压缩后,bwdata
目录需要与 ./docker/docker-compose.yml
文件的映射卷所期望的目录相匹配。如果您愿意,您也可以更改这些映射在主机上的位置。
3、编辑 ./bwdata/env/global.override.env
中的以下环境变量:
globalSettings__baseServiceUri__vault=
:输入您的 Bitwarden 实例的域名。globalSettings__sqlServer__ConnectionString=
:将RANDOM_DATABASE_PASSWORD
替换为在后续步骤中使用的安全密码。globalSettings__identityServer__certificatePassword
:设置一个在后续步骤中使用的安全的证书密码。globalSettings__internalIdentityKey=
:将RANDOM_IDENTITY_KEY
替换为随机密钥字符串。globalSettings__oidcIdentityClientKey=
:将RANDOM_IDENTITY_KEY
替换为随机密钥字符串。globalSettings__duo__aKey=
:将RANDOM_DUO_AKEY
替换为随机密钥字符串。globalSettings__installation__id=
:输入从 https://bitwarden.com/host 获取到的安装 ID。globalSettings__installation__key=
:输入从 https://bitwarden.com/host 获取到的安装密钥。
此时,还要考虑为所有 globalSettings__mail__smtp__
变量和 adminSettings__admins
设置值。这样做将配置用于向新组织成员发送邀请的 SMTP 邮件服务器,并提供对系统管理员门户的访问权限。
4、从 ./bwdata
为身份容器生成一个 .pfx
证书文件并将其移动到已映射的卷目录(默认为 ./bwdata/identity/
)。例如,运行以下命令:
然后
在上述命令中,将 IDENTITY_CERT_PASSWORD
替换为在步骤 3 中创建和使用的证书密码。
5、将 identity.pfx
复制到 ./bwdata/ssl
目录。
6、在 ./bwdata/ssl
中创建一个以您的域名命名的子目录,例如:
7、在新创建的 ./bwdata/ssl/bitwarden.example.com
子目录中提供受信任的 SSL 证书和私钥。
此目录映射到 NGINX 容器的 /etc/ssl
目录。如果您无法提供受信任的 SSL 证书,请在安装前使用代理,以为 Bitwarden 客户端应用程序提供一个 HTTPS 端点。
8、在 ./bwdata/nginx/default.conf
中:
将所有实例
bitwarden.example.com
替换为您的域名,包括Content-Security-Policy
标头。将
ssl_certificate
和ssl_certificate_key
变量设置为步骤 7 中提供的证书和私钥的路径。根据您的证书设置,执行以下操作之一:
如果您使用受信任的 SSL 证书,请将
ssl_trusted_certificate
变量设置为证书的路径。如果您使用自签名证书,请注释掉
ssl_trusted_certificate
变量。
9、在 ./bwdata/env/mssql.override.env
中,将 RANDOM_DATABASE_PASSWORD
替换为在步骤 3 中创建的密码。
10、在 ./bwdata/web/app-id.json
中,将 bitwarden.example.com
替换为您的域名。
11、在 ./bwdata/env/uid.env
中,设置您之前创建的 bitwarden
用户和组的 UID 和 GID,以便容器在它们下面运行,例如:
启动您的服务器
使用以下命令启动您的 Bitwarden 服务器:
验证所有容器是否正常运行:
恭喜! Bitwarden 现已启动并运行在 https://your.domain.com
了。在您的浏览器中访问网络密码库以确认其正常工作。
您现在可以注册一个新帐户并登录了。您需要配置 SMPT 环境变量(请参阅环境变量)以验证您的新帐户的电子邮件。
更新您的服务器
更新已手动安装和部署的自托管服务器与标准更新过程有所不同。要更新您手动安装的服务器:
从 GitHub 发行页面下载最新的
docker-stub.zip
存档。将此新的
docker-stub.zip
存档解压缩并将其内容与当前bwdata
目录中的内容进行比较,将任何新内容复制到bwdata
中预先存在的文件中。 不要使用此较新的docker-stub.zip
存档的内容直接覆盖您预先存在的bwdata
目录,因为这会覆盖您已经完成的任何自定义配置工作。运行以下命令以使用已更新的配置和最新的容器重新启动服务器:
最后更新于