表“test_db.colors”不存在

我正在使用 Docker、docker-compose、MySQL 和 Go 构建一个应用程序。


当我尝试测试一个端点时,我收到错误Table 'test_db.colors' doesn't exist。


似乎 sql 转储没有正确导入。


但是我可以连接数据库,至少没有错误,这是在同一个.sql文件中创建的。


当我启动应用程序时,终端显示:


golang_app         | 2020/06/20 21:48:04 docker:docker@tcp(db_mysql:3306)/test_db


golang_app         | 2020/06/20 21:48:04 DB Connected

在我向端点发出请求后,我得到:


2020/06/20 22:05:00 File: handlers.go  Function: main.testDBHandler Line: 26 Error 1146: Table 'test_db.colors' doesn't exist

文件结构为:


 ./

  |_app/

    |_docker-compose.yml

    |_Go/

      |_*.go

      |_Dockerfile

    |_MySQL/

      |_Dockerfile

      |_.env

      |_sql-scripts/

        |_test.sql

文件的内容如下所示:


码头工人-compose.yml


version: '3'

services:

  fullstack-mysql:

    container_name: db_mysql

    build:

      context: ./MySQL

    ports:

      - 3306:3306

    volumes:

      - database_mysql:/var/lib/mysql

      - mysql-log:/var/log/mysql

      - mysql-conf:/etc/mysql/conf.d

      - ./MySQL/sql-scripts:/docker-entrypoint-initdb.d

    networks:

      - fullstack


  app:

    container_name: golang_app

    env_file:

      - ./Go/.env

    build:

      context: ./Go

    ports:

      - 9000:9000

    restart: unless-stopped

    volumes:

      - api:/usr/src/app/

    depends_on:

      - fullstack-mysql

    networks:

      - fullstack


  phpmyadmin:

    image: phpmyadmin/phpmyadmin

    container_name: phpmyadmin_container

    depends_on:

      - fullstack-mysql

    environment:

      - PMA_HOST=fullstack-mysql #Note the "mysql". Must be the name of the what you used as the mysql service.

      - PMA_USER=root

      - PMA_PORT=3306

      - PMA_PASSWORD=root

      - PMA_ARBITRARY=1

    ports:

      - 9095:80

    restart: always

    networks:

      - fullstack

    links:

      - fullstack-mysql


volumes:

  api:

  database_mysql:

  mysql-log:

    driver: local

  mysql-conf:

    driver: local


networks:

  fullstack:

    driver: bridge

应用程序/MySQL/Dockerfile


千巷猫影
浏览 107回答 2
2回答

四季花海

需要检查的几件事:mysql 容器是否表明它已正确启动?您的 mysql 设置是否太复杂(见下文)?您是否尝试过使用另一个应用程序(例如 datagrip 或其他一些 mysql 客户端)连接到您的 mysql 实例?在连接到它之前,您是否确保 mysql 实际上已经完成了它的启动过程?depends_on在这里可能无法真正正常工作——其他应用程序在 mysql 启动之前不会启动,但 mysql 不一定会被配置——即你的 test.sql 可能没有实际运行。您的 mysql 设置似乎有些复杂。有必要吗?我使用了一组类似的技术,我的数据库 docker compose 看起来像这样:  fullstack-mysql:    image: mysql:8.0    ports:      - 3306:3306    volumes:      - database_mysql:/var/lib/mysql      - mysql-log:/var/log/mysql      - mysql-conf:/etc/mysql/conf.d      - ./MySQL/sql-scripts:/docker-entrypoint-initdb.d    environment:      - MYSQL_ROOT_PASSWORD=root      - MYSQL_PASSWORD=docker      - MYSQL_USER=docker      - MYSQL_DATABASE=test_db      - MYSQL_HOST=127.0.0.1      - MYSQL_PORT=3306      - MYSQL_DRIVER=mysql    networks:      - fullstack假设您不需要做任何复杂的事情,这应该删除大部分 mysql 数据库设置。我做的唯一不同的事情是映射单个启动脚本,而不是整个目录——即volumes:  ./MySQL/sql-scripts/test.sql:/docker-entrypoint-initdb.d/test.sql虽然我认为您指定的文件夹映射应该可以工作。我刚刚注意到的还有一点:在您的 mysql dockerfile 中,您可以这样做:COPY ./sql-scripts/test.sql /docker-entrypoint-initdb.d/但这对于 docker-compose 文件来说似乎是多余的,它将一个卷放在同一位置。

守候你守候我

入口点上的初始化脚本仅在第一次创建数据库时运行(即当文件夹 /var/lib/mysql 为空时)删除主机中的 database_mysql 文件夹并让 docker-compose 自动重新创建它。这将导致脚本运行。请注意,当您删除文件夹时,存储在数据库中的所有数据都将丢失。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go