家住魔仙堡 發表於 2019-6-11 10:51:00

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

<h1>前言&nbsp;&nbsp;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;</h1>
<p>MySQL是目前最流行的开源的关系型数据库,MySQL的容器化之前有朋友投稿并且写过此块,本篇仅从笔者角度进行总结和编写。</p>
<hr>
<p>&nbsp;</p>
<h1 class="a2"><strong><span>目录</span></strong>&nbsp;&nbsp;</h1>
<ul class="list-paddingleft-2">
<li>
<p><strong>镜像说明&nbsp;</strong></p>
</li>
</ul>
<ul class="list-paddingleft-2">
<li>
<p><strong>运行MySQL容器镜像</strong><strong>&nbsp;<br></strong></p>


















</li>


















</ul>
<p style="margin-left: 60px"><strong>1.运行MySQL容器&nbsp;</strong></p>
<p style="margin-left: 60px"><strong>2.修改“root”账户的认证模式和密码&nbsp;</strong></p>
<ul class="list-paddingleft-2">
<li>
<p><strong>管理MySQL&nbsp;</strong></p>


















</li>


















</ul>
<p style="margin-left: 60px"><strong>1. MySQL命令行工具&nbsp;</strong></p>
<p style="margin-left: 60px"><strong>2. Visual Studio Code的MySQL插件&nbsp;</strong></p>
<p style="margin-left: 60px"><strong>3. phpmyadmin&nbsp;</strong></p>
<hr>
<p style="margin-left: 60px">&nbsp;</p>
<p class="a2">MySQL是目前最流行的开源的关系型数据库,因其高性能、可靠性和易用性而广受开发者的欢迎,尤其是开放源码这一特点,一般中小型网站的开发都会优先选择MySQL作为网站数据库。</p>
<p class="a2">与其他的大型数据库例如Oracle、DB2、SQL Server等相比,MySQL虽然有它的不足之处,但是这丝毫也没有减少它受欢迎的程度。对于一般的个人使用者和中小型企业来说,MySQL提供的功能已经绰绰有余,而且由于 MySQL是开放源码软件,因此可以大大降低总体拥有成本。</p>
<hr>
<p class="a2">&nbsp;</p>
<h2 class="a2">镜像说明</h2>
<p class="a2">MySQL的官方镜像地址为:https://hub.docker.com/_/mysql</p>
<p class="a">&nbsp;<img src="https://img2018.cnblogs.com/blog/70544/201906/70544-20190611103920553-1917074071.png" alt=""></p>
<hr>
<h2>运行MySQL容器镜像</h2>
<h3 class="a0">1.运行MySQL容器</h3>
<p class="a2">接下来,我们使用PowerShell来运行MySQL镜像。脚本如下所示:</p>
<div class="cnblogs_code">
<pre>docker run --<span style="color: rgba(0, 0, 0, 1)">name mysql `

</span>-e MYSQL_ROOT_PASSWORD=<span style="color: rgba(128, 0, 128, 1)">123456</span><span style="color: rgba(0, 0, 0, 1)"> `

</span>-p <span style="color: rgba(128, 0, 128, 1)">3306</span>:<span style="color: rgba(128, 0, 128, 1)">3306</span><span style="color: rgba(0, 0, 0, 1)"> `

</span>-d mysql</pre>
</div>
<p class="a2">相关参数说明如下所示:</p>
<p class="a5" style="text-align: center"><strong>表7-2</strong></p>
<table class="4-11" border="1" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td valign="top" width="236">
<p class="a1"><strong>参数</strong></p>
</td>
<td valign="top" width="317">
<p class="a1"><strong>描述</strong></p>
</td>
</tr>
<tr>
<td valign="top" width="236">
<p class="a6"><strong>-e MYSQL_ROOT_PASSWORD=123456</strong></p>
</td>
<td valign="top" width="317">
<p class="a6">此变量是必须的,用于指定MySQL超级管理员帐户(root)的密码。</p>
</td>
</tr>
<tr>
<td valign="top" width="236">
<p class="a6"><strong>-p 3306:3306</strong></p>
</td>
<td valign="top" width="317">
<p class="a6">建立容器端口和主机端口的映射。MySQL默认端口为3306。</p>
</td>
</tr>
<tr>
<td valign="top" width="236">
<p class="a6"><strong>-d</strong></p>
</td>
<td valign="top" width="317">
<p class="a6">在后台运行容器并打印容器ID。</p>
</td>
</tr>
<tr>
<td valign="top" width="236">
<p class="a6"><strong>--name mysql</strong></p>
</td>
<td valign="top" width="317">
<p class="a6">为容器指定一个自定义名称,而不是使用随机生成的名称。&nbsp;如果运行多个容器,则无法重复使用相同的名称。</p>
</td>
</tr>
<tr>
<td valign="top" width="236">
<p class="a6"><strong>mysql</strong></p>
</td>
<td valign="top" width="317">
<p class="a6">MySQL容器镜像。</p>
</td>
</tr>
</tbody>
</table>
<p class="a2">执行界面如图所示:</p>
<p class="a">&nbsp;<img src="https://img2018.cnblogs.com/blog/70544/201906/70544-20190611104051184-519060553.png" alt=""></p>
<p class="a2">同样的,我们可以参考前面的章节使用数据卷或者主机目录来完成MySQL的数据持久化,参考命令参数如下:</p>
<ul>
<li class="a2">使用数据卷“-v my-volume:/var/lib/mysql”</li>
<li class="a2">使用主机目录“-v d:\temp\data:/var/lib/mysql”</li>
</ul>
<h3 class="a0">2.修改“root”账户的认证模式和密码</h3>
<p class="a2">MySQL容器已经运行了,如果我们满怀欣喜地使用Visual Studio Code的MySQL扩展插件去连接时,就会碰到这么一个错误:</p>
<p class="a">&nbsp;<img src="https://img2018.cnblogs.com/blog/70544/201906/70544-20190611104103271-2085308246.png" alt=""></p>
<p class="a2">究其原因,其实就是MySQL新版本的“caching_sha2_password”授权认证模式的问题,我们将其改回“mysql_native_password”授权模式即可。</p>
<p class="a2">主要有以下几步操作:</p>
<p class="a2">1)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 进入MySQL容器</p>
<p class="a2">docker exec -it mysql /bin/bash</p>
<p class="a">&nbsp;<img src="https://img2018.cnblogs.com/blog/70544/201906/70544-20190611104120150-2083810874.png" alt=""></p>
<p class="a2">2)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 使用MySQL命令行工具连接MySQL</p>
<p class="a2">mysql -h localhost -u root -p</p>
<p class="a2">需要输入密码:</p>
<p class="a">&nbsp;<img src="https://img2018.cnblogs.com/blog/70544/201906/70544-20190611104149074-439785335.png" alt=""></p>
<p class="a2">3)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 修改“root”账户的认证模式</p>
<p class="a2">连接成功后,接下来我们就可以使用SQL语句来修改“root”账户的认证模式了:</p>
<p class="a2">ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';</p>
<p class="a2"><em>注意,最后的字符串“123456”为“root”账户的密码。</em></p>
<p class="a">&nbsp;<img src="https://img2018.cnblogs.com/blog/70544/201906/70544-20190611104213713-124105609.png" alt=""></p>
<p class="a2">4)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 验证外部连接</p>
<p class="a2">同样的,我们使用Visual Studio Code的MySQL扩展插件进行验证,正常情况如下所示:</p>
<p class="a">&nbsp;<img src="https://img2018.cnblogs.com/blog/70544/201906/70544-20190611104238667-628680882.png" alt=""></p>
<hr>
<p class="a">&nbsp;</p>
<h2 class="3">管理MySQL</h2>
<p class="a2">这里我们主要简单的介绍以下MySQL命令行工具和Visual Studio Code的MySQL扩展插件。</p>
<h3 class="a0">1. MySQL命令行工具</h3>
<p class="a2">进入方式在前面的章节我们已经多次讲述了,这里就不赘述了。使用MySQL命令行工具,我们可以非常方便的进行管理数据库。比如:</p>
<ul>
<li class="a2">查看数据库</li>
</ul>
<p class="a">&nbsp;<img src="https://img2018.cnblogs.com/blog/70544/201906/70544-20190611104320478-829439181.png" alt=""></p>
<ul>
<li class="a2">创建数据库</li>
</ul>
<p class="a">&nbsp;<img src="https://img2018.cnblogs.com/blog/70544/201906/70544-20190611104345604-1603366656.png" alt=""></p>
<ul>
<li class="a2">执行其他查询</li>
</ul>
<p class="a">&nbsp;<img src="https://img2018.cnblogs.com/blog/70544/201906/70544-20190611104405352-2019347103.png" alt=""></p>
<h3 class="a0">2. Visual Studio Code的MySQL插件</h3>
<p class="a2">由于大部分MySQL UI管理工具都要钱,这里就首要推荐使用万能的Visual Studio Code的MySQL的插件来进行管理。</p>
<ul>
<li class="a2">MySQL插件</li>
</ul>
<p class="a2">使用起来非常简单:</p>
<p class="a">&nbsp;<img src="https://img2018.cnblogs.com/blog/70544/201906/70544-20190611104422203-1396690087.png" alt=""></p>
<ul>
<li class="a2">SQLTools</li>
</ul>
<p class="a2">支持多种数据库(MySQL、MSSQL、PostgreSQL、Oracle、SQLite、SAP HANA),支持书签、查询语句智能提示和自动完成以及将数据导出CSV或JSON:</p>
<p class="a"><img src="https://img2018.cnblogs.com/blog/70544/201906/70544-20190611104441047-411605344.png" alt=""></p>
<h3 class="a0">3. phpmyadmin</h3>
<p class="a2">phpMyAdmin 是一个B/S架构的MySQL的数据库管理工具,让管理者可用Web接口管理MySQL数据库。我们可以使用容器来运行phpmyadmin,官方镜像地址:https://hub.docker.com/r/phpmyadmin/phpmyadmin</p>
<p class="a2">执行命令如下:</p>
<div class="cnblogs_code">
<pre>docker run --<span style="color: rgba(0, 0, 0, 1)">name myadmin `

</span>--<span style="color: rgba(0, 0, 0, 1)">link mysql:db `

</span>-e MYSQL_ROOT_PASSWORD=<span style="color: rgba(128, 0, 128, 1)">123456</span><span style="color: rgba(0, 0, 0, 1)"> `

</span>-p <span style="color: rgba(128, 0, 128, 1)">8080</span>:<span style="color: rgba(128, 0, 128, 1)">80</span><span style="color: rgba(0, 0, 0, 1)"> `

</span>-d phpmyadmin/phpmyadmin</pre>
</div>
<p class="a2">如上述命令所示,我们运行了一个phpmyadmin容器实例,其中MySQL的“root”账户密码为“123456”。运行成功后,就可以访问“http://localhost:8080/”以进入以下管理界面(登录账户和密码分别为“root”、“123456”):</p>
<p class="a"><img src="https://img2018.cnblogs.com/blog/70544/201906/70544-20190611104456024-293333886.png" alt=""></p>
<p class="a2">管理功能很强大,非常值得推荐。</p>
<p>&nbsp;</p>
<div class="ace-line gutter-noauthor text-align-type-justify pap-stylesheet-name-normal emptyGutter">
<h2><strong>往期内容链接</strong></h2>
</div>
<p class="postTitle">Docker最全教程——从理论到实战(一)</p>
<p class="postTitle">Docker最全教程——从理论到实战(二)</p>
<p class="postTitle">Docker最全教程——从理论到实战(三)</p>
<p class="postTitle">Docker最全教程——从理论到实战(四)</p>
<p class="postTitle">Docker最全教程——从理论到实战(五)</p>
<p class="postTitle">Docker最全教程——从理论到实战(六)</p>
<p class="postTitle">Docker最全教程——从理论到实战(七)</p>
<p class="postTitle">Docker最全教程——从理论到实战(八)</p>
<div class="ace-line gutter-noauthor text-align-type-justify pap-stylesheet-name-normal emptyGutter">
<p class="postTitle">Docker最全教程之使用Tencent Hub来完成CI(九)</p>
<p class="postTitle">Docker最全教程——数据库容器化(十)</p>
<p class="postTitle">Docker最全教程——数据库容器化之持久保存数据(十一)</p>
<p class="postTitle">Docker最全教程——MongoDB容器化(十二)</p>
<p class="postTitle">Docker最全教程——Redis容器化以及排行榜实战(十三)</p>
<p class="postTitle">Docker最全教程之Ubuntu下安装Docker(十四)</p>
<p class="postTitle">Docker最全教程之树莓派和Docker(十五)</p>
<p class="postTitle">Docker最全教程之使用TeamCity来完成内部CI、CD流程(十六)</p>
<p class="postTitle">Docker最全教程之使用Docker搭建Java开发环境(十七)</p>
<p class="postTitle">Docker最全教程之Go实战,墙裂推荐(十八)</p>
<p class="postTitle">Docker最全教程之使用.NET Core推送钉钉消息(十九)</p>
<p class="postTitle">Docker最全教程之使用 Visual Studio Code玩转Docker(二十)</p>
<p class="postTitle">Docker最全教程之Python爬网实战(二十一)</p>
<p class="postTitle">Docker最全教程之使用PHP搭建个人博客站点(二十二)</p>
<p class="postTitle">Docker最全教程之使用Node.js搭建团队技术文档站(二十三)</p>
</div>

</div>
<div id="MySignature" role="contentinfo">
    作者:雪雁<br>出处:http://www.cnblogs.com/codelove/
<br>如果喜欢作者的文章,请关注【CodeSpirit-码灵】公众号以便第一时间获得最新内容。本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。<br><b>静听鸟语花香,漫赏云卷云舒。</b>
<br>
<img src="https://images.cnblogs.com/cnblogs_com/codelove/315887/o_251224070213_%E5%85%AC%E4%BC%97%E5%8F%B7.jpg" width="100" height="100"><br><br>
来源:https://www.cnblogs.com/codelove/p/11002329.html
頁: [1]
查看完整版本: Docker最全教程之MySQL容器化 (二十四)