欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

docker中使用mysql数据库详解(在局域网访问)

程序员文章站 2023-08-16 16:39:25
前言 开发过程中经常需要安装、调试mysql数据库,还需要在各种操作系上安装包依赖,实在是繁琐,因此就研究了一下如何在docker上运行一个mysql镜像,省却了我安装、...

前言

开发过程中经常需要安装、调试mysql数据库,还需要在各种操作系上安装包依赖,实在是繁琐,因此就研究了一下如何在docker上运行一个mysql镜像,省却了我安装、找依赖的问题。

注:本文所有内容均在centos linux release 7.2.1511 (core) 上测试完成

假设,你已经安装好docker。如果没有安装好docker可以参考centos7上安装docker

使用

docker pull mysql

获得mysql镜像,接着使用

docker images

查看镜像列表,如下

docker中使用mysql数据库详解(在局域网访问)

使用

docker run -itd -p mysql bash

启动mysql镜像,docker run是启动容器的命令;i是交互式操作,t是一个终端,d指的是在后台运行,-p指在本地生成一个随机端口,用来映射mysql的3306端口,mysql指运行mysql镜像,bash指创建一个交互式shell。

使用

docker ps -a

查看已经运行的docker镜像,如下 image

docker中使用mysql数据库详解(在局域网访问)

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

使用命令

docker exec -it sick_hawking bash

连接到mysql镜像中,

docker exec

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

连接成功以后,如下,

docker中使用mysql数据库详解(在局域网访问)

图中就已经进入到了docker mysql镜像中,使用

service mysql status

查看mysql的启动状态,如下,

docker中使用mysql数据库详解(在局域网访问)

mysql没有启动可以使用

service mysql start

,如下,

docker中使用mysql数据库详解(在局域网访问)

输入mysql验证mysql是否启动成功,如下,

docker中使用mysql数据库详解(在局域网访问)

docker中使用mysql数据库详解(在局域网访问)

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

如何在外部使用root连接这个mysql?

为了安全,首先需要设置root帐号的密码,如下

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

将root的密码改为root。 接着,由于mysql中root执行绑定在了localhost,因此需要对root进行授权,代码如下,

grant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;

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

docker中使用mysql数据库详解(在局域网访问)

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

总结

以上就是这篇文章的全部内容了,希望本文的内容对给各位ios开发者们能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。