182 lines
4.9 KiB
Plaintext
182 lines
4.9 KiB
Plaintext
---
|
|
title: Nextcloud Backup, Restore and Migration Guide
|
|
---
|
|
|
|
This guide can will walk through the process of backing up and existing Nextcloud installation and how to restore or migrate that installation. This guide utilize HostPath or NFS for UserData.
|
|
|
|
## Backup
|
|
|
|
:::danger[SMB EXTERNAL STORAGE]
|
|
|
|
If you are using SMB authenticated external storage on your Nextcloud remove it before starting this guide. The migration process will fail if it is not removed.
|
|
|
|
:::
|
|
|
|
:::danger[TWO FACTOR AUTHENTICATION]
|
|
|
|
If you are using two factor authentication on your Nextcloud accounts disable it before starting this guide. While it can be done via the CLI later it is much easier to disable it before hand.
|
|
|
|
:::
|
|
|
|
### Backup Database
|
|
|
|
If you have not already done so install PGAdmin and the [tcdbinfo.sh script](/development/scale/sql-export/#how-to-list-database-login-info-for-truecharts-apps)
|
|
|
|
import { Steps } from '@astrojs/starlight/components';
|
|
|
|
<Steps>
|
|
|
|
1. Run the tcdbinfo.sh script and take note of the connection info
|
|
|
|
```bash title="List Database Info"
|
|
bash tcdbinfo.sh
|
|
```
|
|
|
|
![tcdbinfo-output](./img/tcdbinfo-output.png)
|
|
|
|
2. Add Nextcloud to PGAdmin using the connection info from previous step.
|
|
![pgadmin-connection1](./img/pgadmin-connection1.png)
|
|
![pgadmin-connection2](./img/pgadmin-connection2.png)
|
|
3. Backup Nextcloud database.
|
|
![pgadmin-backup](./img/pgadmin-backup.png)
|
|
|
|
</Steps>
|
|
|
|
### Backup User Data
|
|
|
|
If you are using HostPath of NFS for UserData then no further action is required. If you are using PVC for UserData then you will first need to mount your Nextcloud PVC and copy your UserData to a new dataset.
|
|
|
|
## Restore
|
|
|
|
### Remove Old AppData
|
|
|
|
This step is not required but to have a clean installation remove all UserData folder and files that are not user folders.
|
|
|
|
```bash title="List Files"
|
|
ls -la
|
|
```
|
|
|
|
![userdata-old](./img/userdata-old.png)
|
|
|
|
:::caution
|
|
|
|
Next steps are destructive without a way to undo. Make sure you have proper backups to avoid data loss.
|
|
|
|
You have been **warned**
|
|
|
|
```bash title="Remmove Old Nextcloud Users/Folders"
|
|
rm -rf <folder>
|
|
```
|
|
|
|
```bash title="Remove Old Nextcloud Files"
|
|
rm .ocdata .htaccess index.html nextcloud.log
|
|
```
|
|
|
|
![userdata-clean](./img/userdata-clean.png)
|
|
|
|
:::
|
|
|
|
### Verify User Data Permissions
|
|
|
|
Nextcloud uses apps for file ownership. Apply permissions as shown below to your User Data dataset.
|
|
|
|
![userdata-perms](./img/userdata-perms.png)
|
|
|
|
### Install Nextcloud
|
|
|
|
Install with a temporary admin user that you do not currently use for Nextcloud (ie. temp)
|
|
|
|
:::caution[UNIQUE USER]
|
|
|
|
If you do not install with a unique user the install will fail because Nexctloud will be unable to create the user folder when one already exists
|
|
|
|
:::
|
|
|
|
Setup Nextcloud User Data storage with your previous User Data dataset or the dataset you copied your User Data to.
|
|
|
|
![userdata-setting](./img/userdata-setting.png)
|
|
|
|
### Restore Database
|
|
|
|
:::caution[Nextcloud Installation]
|
|
|
|
Wait for Nextcloud to fully deploy before proceeding.
|
|
|
|
:::
|
|
|
|
<Steps>
|
|
|
|
1. Stop the main pod of Nextcloud.
|
|
|
|
```bash title="Stop Main Pod of Nextcloud"
|
|
k3s kubectl scale deploy nextcloud -n ix-nextcloud --replicas=0
|
|
```
|
|
|
|
2. Add Nextcloud to PGAdmin as guided in [steps 1 and 2 here](#backup-database).
|
|
3. In PGAdmin right click on the database and select restore as shown below.
|
|
![pgadmin-restore1](./img/pgadmin-restore1.png)
|
|
4. Select the database backup you created previously.
|
|
![pgadmin-restore2](./img/pgadmin-restore2.png)
|
|
5. Configure Data/Objects as shown below.
|
|
![pgadmin-restore3](./img/pgadmin-restore3.png)
|
|
6. Configure Options as shown below and click restore.
|
|
![pgadmin-restore4](./img/pgadmin-restore4.png)
|
|
|
|
:::caution[PGAdmin Error]
|
|
|
|
PGAdmin may display an error during the restore process. This is known to occur and may be ignored.
|
|
|
|
:::
|
|
|
|
7. Start the main pod of Nextcloud.
|
|
|
|
```bash title="Start Main Pod of Nextcloud"
|
|
k3s kubectl scale deploy nextcloud -n ix-nextcloud --replicas=1
|
|
```
|
|
|
|
</Steps>
|
|
|
|
### OCC Commands
|
|
|
|
:::caution[Nextcloud Deploy]
|
|
|
|
Wait for Nextcloud to fully deploy before proceeding.
|
|
|
|
:::
|
|
|
|
<Steps>
|
|
|
|
1. Open a shell for the Nextcloud main pod as shown below. Ensure your are selecting the correct pod it should just say nextcloud for both Pods (followed by random characters only) and Containers as shown below.
|
|
![nextcloud-cli](./img/nextcloud-cli.png)
|
|
2. Run the following commands in the Nextcloud shell.
|
|
|
|
```bash title="Run Upgrade"
|
|
occ upgrade
|
|
```
|
|
|
|
```bash title="Turn On Maintenance Mode"
|
|
occ maintenance:mode --on
|
|
```
|
|
|
|
```bash title="Run Repair"
|
|
occ maintenance:repair
|
|
```
|
|
|
|
```bash title="Turn Off Maintenance Mode"
|
|
occ maintenance:mode --off
|
|
```
|
|
|
|
```bash title="title="Add Missing Database Indices"
|
|
occ db:add-missing-indices
|
|
```
|
|
|
|
```bash title="Scan All User Files"
|
|
occ files:scan --all
|
|
```
|
|
|
|
</Steps>
|
|
|
|
### Delete Temporary User Data Folder
|
|
|
|
You may now remove the folder created during install for the temporary user that was configured.
|