ホストされたデータをバックアップしてください
自己ホスト型のBitwardenを使用する場合、データを安全に保つために自分自身でバックアップ手順を実装する責任があります。
BitwardenのDockerコンテナは、ホストマシン上のすべての重要なデータを保持するためにボリュームマッピングを使用します。つまり、コンテナを停止してもデータは削除されません。一方、Dockerコンテナは一時的と考えられ、データや状態は保持しません。
すべてのBitwardenデータはホストマシン上の./bwdataディレクトリに保存されており、それはあなたがBitwardenをインストールした場所に対して相対的な位置にあります。
あなたが./bwdataディレクトリ全体をバックアップし、安全に保管することをお勧めします。データ損失の場合、このディレクトリに含まれるデータの全部または一部がインスタンスを復元するために必要になります。
特に定期的にバックアップする必要がある./bwdataの重要な部分には以下が含まれます:
./bwdata/env- インスタンスの環境変数、データベースと証明書のパスワードを含む。./bwdata/core/attachments- インスタンスのボールト アイテムの添付ファイル。./bwdata/mssql/データ- インスタンスのデータベースデータ。./bwdata/core/aspnet-dataprotection- フレームワークレベルのデータ保護、認証トークンや一部のデータベース列を含む。Bitwardenは、実行中に
mssqlデータベースコンテナの夜間バックアップを自動的に取ります。
Bitwardenは、mssqlコンテナデータベースの夜間バックアップを自動的に取ります。これらのバックアップは./bwdata/mssql/backupsディレクトリに30日間保管されます。
データの損失が発生した場合、./bwdata/mssql/backupsを使用して夜間のバックアップを復元することができます。
データの損失が発生した場合、以下の手順を完了して夜間バックアップを復元してください。
あなたのデータベースのパスワードを
globalSettings__sqlServer__connectionString=...Password=の値から取得してください。それはglobal.override.envで見つけることができます。mssqlコンテナのContainer IDをdocker psコマンドを使用して識別します。次のコマンドを実行して、あなたの
mssqldockerコンテナのためのbashセッションを開きます:Bashdocker exec -it bitwarden-mssql /bin/bashあなたのコマンドプロンプトは、識別されたコンテナIDと
bitwarden-mssqlコンテナが一致するはずです。コンテナ内で、復元したいバックアップファイルを探してください。
note
コンテナ内のバックアップディレクトリは、ホストディレクトリからボリュームマップされています。ホストマシン上の
./bwdata/mssql/backupsは、コンテナ内のetc/bitwarden/mssql/backupsにマップされます。
たとえば、ファイル
/etc/bitwarden/mssql/backups/vault_FULL_20201208_003243.BAKは、2020年12月8日の午前12時32分に取られたバックアップです。次のコマンドで
sqlcmdユーティリティを開始します:Bash/opt/mssql-tools/bin/sqlcmd -S localhost -U <sa> -P <sa-password>ここで、 と は、
global.override.envで見つけたユーザー=とパスワード=の値と一致します。sqlcmdユーティリティに一度入ると、バックアップには2つのオプションがあります:オフライン復元(推奨)
次のSQLコマンドを実行します:
Bash1> use master 2> GO 1> alter database vault set offline with rollback immediate 2> GO 1> restore database vault from disk='/etc/bitwarden/mssql/backups/vault_FULL_{Backup File Name}.BAK' with replace 2> GO 1> alter database vault set online 2> GO 1> exit復元を完了するために、Bitwardenインスタンスを再起動してください。
オンライン復元
次のSQLコマンドを実行します:
Bash1> RESTORE DATABASE vault FROM DISK = '/etc/bitwarden/mssql/backups/vault_FULL_20200302_235901.BAK' WITH REPLACE 2> GO復元を完了するために、Bitwardenインスタンスを再起動してください。