总结:
需分清楚当前在哪个层级操作,1. 在docker上操作,2.在容器(即Containers,例如mysql)内操作,3.在账号密码连接上mysql之后的操作(这里就是平时使用数据库一样,用SQL执行了).
docker: 一. 拉取mysql,自选版本
docker pull mysql
版本写成docker pull mysql:5.7
(可以查看自己有哪些镜像:docker images)
二.创建容器并启动
我因为Windows已经装了本地的mysql,3306被占用,所以用的3309.
mysql8是容器名称,最后面这个mysql应该是选哪个版本,123456是密码
(一开始我以为mysql8是数据库连接的账户,结果发现不是)
docker run --name mysql8 -e MYSQL_ROOT_PASSWORD=123456 -v /root/mysql/conf:/etc/mysql/conf.d/ -v /root/mysql/data:/var/lib/mysql -p 3309:3306 -d mysql
三.进入容器
容器id不知道的可以用docker ps 指令找, 或者直接复制
docker exec -it 容器id /bin/bash
注意:此处有碰到一些坑,需要改配置啥的, 可能需要安装vim
(安装vim
//参考:https://blog.csdn.net/qq_33770578/article/details/125748826
apt-get update
apt-get install vim
)
容器中: 四.进入MySQL
mysql -u root -p
成功, 可以查看数据库版本, select version();
我用的Navicat连接
如果失败: 跟我一样的萌新建议删了重来, 我尝试了网上的好多种解决方法,最后绕来绕去,没解决掉.
第二步比较关键. 之前试了几种,可能是路径不对,容器进入mysql步骤的时候就出问题.
删除容器(慎用): docker rm 容器名称
退出mysql, 退出容器都是: exit
ps: 安装了mysql8之后我按自己的流程又装了一遍5.7的,第一次路径没改,装完就报
Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’,
然后删了重新执行下面的指令,顺利完成
docker run --name mysql5.7 -e MYSQL_ROOT_PASSWORD=123456 -v /root/mysql5/conf:/etc/mysql/conf.d/ -v /root/mysql5/data:/var/lib/mysql -p 3308:3306 -d mysql:5.7