Docker进入MySQL之后如何用sql文件初始化数据

关闭Docker-compose.yml里面所有容器

docker compose -f docker_compose.yml down

后台形式开启Docker-compose.yml所有容器

docker compose -f docker_compose.yml up -d

罗列出所有启动过的(包括退出过的)容器

docker ps -a

进入指定容器ID内部

docker exec -it 容器ID bash

注意,我这里是3307端口映射到Docker容器里面的3306端口
挂载目录这里Volumes,
./xiaohashu.sql说的是我这个Docker-compose文件所在目录的sql文件路径

/docker-entrypoint-initdb.d/xiaohashu.sql这里是完整的从根目录算起的绝对路径!!!

这个/docker-entrypoint-initdb.d/xiaohashu.sql我们需要在命令行外面手动复制到容器内部

docker cp /data/xiaohashu.sql mysql:/docker-entrypoint-initdb.d/

上面的mysql是我们docker ps -a的服务名称

在这里插入图片描述

这里3307是ubuntu里面的端口,映射到Docker内部3306,注意下面命令写的是ubuntu的3307端口
然后我们进入Docker里面的MySQL容器后面接上我们要初始化的sql文件

mysql -h目标服务器ip地址 -P3307 -uroot -p我的MySQL密码 xiaohashu < ./xiaohashu.sql

用该命令导入sql数据

mysql -h192.168.159.132 -P3307 -uroot -pA2qT03X7KlL4v/F2foD6kV/Ch9gpNBWOh1qoCywanjv1AsI7f9x3iAyR9NkUKeV+FMo+halCTzy5Llbk2VOrVQ== xiaohashu < ./xiaohashu.sql

进入docker里面的MySQL之后

mysql -P3307 -uroot -pA2qT03X7KlL4v/F2foD6kV/Ch9gpNBWOh1qoCywanjv1AsI7f9x3iAyR9NkUKeV+FMo+halCTzy5Llbk2VOrVQ==
show databases;
show tables;

注意:我们的Docker内部的查看文件的命令与ubuntu的指令有区别,
查看当前目录所有文件是dir或者是ls是没有ll

Docker容器异常可以用下面的命令:

docker logs 容器ID
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hwg985

祝老板生意兴隆,财源广进

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值