Hallo
Ich möchte eine Anwendung mit Docker realisieren. Dazu habe ich folgende Container:
Grundsätzlich funktioniert alles bis auf den Zugriff vom Webserver auf Postgresql. Es kommt immer die Meldung, dass der Postgresqlserver nicht gefunden wird. Per DBeaver, wlcher lokal läuft, kann ich aber auf Postgresql zugreifen. Meine Recherchen im Internet haben ergeben, dass der containerübergreifende Zugriff auf Postgres etwas schwierig ist. Ich habe aber bis jetzt keine Lösung dazu gefunden.
Hat jemand Erfahrung mit dieser Konstellation und kann mir sagen wo ich den Hebel ansetzen muss?
docker-compose.yml
nginx default.conf
Ich möchte eine Anwendung mit Docker realisieren. Dazu habe ich folgende Container:
- nginx
- php
- postgresql
- nodejs
Grundsätzlich funktioniert alles bis auf den Zugriff vom Webserver auf Postgresql. Es kommt immer die Meldung, dass der Postgresqlserver nicht gefunden wird. Per DBeaver, wlcher lokal läuft, kann ich aber auf Postgresql zugreifen. Meine Recherchen im Internet haben ergeben, dass der containerübergreifende Zugriff auf Postgres etwas schwierig ist. Ich habe aber bis jetzt keine Lösung dazu gefunden.
Hat jemand Erfahrung mit dieser Konstellation und kann mir sagen wo ich den Hebel ansetzen muss?
docker-compose.yml
Code:
version: "3.9" services:nginx_api-p49153:image: nginx:latestports:- ${PORT_HOST_HTTP}:80volumes:- ${DATADIR_API}:/var/www/html- ./.docker/conf/nginx/default.conf:/etc/nginx/conf.d/default.confrestart: alwaysdepends_on:- postgresql-p49152- phpprofiles:- api- all# networks:# - app-networkphp:build: .docker/build/phprestart: alwaysvolumes:- ./.docker/conf/php/php.ini:/usr/local/etc/php/conf.d/php.ini# - ./.docker/conf/php/xdebug.ini:/usr/local/etc/php/conf.d/xdebug.ini- ${DATADIR_API}:/var/www/htmlprofiles:- api- all# networks:# - app-networkcomposer:image: composervolumes:- ${DATADIR_API}:/appcommand: installprofiles:- api- allpostgresql-p49152:image: postgres:15.2-alpineports:- ${PORT_HOST_DB}:5432environment:- POSTGRES_DB=${DB_NAME}- POSTGRES_USER=${DB_USER}- POSTGRES_PASSWORD=${DB_PASSWORD}volumes:- ${DATADIR_POSTGRES}:/var/lib/postgresql/data- ${DATADIR_POSTGRES_BACKUP}:/mnt# - ./.docker/conf/postgres/:/docker-entrypoint-initdb.d/restart: alwaysprofiles:- db- api- all# networks:# - app-networknodejs_ui-p49154:image: node:18-alpinecommand: sh -c "npm install && npm run dev"# ports:# - ${PORT_HOST_UI}:8080working_dir: /appvolumes:- ./data/ui:/appdepends_on:- nginx_api-p49153profiles:- all- ui# networks:# - app-network#networks:# app-network:
nginx default.conf
Code:
# Nginx configuration server { listen 80 default_server; listen [::]:80 default_server; server_name localhost; root /var/www/html/public; location / { # try to serve file directly, fallback to index.php try_files $uri /index.php$is_args$args; } location ~ ^/index\.php(/|$) { fastcgi_pass php:9000; fastcgi_split_path_info ^(.+\.php)(/.*)$; include fastcgi_params; # optionally set the value of the environment variables used in the application # fastcgi_param APP_ENV prod; # fastcgi_param APP_SECRET <app-secret-id>; # fastcgi_param DATABASE_URL "mysql://db_user:db_pass@host:3306/db_name"; # When you are using symlinks to link the document root to the # current version of your application, you should pass the real # application path instead of the path to the symlink to PHP # FPM. # Otherwise, PHP's OPcache may not properly detect changes to # your PHP files (see https://github.com/zendtech/ZendOptimizerPlus/issues/126 # for more information). fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name; fastcgi_param DOCUMENT_ROOT $realpath_root; # Prevents URIs that include the front controller. This will 404: # http://domain.tld/index.php/some-path # Remove the internal directive to allow URIs like this internal; } # return 404 for all other php files not matching the front controller # this prevents access to other php files you don't want to be accessible. location ~ \.php$ { return 404; } error_log /var/log/nginx/project_error.log; access_log /var/log/nginx/project_access.log; }
Kommentar