当前位置:首页 / 编程技术 / 数据库 / docker中使用mysql数据库实现局域网访问
docker中使用mysql数据库实现局域网访问
发布时间:2022/07/10来源:编程网

获取mysql镜像


docker pull mysql:5.6

注意:此处之所以获取mysql5.6是因为mysql5.7在centos7中启动可能会报错

查看镜像列表


docker images

启动mysql镜像


docker run -itd -P mysql:5.6 bash

其中 docker run是启动容器的命令;i是交互式操作,t是一个终端,d指的是在后台运行,

-P指在本地生成一个随机端口,用来映射mysql的3306端口,mysql指运行mysql镜像,bash指创建一个交互式shell。

查看已经运行的docker镜像


docker ps -a

从图中可以看到mysql镜像的3306端口绑定了本地的32769端口,因此就说如果你要在局域网中访问docker中的mysql数据库就需要使用服务器IP:32769来进行访问。

连接到mysql镜像中


docker exec -it relaxed_hodgkin bash

docker exec 是docker镜像的连接命令,类似于ssh一样的命令,relaxed_hodgkin是镜像的名字,镜像每次启动都必须有一个名字,该名字可以手动指定也可以自己生成。

连接成功以后,如下图,已经进入到了docker mysql镜像中

查看mysql的启动状态,如上图就显示mysql没启动


service mysql status

mysql没有启动可以使用以下命令启动,如图所示启动成功


service mysql start

输入mysql 验证mysql是否启动成功

到此为止,docker中的mysql已经启动成功。

如何在外部使用root连接这个mysql? 为了安全,首先需要设置root帐号的密码,如下


update user set authentication_string = password('root') where user = 'root';

这时会报以下错误

是因为没有选择数据库,要在上面的命令之前执行下面这句,就可以将root的密码改为root


use mysql;

由于mysql中root执行绑定在了localhost,因此需要对root进行授权


GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;

最后,使用SQLyog测试mysql连接,如下

连接成功,说明docker中的mysql可以在局域网中使用。

到此这篇关于docker中使用mysql数据库实现局域网访问的文章就介绍到这了,更多相关docker对mysql数据库操作内容请搜索自学编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持自学编程网!

分享到:
免责声明:本文仅代表文章作者的个人观点,与本站无关,请读者仅作参考,并自行核实相关内容。文章内容来源于网络,版权归原作者所有,如有侵权请与我们联系,我们将及时删除。
资讯推荐
热门最新
精品工具
全部评论(0)
剩余输入数量90/90
暂无任何评论,欢迎留下你的想法
你可能感兴趣的资讯
换一批