• 售前

  • 售后

热门帖子
入门百科

Docker中摆设mysql服务的方法及碰到的坑

[复制链接]
平衡才能持久 显示全部楼层 发表于 2021-10-25 20:29:04 |阅读模式 打印 上一主题 下一主题
迩来一直在学习搬运工,感觉这么锋利的东西怎么以前不知道呢,把本身捣鼓的过程整理记载下来,供同学们参考
第零步:从Docker Hub拉取官方mysql镜像
  1. docker pull mysql
复制代码
然后就是进入漫长的等候,固然假如你设置了镜像加快器,速度会快那么一丢丢
第一步:利用docker images下令检察镜像

你会看到我们这里已经有了MySQL的的镜像
第二步:启动我们的mysql的镜像,创建一个MySQL的容器
利用下令:
  1. docker run -d --name mysql -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql
复制代码
表明一下这里的参数:
-d体现在后台运行,不随当前下令行窗口的退出而退出
--name给容器起一个别名,以后可以通过这个别名管理此容器
-p 3307:3307把宿主机的3307端口映射到Mysql容器的3306端口
-e MySQL容器的情况设置
  1. 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的数据库是指的这一个数据库,好吧我可能照旧没分析确)
然后利用show tables; 下令列出所有的表

可以看到,有许多多少个表,这都是MySQL的的设置,不用去关注,我们只需要修改一个用户表即可
利用sql下令:
  1. update user set host ='%'where user ='root';
复制代码
这个下令有的同学可能会报错,缘故原由是你的MySQL的可能有多个根用户,所以要用下面的下令
  1. update user set host ='%'其中user ='root'和host ='localhost';
复制代码
设置完上面的步骤可以测试一下连接,假如可以或许连接上,恭喜你,你很荣幸。
假如连不上,也要恭喜你,因为你下的mysql镜像是mysql8的,
你可能会遇见下面这个错误
至此,设置完成,利用退出; 下令退出即可。
测试远程连接

第四步:向我们的MySQL的容器导入数据
固然我们的Mysql的的的的容器跑起来了,但是这内里没数据啊,可以通过以下方法向docker中的MySQL导入数据库
先将文件导入到容器,cp背面是你预备导入的sql文件路径
  1. #docker cp **.sql mysql:/root/
  2. 进入容器
  3. #docker exec -it mysql bash
  4. 将文件导入数据库
  5. # mysql -uroot -p 【数据库名】 < ***.sql
  6. mysql -h localhost -u root -p(进入mysql下面)
  7. create database abc;(创建数据库)
  8. show databases;(就可看到所有已经存在的数据库,以及刚刚创建的数据库abc)
  9. use abc;(进入abc数据库下面)
  10. show tables;(产看abc数据库下面的所有表,空的)
  11. source /var/test.sql(导入数据库表)
  12. show tables;(查看abc数据库下面的所有表,就可以看到表了)
  13. desc pollution;(查看表结构设计)
  14. select * from pollution;
  15. exit(或者ctrl + c)退出mysql
复制代码
总结
以上所述是小编给各人先容的Docker中部署mysql服务的方法,盼望对各人有所资助,假如各人有任何疑问请给我留言,小编会及时复兴各人的。在此也非常感谢各人对草根技术分享网站的支持!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作