首页 > 解决方案 > FluentMySQL 迁移在使用 docker-compose 构建时失败,但在从 Xcode 构建时失败

问题描述

将 docker-compose 与 Vapor & FluentMySQL 一起使用时,我遇到了以下崩溃。

api_1  | [ INFO ] Migrating 'mysql' database (/app/.build/checkouts/fluent/Sources/Fluent/Migration/MigrationConfig.swift:69)
    api_1  | Fatal error: Error raised at top level: NIO.ChannelError.connectFailed(NIO.NIOConnectionError(host: "db", port: 3309, dnsAError: nil, dnsAAAAError: nil, connectionErrors: [NIO.SingleConnectionFailure(target: [IPv4]db/172.27.0.2:3309, error: connection reset (error set): Connection refused (errno: 111))])): file /home/buildnode/jenkins/workspace/oss-swift-5.1-package-linux-ubuntu-18_04/swift/stdlib/public/core/ErrorType.swift, line 200

使用时迁移失败:

migrations.add(model: Model.self, database: .mysql)

如果我删除它,那么没有模型被迁移,应用程序构建没有错误,我可以在http://localhost/访问它。

我的 docker-compose.yml 看起来像这样:

version: "3.7"
services:
  api:
    image: vaporapiimage
    ports:
      - 80:8080
    environment:
      MYSQL_HOST: db
      MYSQL_USER: user
      MYSQL_PASSWORD: password
      MYSQL_DATABASE: dbname
      SLEEP_LENGTH: 7
      MYSQL_PORT: 3309
    depends_on:
        - db
  db:
    image: mysql:8.0.1
    environment:
      MYSQL_ROOT_PASSWORD: password
      MYSQL_DATABASE: dbname
      MYSQL_USER: user
      MYSQL_PASSWORD: password
    ports:
      - "3309:3306"

它从 Xcode 本地构建和运行(就像没有 Docker 一样)。

如果api服务被注释掉,那么db服务将自行运行并在第一次运行时创建数据库。

任何帮助将不胜感激。

更新:api用 Adminer 替换导致能够db在浏览器中通过 Adminer 访问。所以该db服务是可访问的,似乎问题出在 Vapor/Fluent 上(或者更确切地说是我对它们的使用):

  admin:
    image: adminer
    ports:
      - 8080:8080

标签: docker-composevaporfluent-mysql

解决方案


问题是我已将端口映射db到 3309,这样它就不会与主机 MYSQL 冲突,但也将 ENV 'MYSQL_PORT' 设置为 3309,而应该将其保留为默认 3306,因为那是为了在容器。


推荐阅读