docker安装MySQL
安装过程
搜索镜像
8.0版本:sudo docker search mysql

sudo docker pull mysql
5.7版本: sudo docker pull mysql:5.7

sudo docker images

安装镜像
sudo docker run -p 3306:3306 --name mysql \
-v /usr/local/server/docker-lib/mysql/conf:/etc/mysql \
-v /usr/local/server/docker-lib/mysql/logs:/var/log/mysql \
-v /usr/local/server/docker-lib/mysql/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql
–name:容器名,此处命名为mysql -e:配置信息,此处配置mysql的root用户的登陆密码 -p:端口映射,此处映射 主机3306端口到容器的3306端口 -d:源镜像名,此处为 mysql
-v:主机和容器的目录映射关系,":"前为主机目录,之后为容器目录
如果之前启动过MySQL,会显示如下错误,表示容器重复:
Error response from daemon: Conflict. The container name "/mysql" is already in use by container

先查看所有的容器:
docker ps -a

docker rm 55b553ee5a26(容器id),然后再启动

遇到的坑1:
Navicat一直连接不上,先检查3306端口是否开放:
firewall-cmd --zone=public --query-port=3306/tcp
如果为no,表示3306端口未开放,进行开放:
firewall-cmd --zone=public --add-port=3306/tcp --permanent
--zone=public :表示作用域
--add-port=3306/tcp : 端口和访问类型
--permanent : 永久生效

遇到的坑2:
我的MySQL是在阿里云上启动的,阿里云的3306端口未开放,去云控制台开放即可

浙公网安备 33010602011771号