gpt4 book ai didi

ruby-on-rails - Dockernized Nginx +(Rails + Unicorn)+ Redis + PostgreSQL:connect()失败(111:连接被拒绝)

转载 作者:行者123 更新时间:2023-12-02 19:42:08 25 4
gpt4 key购买 nike

我正在尝试使用docker-compose运行4个容器(Nginx +(Rails + Unicorn)+ Redis + PostgreSQL),但是它不起作用。我检查了Dockerfile和nginx.conf无法解决Nginx连接拒绝问题(找不到404)浏览器)。

[error] 8#8: *1 connect() failed (111: Connection refused) while connecting to upstream, client: 192.168.99.1, server: localhost, request: "GET / HTTP/1.1", upstream: "http://172.17.0.95:3000/", host: "192.168.99.100:8080"

我的 Dockerfile
FROM ruby:2.1.5

RUN apt-get update && apt-get install -y nodejs mysql-client --no-install-recommends && rm -rf /var/lib/apt/lists/*

RUN mkdir -p /usr/src/app
WORKDIR /usr/src/app

COPY Gemfile /usr/src/app/
COPY Gemfile.lock /usr/src/app/
COPY config/environments/development.rb /usr/src/app/
COPY config/environments/production.rb /usr/src/app/
COPY config/environments/test.rb /usr/src/app/

RUN bundle install

ADD . /usr/src/app

EXPOSE 3000
CMD ["bundle", "exec", "unicorn", "-c", "config/unicorn.rb"]

我的 docker-compose.yml
db:
image: postgres
ports:
- '5432:5432'
volumes_from:
- datastore

redis:
image: redis:2.8.19
ports:
- '6379:6379'
volumes_from:
- datastore

nginx:
build: containers/nginx
ports:
- '8080:80'
volumes_from:
- datastore
links:
- rails

datastore:
build: containers/datastore

rails:
build: .
ports:
- '3000:3000'
environment:
DATABASE_URL: postgres://postgres@db:5432
REDIS_URL: redis://redis:6379
#SECRET_KEY_BASE: hogehoge
volumes_from:
- datastore
links:
- db
- redis
containers/nginx/nginx.conf
user  nginx;
worker_processes 1;

error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;

events {
worker_connections 1024; # increase if you have lots of clients
accept_mutex off; # "on" if nginx worker_processes > 1
}

http {
include mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';

access_log /var/log/nginx/access.log main;

sendfile on;

tcp_nopush on; # off may be better for *some* Comet/long-poll stuff
tcp_nodelay off; # on may be better for some Comet/long-poll stuff

gzip on;
gzip_http_version 1.0;
gzip_proxied any;
gzip_min_length 500;
gzip_disable "MSIE [1-6]\.";
gzip_types text/plain text/html text/xml text/css
text/comma-separated-values
text/javascript application/x-javascript
application/atom+xml;

upstream app_server {
# for UNIX domain socket setups:
# server unix:/path/to/.unicorn.sock fail_timeout=0;

# for TCP setups, point these to your backend servers
# server 192.168.0.7:8080 fail_timeout=0;
server rails:3000 fail_timeout=0;
}

server {
listen 80;
server_name localhost;
client_max_body_size 4G;
keepalive_timeout 5;

# path for static files
root /usr/src/app/public;

try_files $uri/index.html $uri.html $uri @app;

location @app {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_redirect off;
proxy_pass http://app_server;
}

# Rails error pages
error_page 500 502 503 504 /500.html;
location = /500.html {
root /usr/src/app/public;
}
}
}
containers/nginx/Dockerfile
FROM nginx:1.9.6
COPY nginx.conf /etc/nginx/nginx.conf

感谢您在此问题上的任何帮助。

最佳答案

我认为问题是您配置中的fail_timeout=0。当rails容器启动时,它需要花费几毫秒的启动时间(可能更长)。因此,nginx需要重试一段时间。我相信您已将超时设置为0。如果将其配置为重试几秒钟,我认为它可能会起作用。

关于ruby-on-rails - Dockernized Nginx +(Rails + Unicorn)+ Redis + PostgreSQL:connect()失败(111:连接被拒绝),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33458910/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com