1、查找镜像
docker search mysql
也可以去官网查看镜像tag,选择自己需要的版本,否则会下载最新版本:https://hub.docker.com/_/mysql/
2、下载镜像
docker pull mysql
3、运行容器
docker run -p 3306:3306 --name mysql-1 -e MYSQL_ROOT_PASSWORD=root -d mysql
参数说明:
- -p 3306:3306:将容器的 3306 端口映射到主机的 3306 端口。
- –name:指定容器名称
- -e MYSQL_ROOT_PASSWORD=root:初始化 root 用户的密码。
- -d:后台运行
- mysql:运行的镜像名称,如果不跟上版本,默认为mysql:laster。
此时,用navicat for mysql连接mysql发现报错:Client does not support authentication protocol requested by server。
解决方案:
#进入容器:
docker exec -it mysql /bin/bash
#登录mysql:
mysql -uroot -p
#更新root用户密码:
mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root';
#刷新权限:
mysql> flush privileges;
4、修改docker中mysql配置
第一种方法:安装vim,在docker中安装vim
apt-get update
apt-get install vim
第二种方法:在启动时,直接映射conf->/etc/mysql/conf.d文件夹,然后在conf.d中添加my.cnf文件。由于/etc/mysql/my.cnf默认导入了conf.d文件夹下的内容,所以直接在宿主机外部添加my.cnf文件即可。
docker run -p 3306:3306 --name mysql-1 --privileged=true -v $PWD/conf:/etc/mysql/conf.d -v $PWD/logs:/logs -v $PWD/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql
第三种方法:在数组机修改后,复制到docker容器中。
从容器中复制到宿主机
docker cp mysql:/etc/mysql/mysql.conf.d/mysqld.cnf /root/mysqld.cnf
从宿主机复制到容器
docker cp /root/mysqld.cnf mymysql:/etc/mysql/mysql.conf.d/
Docker 修改MySQL配置
参考:https://blog.youkuaiyun.com/zhaoyajie1011/article/details/98623666