Docker-compose 桥接网络和主机远程端口转发在同一容器中

Zul*_*com 5 unix ssh networking docker docker-compose

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

networks
- host
Run Code Online (Sandbox Code Playgroud)

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

这是我的 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
Run Code Online (Sandbox Code Playgroud)

网络方案(绿线问题):
网络方案

主机在 Debian 7 上工作(禁止更新),conainer 在最新的 Alpine 上工作