无法将docker用于php项目

时间:2019-02-13 11:53:51

标签: php docker connection connection-refused

我正打算使用docker,因为我需要在工作中使用laravel,而我正努力适应它。我创建了dockerfile,并将其粘贴到我在网上找到的教程中:

FROM php:5.6.30-fpm-alpine

RUN apk update && apk add build-base

RUN apk add postgresql postgresql-dev \
    && docker-php-ext-configure pgsql -with-pgsql=/usr/local/pgsql \
  && docker-php-ext-install pdo pdo_pgsql pgsql

RUN apk add zlib-dev git zip \
  && docker-php-ext-install zip

RUN curl -sS https://getcomposer.org/installer | php \
        && mv composer.phar /usr/local/bin/ \
        && ln -s /usr/local/bin/composer.phar /usr/local/bin/composer

COPY . /app
WORKDIR /app

RUN composer install --prefer-source --no-interaction

ENV PATH="~/.composer/vendor/bin:./vendor/bin:${PATH}"

我创建了docker-compose.yml文件并将其粘贴:

version: '2'
services:
  nginx:
    image: nginx:1.11.10-alpine
    ports:
      - 3000:80
    volumes:
      - ./nginx.conf:/etc/nginx/conf.d/default.conf
  web:
    build: .
    ports:
      - 9000:9000
    volumes:
      - .:/app
      - /app/vendor
    depends_on:
      - postgres
    environment:
      DATABASE_URL: postgres://todoapp@postgres/todos
  postgres:
    image: postgres:9.6.2-alpine
    environment:
      POSTGRES_USER: todoapp

  POSTGRES_DB: todos

我做了docker-compose up-d,它似乎可以正常工作,但是如果我尝试docker-compose ps,我在第一行上没有任何端口,并且在状态下,我有1号出口

enter image description here

当我尝试转到localhost:3000/todos时,它说找不到该页面。如果我尝试做curl localhost:3000/todos,它说连接被拒绝了。...我该怎么办?

编辑:

./ nginx.conf:

server {
  listen  80;
  error_log  /var/log/nginx/error.log;
  access_log /var/log/nginx/access.log;
  root /app/public/;

  location / {
      try_files $uri /index.php$is_args$args;
  }

  location ~ ^/.+\.php(/|$) {
      fastcgi_pass web:9000;
      include fastcgi_params;
      fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
  }
}

和日志:enter image description here

文本:

nginx_1     | 2019/02/13 14:30:19 [emerg] 1#1: host not found in upstream "web" in /etc/nginx/conf.d/default.conf:12
nginx_1     | nginx: [emerg] host not found in upstream "web" in /etc/nginx/conf.d/default.conf:12

1 个答案:

答案 0 :(得分:1)

问题似乎仅在于nginx在php准备好之前启动。要进行测试,只需再运行docker-compose up -d一次即可。

在Web服务中简单地添加depends_on应该可以解决问题。 (还将版本升至2.4,这是v2 docker-compose的最新版本)

version: '2.4'
services:
  nginx:
    depends_on:
      - web

这将导致docker-compose在nginx容器之前启动php容器。但是它不会等待postgres准备好。在这种情况下,应该没问题,因为php的启动速度非常快。

如果您想要更坚实的东西,或者depends_on无法解决问题,则可以向容器添加入口点包装脚本。要了解更多信息,请访问https://docs.docker.com/compose/startup-order/。也有指向工具的链接,因此您不必从头开始编写自己的脚本。