
Vaultwarden是一个开源的密码管理解决方案,它允许用户安全地存储和管理密码、信用卡信息及密码提示等敏感数据。通过自行托管 Vaultwarden,用户能够完全掌控自己的数据,避免将个人信息存储在第三方服务中,从而增强隐私保护和数据安全性。此外,Vaultwarden 提供了便捷的工具和界面,使得管理和访问这些敏感信息变得简单而高效。
本次实践为个人测试环境,操作系统版本为|Ubuntu 22.04.1。
hostname | IP地址 | 操作系统版本 | Docker版本 | 部署项目 |
|---|---|---|---|---|
jeven01 | 192.168.3.88 | Ubuntu 22.04.1 LTS | 27.1.1 | vaultwarden |
1.本次实践部署环境为个人测试环境,生产环境请谨慎;
2.在Docker环境下部署vaultwarden密码管理工具。
检查Docker服务是否正常运行,确保Docker正常运行。
root@jeven01:~# systemctl status docker
● docker.service - Docker Application Container Engine
Loaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled)
Active: active (running) since Wed 2025-04-02 05:59:08 UTC; 4min 6s ago
TriggeredBy: ● docker.socket
Docs: https://docs.docker.com
Main PID: 906 (dockerd)
Tasks: 29
Memory: 143.2M
CPU: 1.172s
CGroup: /system.slice/docker.service检查Docker版本
root@jeven01:~# docker -v
Docker version 27.1.1, build 6312585检查Docker compose版本,确保2.0以上版本。
root@jeven01:~# docker compose version
Docker Compose version v2.19.1拉取vaultwarden镜像,拉取相关镜像如下所示:
root@jeven01:~# docker pull vaultwarden/server:latest
latest: Pulling from vaultwarden/server
Digest: sha256:87edb99945da91bd7504ac1435495595af2e89ad2c7adc151ae5bf091ec8baf2
Status: Image is up to date for vaultwarden/server:latest
docker.io/vaultwarden/server:latestmkdir -p /data/vaultwarden && cd /data/vaultwardendocker pull vaultwarden/server:latest
docker run --detach --name vaultwarden \
--env DOMAIN="https://vw.domain.tld" \
--volume /vw-data/:/data/ \
--restart unless-stopped \
--publish 80:80 \
vaultwarden/server:latest在`部署目录下,创建docker-compose.yaml文件,如下所示:
vim docker-compose.yamlservices:
vaultwarden:
image: vaultwarden/server:latest
container_name: vaultwarden
restart: unless-stopped
environment:
DOMAIN: "https://vw.domain.tld"
volumes:
- ./vw-data/:/data/
ports:
- 5980:80备注:所有环境变量,可参考官方:https://github.com/dani-garcia/vaultwarden/blob/main/.env.template。
执行以下命令,创建vaultwarden容器。
docker compose up -d
检查建vaultwarden容器运行状态,确保建vaultwarden容器正常启动。
root@jeven01:/data/vaultwarden# docker compose ps
NAME IMAGE COMMAND SERVICE CREATED STATUS PORTS
vaultwarden vaultwarden/server:latest "/start.sh" vaultwarden 53 seconds ago Up 52 seconds (health: starting) 0.0.0.0:5980->80/tcp, :::5980->80/tcpdocker compose logs
apt install nginx -y
openssl genrsa -out nginx.key 2048
openssl req -new -key nginx.key -out nginx.csr
openssl x509 -req -in nginx.csr -signkey nginx.key -out nginx.pemmv /etc/nginx/nginx.conf /etc/nginx/nginx.conf.bak # 备份配置文件vim /etc/nginx/nginx.conf#user nobody;
worker_processes 1;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
# upstream web {
# server 192.168.3.166;
# }
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
root html;
index index.html index.htm;
proxy_pass http://192.168.3.88:5980;
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ \.php$ {
# root html;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
# include fastcgi_params;
#}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /\.ht {
# deny all;
#}
}
# another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
# listen 8000;
# listen somename:8080;
# server_name somename alias another.alias;
# location / {
# root html;
# index index.html index.htm;
# }
#}
# HTTPS server
#
server {
listen 443 ssl;
server_name localhost;
ssl_certificate /data/vaultwarden/nginx.pem;
ssl_certificate_key /data/vaultwarden/nginx.key;
ssl_session_cache shared:SSL:1m;
ssl_session_timeout 5m;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
location / {
root html;
index index.html index.htm;
proxy_pass http://192.168.3.88:5980;
}
}
}systemctl restart nginx浏览器地址:
https://<个人的服务器IP>,访问vaultwarden的初始页。注意需要https访问,使用http访问会直接访问失败。如果无法访问,请确保宿主机的防火墙已关闭或已放行相关端口,对于云服务器还需配置相应的安全组规则。

选择注册账号,自定义注册账号即可。

注册完毕后,重新登录,访问vaultwarden首页。



通过本次实践,我们成功使用Docker部署了vaultwarden开源工作管理工具,并配置了Nginx作为反向代理来增强访问的安全性和灵活性。过程中不仅加深了对Docker容器化部署和管理的理解,也实践了如何为Web服务配置HTTPS访问,提升了项目的实战能力。此外,这次部署也为后续类似项目提供了一个可借鉴的模板,特别是在安全和效率方面提供了宝贵的经验。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。