I have got the same problem described in this post, but inside a docker container.
I don’t really know where my pgadmin file reside to edit it’s default path.How do I go about fixing this issue? Please be as detailed as possible because I don’t know how to docker.
Here is an abstract of the verbatim of docker-compose up
command:
php-worker_1 | 2020-11-11 05:50:13,700 INFO spawned: 'laravel-worker_03' with pid 67
pgadmin_1 | [2020-11-11 05:50:13 +0000] [223] [INFO] Worker exiting (pid: 223)
pgadmin_1 | WARNING: Failed to set ACL on the directory containing the configuration database:
pgadmin_1 | [Errno 1] Operation not permitted: '/var/lib/pgadmin'
pgadmin_1 | HINT : You may need to manually set the permissions on
pgadmin_1 | /var/lib/pgadmin to allow pgadmin to write to it.
pgadmin_1 | ERROR : Failed to create the directory /var/lib/pgadmin/sessions:
pgadmin_1 | [Errno 13] Permission denied: '/var/lib/pgadmin/sessions'
pgadmin_1 | HINT : Create the directory /var/lib/pgadmin/sessions, ensure it is writeable by
pgadmin_1 | 'pgadmin', and try again, or, create a config_local.py file
pgadmin_1 | and override the SESSION_DB_PATH setting per
pgadmin_1 | https://www.pgadmin.org/docs/pgadmin4/4.27/config_py.html
pgadmin_1 | /usr/local/lib/python3.8/os.py:1023: RuntimeWarning: line buffering (buffering=1) isn't supported in binary mode, the default buffer size will be used
pgadmin_1 | return io.open(fd, *args, **kwargs)
pgadmin_1 | [2020-11-11 05:50:13 +0000] [224] [INFO] Booting worker with pid: 224
my docker-compose.yml:
### pgAdmin ##############################################
pgadmin:
image: dpage/pgadmin4:latest
environment:
- "PGADMIN_DEFAULT_EMAIL=${PGADMIN_DEFAULT_EMAIL}"
- "PGADMIN_DEFAULT_PASSWORD=${PGADMIN_DEFAULT_PASSWORD}"
ports:
- "${PGADMIN_PORT}:80"
volumes:
- ${DATA_PATH_HOST}/pgadmin:/var/lib/pgadmin
depends_on:
- postgres
networks:
- frontend
- backend
3
Answers
Okay. looks like problem appears when you try to run
pgadmin
service.This part
As you can see you trying to mount local directory
${DATA_PATH_HOST}/pgadmin
into container’s/var/lib/pgadmin
As you can read in this article your local
${DATA_PATH_HOST}/pgadmin
directory’s UID and GID must be5050
. Is this5050
?You can check it by running
Output will be like
or
if
SOME_USER
‘s andSOME_GROUP
‘s IDs are5050
, it is okay.5050
as is also okay. If not, try to do as described in article above.Also you need to check is environment variable exists:
If output will be empty you need to set
${DATA_PATH_HOST}
or allow docker to read variables from file. There are many ways to do it.If you’re on Windows, add this line to your
docker-compose.yml
. It gives container an access to your local folderWhen running in kubernetes environment, I had to add these values.