Backing up media cache
-
@nichu42 the updates will be tried again later, so this shouldn't be a problem. Just move the update schedule maybe to a later time maybe.
As for moving the media cache to S3, I will put note in our docs on how to do this and link it here. But you don't really need to change nginx proxies and stuff.
-
@nichu42 said in Backing up media cache:
The instructions posted above do not really help as I have no idea for nginx proxies and stuff, as mentioned before. I wouldn't even know where to do the changes. This is pretty frustrating.
To just start using S3 for your media storage for your Mastodon app doesn't require doing anything with nginx proxies.
Literally all you need to do is use the File Manger to edit your
/app/data/env.production
and add something like this:# Store data using S3 object S3_ENABLED=true S3_BUCKET=bucket-name AWS_ACCESS_KEY_ID=<key_id> AWS_SECRET_ACCESS_KEY=<secret_key> S3_REGION=fr-par S3_PROTOCOL=https S3_HOSTNAME=s3.fr-par.scw.cloud
The problem in your case is, I think, you'd also like to move your existing data over to the S3 storage too. I've not personally done that and so can't help other than pointing to the guide linked to in the guide I pointed to previously which explains how to do it, i.e. read this:
https://github.com/cybrespace/cybrespace-meta/blob/master/s3.md
Good luck!
-
-
Thank you all for coming to my rescue! I really appreciate it.
I think I'll just start with making the settings in the env.production file and take it from there. I plan to use IDrive e2 where I got a 30 days free trial.A last question for now: Once I do this, visitor's browsers will load media directly from S3 and no longer from my server, is that right? (At least I think what that nginx proxy thing is all about).
If I want to avoid this, I'll have to make the vhost settings as in https://stanislas.blog/2018/05/moving-mastodon-media-files-to-wasabi-object-storage/#setting-up-a-nginx-reverse-proxy-with-cache-for-the-bucket, correct?
@doodlemania2: Can you give me a hint how to do this in Cloudron? -
@nichu42 said in Backing up media cache:
Can you give me a hint how to do this in Cloudron?
I like an idiots guide to doing this too
-
@nichu42 I didn't do the cache bit which can't easily be done in cloudron, media loads directly from "s3" (mine is also in idrive). It's definitely slower and you SHOULD use a cache (in or very near to your cloudron server) if you have more than a few dozen users.
I was thinking about packaging up a VERY simple custom cloudron app that did exactly that but figured my scenario was too esoteric.
When you put the details into your .env file, then restart and all new media will go to "s3" but you have to repopulate your media for historical stuff in your bucket with tootctl - but you'll be able to rm -rf the cache folder on your vps!
-
@jdaviescoates indeed, and idiot guide for an already running cloudron/mastodon app would be nice.
Got deepl running with simpel guide, so hope that for adding s3 bucket this can be the same
-
-
Hi, I don't want to start a new thread. I need to connect an S3 bucket to the IDrive storage. I am trying to add the configuration from the bucket in the repository to the /app/data/env.production file. I have tried just about everything. Bucket private, public, set Cname record with subdomain pointing to the repository, but after restarting the app, uploading images ends with a 500 error, or the image uploads but can't be opened, it's like hidden. Has anyone solved a similar problem please. I must have tried everything and I don't know how to set the configuration file anymore. Thank you all very much for any advice.
-
@archos it could be a CORS issue?
Have you already done what is described here: https://www.idrive.com/object-storage-e2/faq-dashboard#cross_origin ?
-
Thank you for your reply. I tried it now, but the result is the same.
According to me, I think I'm making a mistake in the hostname. Please Bucket should be public or private? I've been playing with this all day, I really don't know anymore.
Do I need a Cname DNS record? -
@archos said in Backing up media cache:
Please Bucket should be public or private?
From my limited experience I think either should work but you probably want it to be private (I think public means the bucket itself can be publicly browsed)
@archos said in Backing up media cache:
Do I need a Cname DNS record?
I don't think so, unless you're trying to set-up an S3 hostname using one of your domains, but I've no idea if that's actually possible if you're not self-hosting the S3 buckets yourself. I tried a while ago but then gave up (although seems this might be possible with iDrive https://www.idrive.com/object-storage-e2/faq-dashboard#use-domain but that's just adding additional complexity, so I'd focus on just getting it working for now!)
@archos said in Backing up media cache:
According to me, I think I'm making a mistake in the hostname.
Quite possible.
The annoying thing is there doesn't seem to be any standard agreed upon way it all works and it seems different providers want different things.
On Scaleway S3 this is what my working settings looks like for Mastodon:
# Store media on Scaleway S3 object S3_ENABLED=true S3_BUCKET=example_bucknet_name AWS_ACCESS_KEY_ID=example_key_id AWS_SECRET_ACCESS_KEY=example_secret_access_key S3_REGION=fr-par S3_PROTOCOL=https S3_HOSTNAME=s3.fr-par.scw.cloud S3_ENDPOINT=https://s3.fr-par.scw.cloud
-
@jdaviescoates Thank you very much, I will try to create a bucket in Scaleway, the price is almost the same, so hopefully it will work.
-
@archos Note, you also have to do the CORS stuff on Scaleway too, so it won't work without doing that as well,
see:
https://www.scaleway.com/en/docs/storage/object/api-cli/setting-cors-rules/
But before you can do that you need to set-up the AWS CLI stuff, see:
https://www.scaleway.com/en/docs/storage/object/api-cli/object-storage-aws-cli/
And before you can do that you need API Keys:
https://www.scaleway.com/en/docs/identity-and-access-management/iam/how-to/create-api-keys/
Good luck!
-
@jdaviescoates I didn't really understand the instructions, so I tried Wasabi and Idrive again. The logs show this error.
Aws::S3::Errors::InvalidAccessKeyId (The AWS Access Key Id you provided does not exist in our records.):
I tried to re-create the keys, but to no avail.
-
@archos said in Backing up media cache:
@jdaviescoates I didn't really understand the instructions, so I tried Wasabi and Idrive again. The logs show this error.
Aws::S3::Errors::InvalidAccessKeyId (The AWS Access Key Id you provided does not exist in our records.):
I tried to re-create the keys, but to no avail.
The logs where? Which provider?
-
@jdaviescoates This is the log from Mastodon when I try to post a photo. It's on every provider I've tried. Yesterday I tried following this exact procedure and created a bucket on AWS and the result was the same.
-
I followed the joinmastodon instructions, on the Scaleway repository. Now I'm getting this error in the logs in the application.
Aws::S3::Errors::AuthorizationHeaderMalformed (The authorization header is malformed; the region 'us-east-1' is wrong; expecting 'fr-par'):
I chose Paris as the region for the bucket and in env.production. So I really don't know what I'm doing wrong :-(.
# Store data using S3 object S3_ENABLED=true S3_BUCKET=mastcz AWS_ACCESS_KEY_ID=ACCESS_KEY_ID AWS_SECRET_ACCESS_KEY=SECRET_ACCESS_KEY #S3_REGION=fr-par S3_PROTOCOL=https S3_HOSTNAME=s3.fr-par.scw.cloud S3_ENDPOINT=https://mastcz.s3.fr-par.scw.cloud