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

前言                

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


 

目录  

  • 镜像说明 html

  • 运行MySQL容器镜像 
    mysql

1.运行MySQL容器 sql

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

  • 管理MySQL 数据库

1. MySQL命令行工具 bash

2. Visual Studio Code的MySQL插件 架构

3. phpmyadmin 工具


 

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

与其余的大型数据库例如Oracle、DB二、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插件

使用起来很是简单:

 

  • SQLTools

支持多种数据库(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最全教程——从理论到实战(八)

原文出处:https://www.cnblogs.com/codelove/p/11002329.html

相关文章
相关标签/搜索