Docker Compose mysql import .sql

前端 未结 5 714
伪装坚强ぢ
伪装坚强ぢ 2021-01-31 16:32

I\'m having trouble importing an .sql dump file with docker-compose. I\'ve followed the docs, which apparently will load the .sql file from docker-entrypoint-initdb.d. However,

5条回答
  •  梦毁少年i
    2021-01-31 17:11

    I was having a similar issue with mysql where I would mount a local directory at /configs/mysql/data containing a mydatabasedump.sql file via docker-compose to the docker-entrypoint-initdb.d volume, the file would get loaded on to the container but not execute or populate the database when the container initialized. My intial docker-compose.yml looke like this:

    #docker-compose.yml
    version: '3'
    services:
        db:
            build: ./build/mysql/ #this is pointing to my Dockerfile
            container_name: MYSQL_Database
            restart: always
            environment:
            MYSQL_PORT: 3306
            MYSQL_ROOT_PASSWORD: admin
            MYSQL_DATABASE: my_app_database
            MYSQL_USER: admin
            MYSQL_PASSWORD: admin
        volumes:
            - ./configs/mysql/data:/docker-entrypoint-initdb.d:
    

    I found two working solutions for this problem:

    The first came after I logged in the running container and confirmed that mydatabasedump.sq file was present and executable in the container's docker-entrypoint-initdb.d directory; I created and added a bash script to my local /configs/mysql/data directory called dump.sh that excuted after the container was initialized. It contains a single mysql command that copies my_database_dump.sql to my_app_database. The bash script looks like this

        #!/bin/bash
        #dump.sh
        mysql -uadmin -padmin my_app_database < my_database_dump.sql 
        #end of dump.sh
    

    I executed this script via my Dockerfile in the ENTRYPOINT directive like this:

        #Dockerfile
        FROM mysql:5.5
        ENTRYPOINT [ "dump.sh" ]
        EXPOSE 80
        #end of Dockerfile
    

    After realizing the initial issue was due to the volumes being mouted after the cotainer is built and therefore not intilizing the database with the dump file (or executing any scripts in that directory) at boot time, the second solution was simply to move the volumes directive in my compose-file above the built directive. This worked and allowed me to remove the dump.sh scrip and the DOCKERENTRY directive in my Dockerfile. The modified docker-compose.yml looks like this

    #docker-compose.yml
    version: '3'
    services:
        db:
            volumes:
              - ./configs/mysql/data:/docker-entrypoint-initdb.d
           build: ./build/mysql/ #this is pointing to my Dockerfile
             container_name: MYSQL_Database
             restart: always
         environment:
             MYSQL_PORT: 3306
             MYSQL_ROOT_PASSWORD: admin
             MYSQL_DATABASE: my_app_database
             MYSQL_USER: admin
             MYSQL_PASSWORD: admin
    

提交回复
热议问题