关闭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