美文网首页Linux中国::开源热点 Linux中国::技术专栏
使用 Bitwarden 和 Podman 管理你的密码

使用 Bitwarden 和 Podman 管理你的密码

作者: Linux技术 | 来源:发表于2019-08-04 15:14 被阅读3次

在过去的一年中,你可能会遇到一些试图向你推销密码管理器的广告。比如 LastPass1Password 或 Dashlane。密码管理器消除了记住所有网站密码的负担。你不再需要使用重复或容易记住的密码。相反,你只需要记住一个可以解锁所有其他密码的密码。

通过使用一个强密码而​​不是许多弱密码,这可以使你更安全。如果你有基于云的密码管理器(例如 LastPass、1Password 或 Dashlane),你还可以跨设备同步密码。不幸的是,这些产品都不是开源的。幸运的是,还有其他开源替代品。

开源密码管理器

替代方案包括 Bitwarden、LessPass 或 KeePass。Bitwarden 是一款开源密码管理器,它会将所有密码加密存储在服务器上,它的工作方式与 LastPass、1Password 或 Dashlane 相同。LessPass 有点不同,因为它专注于成为无状态密码管理器。这意味着它根据主密码、网站和用户名生成密码,而不是保存加密的密码。另一方面,KeePass 是一个基于文件的密码管理器,它的插件和应用具有很大的灵活性。

这三个应用中的每一个都有其自身的缺点。Bitwarden 将所有东西保存在一个地方,并通过其 API 和网站接口暴露给网络。LessPass 无法保存自定义密码,因为它是无状态的,因此你需要使用它生成的密码。KeePass 是一个基于文件的密码管理器,因此无法在设备之间轻松同步。你可以使用云存储和 WebDAV 来解决此问题,但是有许多客户端不支持它,如果设备无法正确同步,你可能会遇到文件冲突。

本文重点介绍 Bitwarden。

运行非官方的 Bitwarden 实现

有一个名为 bitwarden_rs 的服务器及其 API 的社区实现。这个实现是完全开源的,因为它可以使用 SQLite 或 MariaDB/MySQL,而不是官方服务器使用的专有 Microsoft SQL Server。

有一点重要的是要认识到官方和非官方版本之间存在一些差异。例如,官方服务器已经由第三方审核,而非官方服务器还没有。在实现方面,非官方版本缺少电子邮件确认和采用 Duo 或邮件码的双因素身份验证

让我们在 SELinux 中运行服务器。根据 bitwarden_rs 的文档,你可以如下构建一个 Podman 命令:

$ podman run -d \ 

--userns=keep-id \ 

--name bitwarden \ 

-e SIGNUPS_ALLOWED=false \ 

-e ROCKET_PORT=8080 \ 

-v /home/egustavs/Bitwarden/bw-data/:/data/:Z \ 

-p 8080:8080 \ 

bitwardenrs/server:latest

这将下载 bitwarden_rs 镜像并在用户命名空间下的用户容器中运行它。它使用 1024 以上的端口,以便非 root 用户可以绑定它。它还使用 :Z 更改卷的 SELinux 上下文,以防止在 /data 中的读写权限问题。

如果你在某个域下托管它,建议将此服务器放在 Apache 或 Nginx 的反向代理下。这样,你可以使用 80 和 443 端口指向容器的 8080 端口,而无需以 root 身份运行容器。

在 systemd 下运行

Bitwarden 现在运行了,你可能希望保持这种状态。接下来,创建一个使容器保持运行的单元文件,如果它没有响应则自动重新启动,并在系统重启后开始运行。创建文件 /etc/systemd/system/bitwarden.service:

[Unit] 

Description=Bitwarden Podman container 

Wants=syslog.service 

[Service] 

User=egustavs 

Group=egustavs 

TimeoutStartSec=0 

ExecStart=/usr/bin/podman run 'bitwarden' 

ExecStop=-/usr/bin/podman stop -t 10 'bitwarden' 

Restart=always 

RestartSec=30s 

KillMode=none 

[Install] 

WantedBy=multi-user.target

现在使用 sudo 启用并启动该服务:

$ sudo systemctl enable bitwarden.service && sudo systemctl start bitwarden.service 

$ systemctl status bitwarden.service 

bitwarden.service - Bitwarden Podman container 

Loaded: loaded (/etc/systemd/system/bitwarden.service; enabled; vendor preset: disabled)

Active: active (running) since Tue 2019-07-09 20:23:16 UTC; 1 day 14h ago 

Main PID: 14861 (podman) 

Tasks: 44 (limit: 4696) 

Memory: 463.4M

成功了!Bitwarden 现在运行了并将继续运行。

添加 LetsEncrypt

如果你有域名,强烈建议你使用类似 LetsEncrypt 的加密证书运行你的 Bitwarden 实例。Certbot 是一个为我们创建 LetsEncrypt 证书的机器人,这里有个在 Fedora 中操作的指南

生成证书后,你可以按照 bitwarden_rs 指南中关于 HTTPS 的部分来。只要记得将 :Z 附加到 LetsEncrypt 来处理权限,而不用更改端口。

照片由 CMDR Shane 拍摄,发表在 Unsplash 上。

via: https://fedoramagazine.org/manage-your-passwords-with-bitwarden-and-podman/

作者:Eric Gustavsson 选题:lujun9972 译者:geekpi 校对:wxy

本文由 LCTT 原创编译,Linux中国 荣誉推出

相关文章

  • 使用 Bitwarden 和 Podman 管理你的密码

    在过去的一年中,你可能会遇到一些试图向你推销密码管理器的广告。比如LastPass、1Password或Dashl...

  • CentOS8的podman容器

    笔者在使用CentOS8时安装docker失败,于是发现CentOS8自带容器podman,podman的使用...

  • CentOS 8上装Docker

    假设你不想使用podman,而是希望使用docker社区版,下面是步骤: 1 卸载podman 2 设置repo ...

  • podman

    podman简介 Podman是一个开源项目,可在大多数Linux平台上使用并开源在GitHub上。Podman...

  • podman的安装和使用

    1.podman简介 Podman 原来是 CRI-O 项目的一部分,后来被分离成一个单独的项目叫 libpod。...

  • 在Ubuntu18.04 上采用Docker 安装bitward

    文章使用环境为ubuntu,使用docker运行bitwarden_rs服务。 一、安装docker 简单安装法:...

  • Podman 和用户名字空间:天作之合

    了解如何使用 Podman 在单独的用户空间运行容器。 Podman是libpod库的一部分,使用户能够管理 po...

  • podman-pod-command

    podman-pod-create podman-pod-inspect podman-pod-ps podman...

  • podman service in inactive state

    Red Hat系(包括fedora)上开始使用了podman来替代docker,在默认配置下启动podman se...

  • 如何在CLI上管理密码

    基于密码的认证在网络盛行的今天,你可能需要或者已经使用了某种密码管理工具来跟踪管理你正在使用的所有密码。有各种各样...

网友评论

    本文标题:使用 Bitwarden 和 Podman 管理你的密码

    本文链接:https://www.haomeiwen.com/subject/qakydctx.html