Vaultwarden

Lightweight Rust Bitwarden-compatible server for self-hosted deployments.

Acceso

  1. Abrir en el navegador: https://<SERVER_IP>
  2. Aceptar advertencia SSL (certificado autofirmado).

Disable Public Registration (Recommended)

Editar /root/vaultwarden/docker-compose.yml

Change SIGNUPS_ALLOWED: true a SIGNUPS_ALLOWED: false

Apply the changes:

docker compose -f /root/vaultwarden/docker-compose.yml up -d

Archivos y directorios importantes

  • Directorio de instalación: /root/vaultwarden
  • Crear archivo: /root/vaultwarden/docker-compose.yml
  • Directorio de datos: /root/vaultwarden/vw-data
  • Configuración de Nginx: /etc/nginx/sites-available/vaultwarden
  • TLS certificates: /etc/nginx/ssl

Gestión de servicios

Check container:

docker ps

Ver registros:

docker compose -f /root/vaultwarden/docker-compose.yml logs -f

Reiniciar el contenedor:

docker compose -f /root/vaultwarden/docker-compose.yml restart

Reiniciar Nginx:

systemctl restart nginx

Habilitar SSL con un dominio

1. Dirija su dominio a la IP del servidor.

2. Editar el /root/vaultwarden/docker-compose.yml archivo para configurar tu nombre de dominio: DOMAIN: "https://your.domain.com"

3. Recrear los servicios:

cd /root/vaultwarden/
docker compose up -d

4. Edita la configuración de Nginx y sustituye ambos server_name <IP>; con tu dominio (<your-domain>) tanto para bloques HTTP (puerto 80) como HTTPS (puerto 443):

vim /etc/nginx/sites-available/vaultwarden

5. Instalar Certbot:

apt install -y certbot python3-certbot-nginx

6. Ejecute el siguiente comando para generar un certificado Let's Encrypt válido:

certbot certonly --nginx --non-interactive --agree-tos --email [email protected] -d yourdomain.com

7. Reemplazar las rutas SSL en la configuración de Nginx (sección TLS):

vim /etc/nginx/sites-available/vaultwarden
# Before:
    # ssl_certificate /etc/nginx/ssl/fullchain.pem;
    # ssl_certificate_key /etc/nginx/ssl/privkey.pem;
# After:
    # ssl_certificate /etc/letsencrypt/live/yourdomain.com/fullchain.pem;
    # ssl_certificate_key /etc/letsencrypt/live/yourdomain.com/privkey.pem;

8. Reinicie Nginx para aplicar los cambios:

systemctl restart nginx

9. Abra su navegador y visite: https://yourdomain.com

Detalles de la solicitud