Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

can not change MEDIA_ROOT to an USB drive #1091

Open
SDFTDusername opened this issue Oct 23, 2024 · 9 comments
Open

can not change MEDIA_ROOT to an USB drive #1091

SDFTDusername opened this issue Oct 23, 2024 · 9 comments
Assignees

Comments

@SDFTDusername
Copy link

Describe the issue
I want to store all media and their encoded files on my USB drive, but when I try to do that I can't upload videos anymore.

I tried setting MEDIA_ROOT in /home/mediacms.io/mediacms/cms/settings.py to /mnt/f/media_files/
and tried mounting the usb to /home/mediacms.io/mediacms/media_files

but neither worked. when I try to upload something, it retries twice and then fails. it only works if MEDIA_ROOT points at /home/mediacms.io/mediacms/media_files (default) without the usb mounted to that path.

I tried this with the USB formatted to exFAT and NTFS

Expected behavior
it should work like normal.

Environment

  • OS: WSL 2 with Ubuntu 22
  • Installation method: single server install
  • Browser: Microsoft Edge
@yatesdr
Copy link
Contributor

yatesdr commented Oct 23, 2024

Did you check the permissions on the mount location? The docker install needs write access to whatever you're trying to write.

cd /mnt/f
ls -lah
check the permissions assigned, if they're 755 for your user / your group, mediaCMS won't be able to write there as it runs under some other user typically.
chmod 777 media_files

If that fixes it, you know it's a permissions issue with your mount. It's not really a great idea to just leave it as 777, so you'll have to figure out what user and group mediacms is running as and change to 775 and chgrp to the appropriate permissions.

@SDFTDusername
Copy link
Author

when i run ls -lah, it says that the media_files directory is drwxrwxrwx, which means full permission, and running chmod 777 media_files doesn't change anything.
also it writes just fine. i tried uploading an image and even though the website says it fails, i can see the image at /mnt/f/media_files/uploads/{random-uuid}
but i don't see the videos of failed uploads at /mnt/f/media_files/original/user/{username} and /mnt/f/media_files/encoded/{num}/{username}

@yatesdr
Copy link
Contributor

yatesdr commented Oct 23, 2024

That almost sounds like it's writing with permissions it can't read. Did you check the permissions that got set on the "failed" image upload that appeared? If those are okay, then you may need to also check your postgres_data directory and make sure the database writes aren't failing for some reason.

I have had a bunch of trouble with permissions trying to run it for development with docker on MacOS that I was unable to solve, but it ran properly on ubuntu server in docker as a generic user.

@SDFTDusername
Copy link
Author

where's the postgres_data directory? the files also have full permissions.
also i checked and i'm able to see the failed video uploads, i just didn't check the right directory

@yatesdr
Copy link
Contributor

yatesdr commented Oct 23, 2024

On my system, it created it in the root folder, but I'm running a docker instance. It should be set in your config somewhere, check there. Aside from that, I'm out of ideas, will have to wait for someone more knowledgeable to come along if you can't get it sorted.

@SDFTDusername
Copy link
Author

there is no postgres_data directory. i ran find / -type d -name 'postgres_data' but nothing was found, maybe that directory is only for docker instances?

@gimail
Copy link

gimail commented Oct 29, 2024

Installing Docker on WSL (Windows Subsystem for Linux) and deploying MediaCMS can be done using the following steps. Here we will assume that you are using WSL 2 and the Ubuntu distribution. If WSL 2 is not configured yet, make sure that you have done so before you start installing Docker.

   Step 1: Make sure that WSL 2 is installed and configured
  1. Open PowerShell as an administrator and run:
    bash
    wsl --set-default-version 2

  2. Make sure that you have the Ubuntu distribution installed. If not, install it through the Microsoft Store.
    Step 2: Install Docker on Ubuntu in WSL

  3. Open your Ubuntu session in WSL.

  4. Update the package list and install the necessary dependencies:
    bash
    sudo apt update
    sudo apt install apt-transport-https ca-certificates curl software-properties-common

  5. Install the Docker GPG key:
    bash
    curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -

  6. Add the Docker repository to the list of package sources:
    bash
    echo "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list

  7. Update the package list again:
    bash
    sudo apt update

  8. Install Docker:
    bash
    sudo apt install docker-ce

  9. After installing Docker, run the Docker daemon:
    bash
    sudo service docker start

    Step 3: Configure Docker to work without sudo (optional)
    

If you want to run Docker without using sudo, add your user to the Docker group.
bash
sudo usermod -aG docker $USER

After executing this command, you will need to log out and log in again for the changes to take effect.
Step 4: Install Docker Compose (optional)
If MediaCMS requires Docker Compose, install it:

  1. Install Docker Compose:
    bash
    sudo apt install docker-compose

  2. Check the installation:
    bash
    docker-compose --version

    Step 5: Install MediaCMS
    

Now you are ready to install MediaCMS. Create a directory in Windows in another drive for your project and navigate to it and copy mediacms there:
in WSL Ubuntu, go to the directory in Windows
cd /mnt/d/mediacms

Edit the 'docker-compose' file.yml` with settings for MediaCMS. Sample content:
version: "3"
services:
migrations:
image: mediacms/mediacms:latest
volumes:
- ./:/home/mediacms.io/mediacms/
environment:
ENABLE_UWSGI: 'no'
ENABLE_NGINX: 'no'
ENABLE_CELERY_SHORT: 'no'
ENABLE_CELERY_LONG: 'no'
ENABLE_CELERY_BEAT: 'no'
ADMIN_USER: 'admin'
ADMIN_EMAIL: 'admin@localhost'
ADMIN_PASSWORD: 'admin'
command: "./deploy/docker/prestart.sh"
restart: on-failure
depends_on:
redis:
condition: service_healthy
db:
condition: service_healthy
web:
image: mediacms/mediacms:latest
deploy:
replicas: 1
ports:
- "80:80"
volumes:
- /mnt/d/mediacms:/home/mediacms.io/mediacms/
environment:
ENABLE_CELERY_BEAT: 'no'
ENABLE_CELERY_SHORT: 'no'
ENABLE_CELERY_LONG: 'no'
ENABLE_MIGRATIONS: 'no'
depends_on:
- migrations
celery_beat:
image: mediacms/mediacms:latest
volumes:
- /mnt/d/mediacms:/home/mediacms.io/mediacms/
environment:
ENABLE_UWSGI: 'no'
ENABLE_NGINX: 'no'
ENABLE_CELERY_SHORT: 'no'
ENABLE_CELERY_LONG: 'no'
ENABLE_MIGRATIONS: 'no'
depends_on:
- redis
celery_worker:
image: mediacms/mediacms:latest
deploy:
replicas: 1
volumes:
- /mnt/d/mediacms:/home/mediacms.io/mediacms/
environment:
ENABLE_UWSGI: 'no'
ENABLE_NGINX: 'no'
ENABLE_CELERY_BEAT: 'no'
ENABLE_MIGRATIONS: 'no'
depends_on:
- migrations
db:
image: postgres:15.2-alpine
volumes:
- ../postgres_data:/var/lib/postgresql/data/
restart: always
environment:
POSTGRES_USER: mediacms
POSTGRES_PASSWORD: mediacms
POSTGRES_DB: mediacms
PGUSER: mediacms
TZ: Europe/London
healthcheck:
test: ["CMD-SHELL", "pg_isready -d $${POSTGRES_DB} -U $${POSTGRES_USER}", "--host=db", "--dbname=$POSTGRES_DB", "--username=$POSTGRES_USER"]
interval: 10s
timeout: 5s
retries: 5
redis:
image: "redis:alpine"
restart: always
healthcheck:
test: ["CMD", "redis-cli","ping"]
interval: 30s
timeout: 10s
retries: 3

  • ../postgres_data:/var/lib/postgresql/data/ - to your preference
    If the command sudo chown -R 999:999 ../postgres_data does not change the owner and the group remains root:root, this may happen for one of the following reasons:
  1. The system does not allow you to change the owner: Some file systems, in particular, states such as NTFS or FAT, may not support UNIX-like permissions and owners. If you are running on Windows and using WSL (Windows Subsystem for Linux), this may be a problem.
  2. Docker Desktop and WSL: If you use Docker on Windows via WSL, rights errors may occur due to the peculiarities of the WSL file system.
    Possible solutions
    Open the etc/wsl.conf file, if it is missing, create it. Add the configuration:
    [autumount]
    enabled = true
    options="metadata,umask=22,fmask=11"
    sudo chmod -R 777 /mnt/d/mediacms
    wsl --shutdown
  3. Try to change the access rights:
    You can change the access rights so that all users can write to the directory, although this is not the best way from a security point of view:
    bash
    sudo chmod -R 777 ../postgres_data

After that, check the operation of the container.
docker start $(docker ps -aq) starting all containers after installing MediaCMS

@mgogoulos
Copy link
Contributor

That almost sounds like it's writing with permissions it can't read. Did you check the permissions that got set on the "failed" image upload that appeared? If those are okay, then you may need to also check your postgres_data directory and make sure the database writes aren't failing for some reason.

I have had a bunch of trouble with permissions trying to run it for development with docker on MacOS that I was unable to solve, but it ran properly on ubuntu server in docker as a generic user.

i don't have much experience with MacOS but if there are specific suggestions to improve things it would be great! I'm mainly using/developing in Linux where things run smoothly, however I see there are many people in MacOS and Windows too

@yatesdr
Copy link
Contributor

yatesdr commented Oct 30, 2024

That almost sounds like it's writing with permissions it can't read. Did you check the permissions that got set on the "failed" image upload that appeared? If those are okay, then you may need to also check your postgres_data directory and make sure the database writes aren't failing for some reason.
I have had a bunch of trouble with permissions trying to run it for development with docker on MacOS that I was unable to solve, but it ran properly on ubuntu server in docker as a generic user.

i don't have much experience with MacOS but if there are specific suggestions to improve things it would be great! I'm mainly using/developing in Linux where things run smoothly, however I see there are many people in MacOS and Windows too

I wasn't able to get it to run in Docker on MacOS, and wound up spinning up a new VM on Ubuntu 22 to test on instead. I think it has to do with the way bind mounts are set up for Colima vs dockerd / containerd, in that the permissions for some files can't be directly set by Colima as you would with a rootful normal docker compose. The failure is when it gets into chown the files that are passed into the container - and It's not clear why exactly this is the case but I wouldn't worry about it too much, it works great with the regular docker compose client everywhere else I've tried it!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants