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

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

bash 复制代码
docker compose -f docker_compose.yml down

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

bash 复制代码
docker compose -f docker_compose.yml up -d

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

bash 复制代码
docker ps -a

进入指定容器ID内部

bash 复制代码
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我们需要在命令行外面手动复制到容器内部

bash 复制代码
docker cp /data/xiaohashu.sql mysql:/docker-entrypoint-initdb.d/

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

这里3307是ubuntu里面的端口,映射到Docker内部3306,注意下面命令写的是ubuntu的3307端口

然后我们进入Docker里面的MySQL容器后面接上我们要初始化的sql文件

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

用该命令导入sql数据

bash 复制代码
mysql -h192.168.159.132 -P3307 -uroot -pA2qT03X7KlL4v/F2foD6kV/Ch9gpNBWOh1qoCywanjv1AsI7f9x3iAyR9NkUKeV+FMo+halCTzy5Llbk2VOrVQ== xiaohashu < ./xiaohashu.sql

进入docker里面的MySQL之后

bash 复制代码
mysql -P3307 -uroot -pA2qT03X7KlL4v/F2foD6kV/Ch9gpNBWOh1qoCywanjv1AsI7f9x3iAyR9NkUKeV+FMo+halCTzy5Llbk2VOrVQ==
bash 复制代码
show databases;
bash 复制代码
show tables;

注意:我们的Docker内部的查看文件的命令与ubuntu的指令有区别,

查看当前目录所有文件是dir或者是ls是没有ll

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

bash 复制代码
docker logs 容器ID
相关推荐
匆匆那年96741 分钟前
Docker容器中安装MongoDB,导入数据
运维·docker·容器
眠りたいです1 小时前
Mysql常用内置函数,复合查询及内外连接
linux·数据库·c++·mysql
i小溪2 小时前
在使用 Docker 时,如果容器挂载的数据目录(如 `/var/moments`)位于数据盘,只要服务没有读写,数据盘是否就不会被唤醒?
人工智能·docker
M1A12 小时前
Java 面试系列第一弹:基础问题大盘点
java·后端·mysql
He.ZaoCha2 小时前
函数-1-字符串函数
数据库·sql·mysql
叁沐2 小时前
MySQL 09 普通索引和唯一索引,应该怎么选择?
mysql
草履虫建模4 小时前
Redis:高性能内存数据库与缓存利器
java·数据库·spring boot·redis·分布式·mysql·缓存
苹果醋34 小时前
Vue3组合式API应用:状态共享与逻辑复用最佳实践
java·运维·spring boot·mysql·nginx
一个处女座的测试4 小时前
Python语言+pytest框架+allure报告+log日志+yaml文件+mysql断言实现接口自动化框架
python·mysql·pytest
蓝纹绿茶5 小时前
【Mac】实现Docker下载安装【正在逐步完善】
macos·docker·容器