Docker中部署mysql服务的⽅法及遇到的坑
最近⼀直在学习搬运⼯,感觉这么厉害的东西怎么以前不知道呢,把⾃⼰捣⿎的过程整理记录下来,供同学们参考
第零步:从Docker Hub拉取官⽅mysql镜像
docker pull mysql
然后就是进⼊漫长的等待,当然如果你配置了镜像加速器,速度会快那么⼀丢丢
第⼀步:使⽤docker images命令查看镜像
你会看到我们这⾥已经有了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
可以看到,我们的MySQL的的的的容器已经跑起来了,dockeer给mysql的的的的容器分配了⼀个容器的编号,便于我们管理,还显⽰我们设置的端⼝映射情况
这个时候有的⽼哥可能会想,虽然MySQL的的的的容器欢快的跑起来了,但是你丫只告诉我们端⼝,我们怎么知道它的IP呢,我信你个⿁你的⽼头⼦坏得很。
不不不。我们可以使⽤docker inspect -f ='{{。NetworkSettings.IPAddress}}'5fef288f221f命令查看容器的ip,注意最后直接写要查看的容器的id即可,⽹上那些⼈坏得很,还给你加⼀个<>,导致你很郁闷,就照我这样准没错
还有⼀点需要注意的是:要是想在外部连接我们的Mysql容器,进⾏远程管理的话,需要配置容器⾥mysql的root账户的主机,把它改成⼀个通配符%,就可以让任意主机连接我们的MySQL的了,具体⽅法如下:
进⼊MySQl容器:使⽤的docker exec命令,-it是参数,bash表⽰创建⼀个交互界⾯
登录mysql服务器:使⽤的root⽤户登录mysql,在输⼊密码之后,我们可以看到已经进去了mysql
使⽤show数据库; 命令查看数据库(注意不要忘了最后的分号中,MySQL的命令都要有分号)
mysql社区版国内镜像下载可以看到,我们的数据库都列了出来,然后使⽤mysql; 命令进⼊MySQL的这个数据库(是不是很绕⼝,哈哈哈,这⾥的MySQL的数据库是指的这⼀个数据库,好吧我可能还是没说明⽩)
然后使⽤show tables; 命令列出所有的表
可以看到,有好多个表,这都是MySQL的的配置,不⽤去关注,我们只需要修改⼀个⽤户表即可
使⽤sql命令:update user set host ='%'where user ='root';
这个命令有的同学可能会报错,原因是你的MySQL的可能有多个根⽤户,所以要⽤下⾯的命令
update user set host ='%'其中user ='root'和host ='localhost';
配置完上⾯的步骤可以测试⼀下连接,如果能够连接上,恭喜你,你很幸运。
如果连不上,也要恭喜你,因为你下的mysql镜像是mysql8的,
你可能会遇见下⾯这个错误
⾄此,配置完成,使⽤退出; 命令退出即可。
测试远程连接
第四步:向我们的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服务的⽅法,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论