问题描述
[emerg] 在 /etc/Nginx/conf.d/default.conf:53 的上游“varnish”中找不到主机
清漆日志中的错误
无法将后端主机“web”解析为 IP 地址: 名称解析暂时失败 (对不起,如果该错误消息是胡言乱语。) ('/etc/varnish/default.vcl'第 9 行 Pos 13) .host = "web";
好像有依赖循环,使得docker无法同时启动varnish和Nginx。
有人对此有任何想法吗?
文件 docker-compose.yml
web:
image: magento/magento-cloud-docker-Nginx:latest
ports:
- 80:80
- 443:443
- 8080:8080
links:
- fpm
- fpm_xdebug
- db
volumes_from:
- appdata
volumes:
- ./Nginx/default.conf:/etc/Nginx/conf.d/default.conf
- ./Nginx/ssl:/etc/Nginx/ssl
env_file:
- ./global.env
varnish:
build: ./varnish
depends_on:
- web
links:
- web
ports:
- 6082:6082
- 6081:6081
volumes:
- ./varnish/etc/varnish/default.vcl:/etc/varnish/default.vcl
- ./varnish/etc/default/varnish:/etc/default/varnish
我的配置 default.conf
upstream fastcgi_backend {
# use tcp connection
server fpm:9000;
}
server {
listen 80;
server_name local.defaultsite.com;
return 301 https://$server_name$request_uri;
}
server {
listen 8080;
server_name local.defaultsite.com;
# set $MAGE_ROOT /app;
set $MAGE_ROOT /home/webapps/public_html;
# include /app/Nginx.conf.sample;
include /home/webapps/public_html/Nginx.conf.sample;
}
server {
listen 443 ssl http2 default_server;
listen [::]:443 ssl http2 default_server;
ssl_certificate /etc/Nginx/ssl/cert.pem;
ssl_certificate_key /etc/Nginx/ssl/key.pem;
set $MAGE_ROOT /home/webapps/public_html;
set $MAGE_DEBUG_SHOW_ARGS 0;
set $my_fastcgi_pass "fastcgi_backend";
if ($cookie_XDEBUG_SESSION) {
set $my_fastcgi_pass "fastcgi_backend_xdebug";
}
server_name local.defaultsite.com;
location / {
proxy_pass http://varnish:6081;
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For
$proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto https;
proxy_set_header X-Forwarded-Port 443;
proxy_buffer_size 128k;
proxy_buffers 4 256k;
proxy_busy_buffers_size 256k;
fastcgi_buffer_size 32k;
fastcgi_buffers 4 32k;
}
}
在清漆 default.vcl 中
backend default {
.host = "web";
.port = "8080";
.first_byte_timeout = 600s;
}
解决方法
问题始于您的 Nginx 配置使用以下 FastCGI 上游配置:
upstream fastcgi_backend {
# use tcp connection
server fpm:9000;
}
主机名是 fpm
,它可能指的是 PHP-FPM Docker 容器。此容器似乎不是您的 docker-compose.yml
设置的一部分。
您的 web
容器可能无法从中恢复并出现故障(请参阅 docker-compose
输出日志)。
Varnish 依赖于 web
主机名来代理其数据,但由于它不再解析,Varnish 也会引发错误。
看看 https://hub.docker.com/_/php?tab=tags&page=1&name=fpm:它列出了官方 PHP 映像的所有可用的基于 FPM 的映像。你可以选择php:7.4-fpm
。