docker启动mysql
docker run \ -p 3307:3306 \ --name mysql-first \ --privileged=true \ --restart unless-stopped \ -v /usr/local/mysql/mysql-first/conf.d:/etc/mysql/conf.d \ -v /usr/local/mysql/mysql-first/logs:/logs \ -v /usr/local/mysql/mysql-first/data:/var/lib/mysql \
-v /etc/localtime:/etc/localtime \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql
解释: -p 端口映射 【这里有个特殊的地方是把3306映射给了3307、后续链接数据库的时候用3307链接不用3306】
--name mysql-first 名称是mysql-first
--privileged=true 挂载文件权限设置
--restart unless-stopped 设置 开机后自动重启容器
-v /usr/local/mysql/mysql-first/conf.d:/etc/mysql/conf.d \ 挂载配置文件【路径是上面创建的挂载路径】
-v /usr/local/mysql/mysql-first/logs:/logs \ 挂载日志【路径是上面创建的挂载路径】
-v /usr/local/mysql/mysql-first/data:/var/lib/mysql \ 挂载数据文件 持久化到主机【路径是上面创建的挂载路径】
-v /etc/localtime:/etc/localtime 容器时间与宿主机同步
-e MYSQL_ROOT_PASSWORD=123456 设置密码
-d mysql 后台启动,mysql
检查是否启动成功
docker ps
6.配置链接信息
到这里已经成功启动了、但是连接还需要在配置之后才可以链接。
进入mysql8 容器
docker exec -it mysql8 bash
在容器内登录mysql
mysql -u root -p
如果出现异常:(初始密码不成功,密码默认为空,直接Enter)保证进入到mysql命令行。
设置权限(为root分配权限,以便可以远程连接)
grant all PRIVILEGES on *.* to root@'%' WITH GRANT OPTION;
use mysql
update user set host='%' where user='root';
由于Mysql5.6以上的版本修改了Password算法,这里需要更新密码算法,便于使用Navicat连接
grant all PRIVILEGES on *.* to root@'%' WITH GRANT OPTION;
ALTER user 'root'@'%' IDENTIFIED BY '123456' PASSWORD EXPIRE NEVER;
ALTER user 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
FLUSH PRIVILEGES;

浙公网安备 33010602011771号