Docker组成的桥接网络和主机在同一容器上的远程端口转发

时间:2018-12-14 08:05:58

标签: docker unix networking ssh docker-compose

我正在尝试提供可以将远程数据库端口转发到容器的服务,同时可以通过别名主机名从其他容器访问该服务以与它们一起使用。
我认为让所有容器通过主机网络进行通信是一种不好的做法,因此我正在尝试设置该配置。
当我用driver: host添加到php-fpm服务网络时,码头工人说
only one instance of "host" network is allowed
当我尝试以此设置php-fpm服务

networks
- host

Docker说他找不到这个名字的网络。
当我尝试通过内置host的id在docker-compose中定义网络时,它只是无法启动此容器。

这是我的docker-compose:

version: '3.2'

networks:
  backend-network:
    driver: bridge
  frontend-network:
    driver: bridge

volumes:
  redis-data:
  home-dir:

services:
  &app-service app: &app-service-template
    build:
      context: ./docker/app
      dockerfile: Dockerfile
    volumes:
    - ./src:/app:rw
    - home-dir:/home/user
    hostname: *app-service
    environment:
      FPM_PORT: &php-fpm-port 9001
      FPM_USER: "${USER_ID:-1000}"
      FPM_GROUP: "${GROUP_ID:-1000}"
      APP_ENV: local
      HOME: /home/user
    command: keep-alive.sh
    networks:
    - backend-network

  &php-fpm-service php-fpm:
    <<: *app-service-template
    user: 'root:root'
    restart: always
    hostname: *php-fpm-service
    ports: [*php-fpm-port]
    environment:
      FPM_PORT: *php-fpm-port
      FPM_USER: "${USER_ID:-1000}"
      FPM_GROUP: "${GROUP_ID:-1000}"
      APP_ENV: local
      HOME: /home/user
    entrypoint: /fpm-entrypoint.sh
    command: php-fpm --nodaemonize -R -d "opcache.enable=0" -d "display_startup_errors=On" -d "display_errors=On" -d "error_reporting=E_ALL"
    networks:
    - backend-network
    - frontend-network

  nginx:
    build:
      context: ./docker/nginx
      dockerfile: Dockerfile
    restart: always
    working_dir: /usr/share/nginx/html
    environment:
      FPM_HOST: *php-fpm-service
      FPM_PORT: *php-fpm-port
      ROOT_DIR: '/app/public' # App path must equals with php-fpm container path
    volumes:
    - ./src:/app:ro
    ports: ['9999:80']
    depends_on:
    - *php-fpm-service
    networks:
    - frontend-network

网络方案(关于绿线的问题):
Network Scheme

主机在Debian 7上运行(禁止更新),而conainer在最新的Alpine上运行

0 个答案:

没有答案