微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Docker最全教程之MySQL容器化 二十四

前言                

MysqL是目前最流行的开源的关系型数据库MysqL的容器化之前有朋友投稿并且写过此块,本篇仅从笔者角度进行总结和编写。


 

目录  

  • 镜像说明 

  • 运行MysqL容器镜像 

1.运行MysqL容器 

2.修改“root”账户的认证模式和密码 

1. MySQL命令行工具 

2. Visual Studio Code的MysqL插件 

3. PHPmyadmin 


 

MysqL是目前最流行的开源的关系型数据库,因其高性能、可靠性和易用性而广受开发者的欢迎,尤其是开放源码这一特点,一般中小型网站的开发都会优先选择MysqL作为网站数据库。

与其他的大型数据库例如Oracle、DB2、sql Server等相比,MysqL虽然有它的不足之处,但是这丝毫也没有减少它受欢迎的程度。对于一般的个人使用者和中小型企业来说,MysqL提供的功能已经绰绰有余,而且由于 MysqL是开放源码软件,因此可以大大降低总体拥有成本。


 

镜像说明

MysqL的官方镜像地址为:https://hub.docker.com/_/mysql

 


运行MysqL容器镜像

1.运行MysqL容器

接下来,我们使用PowerShell来运行MysqL镜像。脚本如下所示:

docker run --name MysqL `

-e MysqL_ROOT_PASSWORD=123456 `

-p 3306:3306 `

-d MysqL

相关参数说明如下所示:

表7-2

参数

描述

-e MysqL_ROOT_PASSWORD=123456

此变量是必须的,用于指定MysqL超级管理员帐户(root)的密码。

-p 3306:3306

建立容器端口和主机端口的映射。MysqL认端口为3306。

-d

后台运行容器并打印容器ID。

--name MysqL

为容器指定一个自定义名称,而不是使用随机生成名称。 如果运行多个容器,则无法重复使用相同的名称

MysqL

MysqL容器镜像。

执行界面如图所示:

 

同样的,我们可以参考前面的章节使用数据卷或者主机目录来完成MysqL的数据持久化,参考命令参数如下:

  • 使用数据卷“-v my-volume:/var/lib/MysqL
  • 使用主机目录“-v d:\temp\data:/var/lib/MysqL

2.修改“root”账户的认证模式和密码

MysqL容器已经运行了,如果我们满怀欣喜地使用Visual Studio Code的MysqL扩展插件去连接时,就会碰到这么一个错误

 

究其原因,其实就是MysqL新版本的“caching_sha2_password”授权认证模式的问题,我们将其改回“MysqL_native_password”授权模式即可。

主要有以下几步操作:

1)        进入MysqL容器

docker exec -it MysqL /bin/bash

 

2)        使用MySQL命令行工具连接MysqL

MysqL -h localhost -u root -p

需要输入密码:

 

3)        修改“root”账户的认证模式

连接成功后,接下来我们就可以使用sql语句来修改“root”账户的认证模式了:

ALTER USER 'root'@'%' IDENTIFIED WITH MysqL_native_password BY '123456';

注意,最后的字符串“123456”为“root”账户的密码。

 

4)        验证外部连接

同样的,我们使用Visual Studio Code的MysqL扩展插件进行验证,正常情况如下所示:

 


 

管理MysqL

这里我们主要简单的介绍以下MySQL命令行工具和Visual Studio Code的MysqL扩展插件

1. MySQL命令行工具

进入方式在前面的章节我们已经多次讲述了,这里就不赘述了。使用MySQL命令行工具,我们可以非常方便的进行管理数据库。比如:

 

 

 

2. Visual Studio Code的MysqL插件

由于大部分MysqL UI管理工具都要钱,这里就首要推荐使用万能的Visual Studio Code的MysqL插件来进行管理。

使用起来非常简单:

 

支持多种数据库MysqL、MSsql、Postgresql、Oracle、sqlite、SAP HANA),支持书签、查询语句智能提示自动完成以及将数据导出CSV或JSON:

3. PHPmyadmin

PHPMyAdmin 是一个B/S架构的MysqL数据库管理工具,让管理者可用Web接口管理MysqL数据库。我们可以使用容器来运行PHPmyadmin,官方镜像地址:https://hub.docker.com/r/phpmyadmin/phpmyadmin

执行命令如下:

docker run --name myadmin `

 --link MysqL:db `

 -e MysqL_ROOT_PASSWORD=123456 `

 -p 8080:80 `

 -d PHPmyadmin/PHPmyadmin

如上述命令所示,我们运行了一个PHPmyadmin容器实例,其中MysqL的“root”账户密码为“123456”。运行成功后,就可以访问“http://localhost:8080/”以进入以下管理界面(登录账户和密码分别为“root”、“123456”):

管理功能很强大,非常值得推荐。

 

往期内容链接

Docker最全教程——从理论到实战(一)

Docker最全教程——从理论到实战(二)

Docker最全教程——从理论到实战(三)

Docker最全教程——从理论到实战(四)

Docker最全教程——从理论到实战(五)

Docker最全教程——从理论到实战(六)

Docker最全教程——从理论到实战(七)

Docker最全教程——从理论到实战(八)

Docker最全教程之使用Tencent Hub来完成CI(九)

Docker最全教程——数据库容器化(十)

Docker最全教程——数据库容器化之持久保存数据(十一)

Docker最全教程——MongoDB容器化(十二)

Docker最全教程——Redis容器化以及排行榜实战(十三)

Docker最全教程之Ubuntu下安装Docker(十四)

Docker最全教程之树莓派和Docker(十五)

Docker最全教程之使用TeamCity来完成内部CI、CD流程(十六)

Docker最全教程之使用Docker搭建Java开发环境(十七)

Docker最全教程之Go实战,墙裂推荐(十八)

Docker最全教程之使用.NET Core推送钉钉消息(十九)

Docker最全教程之使用 Visual Studio Code玩转Docker(二十)

Docker最全教程之Python爬网实战(二十一)

Docker最全教程之使用PHP搭建个人博客站点(二十二)

Docker最全教程之使用Node.js搭建团队技术文档站(二十三)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐