使用 Docker 部署 MySQL 服务,通透!

>>强大,10k+点赞的 SpringBoot 后台管理系统竟然出了详细教程!

点击关注公众号,利用碎片时间学习

最近一直在学习docker,感觉这么厉害的东西怎么以前不知道呢,把自己捣鼓的过程整理记录下来,供同学们参考

第零步:从Docker Hub拉取官方mysql镜像

docker pull mysql

然后就是进入漫长的等待,当然如果你配置了镜像加速器,速度会快很多,因为就相当于你从国内的镜像源下载。

第一步:使用docker images命令查看镜像

使用 Docker 部署 MySQL 服务,通透!

你会看到我们这里已经有了MySQL的的的镜像

第二步:启动我们的mysql的镜像,创建一个MySQL容器

使用命令:docker run -d --name mysql -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql

解释一下这里的参数:

  • -d表示在后台运行,不随当前命令行窗口的退出而退出
  • --name给容器起一个别名,以后可以通过这个别名管理此容器
  • -p 3307指3307把宿主机的3307端口映射到Mysql容器的3306端口
  • -e MySQL容器的环境配置
  • MYSQL_ROOT_PASSWORD=123456   指定mysql的密码,用户名默认为root,注意如果没有指定密码,会启动失败

第三步:查看我们已经启动的mysql容器

使用命令:docker ps

使用 Docker 部署 MySQL 服务,通透!

可以看到,我们的MySQL的容器已经跑起来了,dockeer给mysql的容器分配了一个容器的编号,便于我们管理,还显示我们设置的端口映射情况

这个时候有的老哥可能会想,虽然MySQL容器欢快的跑起来了,但是你丫只告诉我们端口,我们怎么知道它的IP呢,我信你个鬼你的老头子坏得很。

不不不。我们可以使用docker inspect -f ='{{。NetworkSettings.IPAddress}}'5fef288f221f命令查看容器的ip,注意最后直接写要查看的容器的id即可,网上那些人坏得很,还给你加一个<>,导致你很郁闷,就照我这样准没错

还有一点需要注意的是:要是想在外部连接我们的Mysql的容器,进行远程管理的话,需要配置容器里的MySQL的根账户的主机,把它改成一个通配符,就可以让任意主机连接我们的MySQL的的了,具体方法如下:

进入MySQl容器:使用的docker exec命令,-it是参数,bash表示创建一个交互界面

使用 Docker 部署 MySQL 服务,通透!

登录MySQL的服务器:使用的root用户登录的MySQL,在输入密码之后,我们可以看到已经进去了的MySQL

使用 Docker 部署 MySQL 服务,通透!

使用show databases; 命令查看数据库(注意不要忘了最后的分号,MySQL的命令都要有分号)

使用 Docker 部署 MySQL 服务,通透!

可以看到,我们的数据库都列了出来,然后使用MySQL的; 命令进入的MySQL的这个数据库(是不是很绕口,哈哈哈,这里的MySQL的的数据库是指的这一个数据库,好吧我可能还是没说明白)

然后使用show tables; 命令列出所有的表

使用 Docker 部署 MySQL 服务,通透!

可以看到,有好多个表,这都是MySQL的的的配置,不用去关注,我们只需要修改一个用户表即可

使用sql命令:update user set host ='%'where user ='root';

这个命令有的同学可能会报错,原因是你的MySQL的的可能有多个根用户,所以要用下面的命令

更新root用户的host为通配符%

update user set host ='%' 其中user ='root'和host ='localhost';

-- 授权用户,赋予用户超级管理权限
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;

这里有一个需要注意的点,上面的命令适用于Mysql5.7之前的版本,在mysql8.0之后,有一些细微改动,Mysql8.0建议把创建用户和授权用户的命令分开,上面的命令相当于创建一个用户再授权,而mysql8.0需要用下面的命令

-- 创建一个用户,mysql 8 之后要求先创建用户,再授权,而不能在授权时创建用户
create user 'root'@'%' identified by '123456';
-- 授权用户为超级管理用户
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;

然后还不算完,还有一个坑,mysql8以后的版本更改了连接密码验证方式,由原来的native改成了ssh2的,但是可视化工具还不支持,要是想用可视化工具连接,需要手动更改root用户的密码验证方式

-- 更改用户密码验证方式
ALTER USER 'root'@'%' IDENTIFIED BY '123456' PASSWORD EXPIRE NEVER;
 
 
-- 刷新更改密码验证方式之后的密码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456'
 
 
-- 刷新权限
FLUSH PRIVILEGES;

配置完上面的步骤可以测试一下连接,如果能够连接上,恭喜你,你很幸运。

至此,配置完成,使用退出; 命令退出即可。

测试远程连接,测试用mysql_front是不行的,这里我用的native for mysql,是一个非常强大的数据库可视化工具,它可以支持多种数据库。

使用 Docker 部署 MySQL 服务,通透!

第四步:向我们的MySQL的的容器导入数据

虽然我们的Mysql容器跑起来了,但是这里面没数据啊,可以通过以下方法向docker中的MySQL的导入数据库,当然了,如果你用可视化工具连上了,就用不到下面的步骤了

先将文件导入到容器,cp后面是你准备导入的sql文件路径

#docker cp **.sql mysql:/root/

进入容器

#docker exec -it mysql bash

将文件导入数据库

# mysql -uroot -p 【数据库名】 < ***.sql
  • mysql -h localhost -u root -p(进入mysql下面)
  • create database abc;(创建数据库)
  • show databases;(就可看到所有已经存在的数据库,以及刚刚创建的数据库abc)
  • use abc;(进入abc数据库下面)
  • show tables;(产看abc数据库下面的所有表,空的)
  • source /var/test.sql(导入数据库表)
  • show tables;(查看abc数据库下面的所有表,就可以看到表了)
  • desc pollution;(查看表结构设计)
  • select * from pollution;
  • exit(或者ctrl + c)退出mysql

以上,就是在docker中部署的Mysql的服务的方法,刚刚学遇到很多坑,希望你们引以为戒,上述内容亲测可用,如果有错误,请提醒我改正

来源:blog.csdn.net/weixin_40693633/

article/details/84074459

推荐:

主流Java进阶技术(学习资料分享)

使用 Docker 部署 MySQL 服务,通透!
PS:因为公众号平台更改了推送规则,如果不想错过内容,记得读完点一下“在看”,加个“星标”,这样每次新文章推送才会第一时间出现在你的订阅列表里。“在看”支持我们吧!

原文始发于微信公众号(Java笔记虾):使用 Docker 部署 MySQL 服务,通透!