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

640?wx_fmt=gif

前言                

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



目录  


  • 镜像说明 

  • 运行MySQL容器镜像 

1.运行MySQL容器 

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


  • 管理MySQL 

1. MySQL命令行工具 

2. Visual Studio Code的MySQL插件 

3. phpmyadmin 


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

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



镜像说明


MySQL的官方镜像地址为:

https://hub.docker.com/_/mysql

640



 运行MySQL容器镜像



1.运行MySQL容器

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

docker run --name mysql `	
-e MYSQL_ROOT_PASSWORD=123456 `	
-p 3306:3306 `	
-d mysql

相关参数说明如下所示:

参数

描述

-e MYSQL_ROOT_PASSWORD=123456

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

-p 3306:3306

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

-d

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

--name mysql

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

mysql

MySQL容器镜像。

执行界面如图所示:

640

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

  • 使用数据卷“-v my-volume:/var/lib/mysql”

  • 使用主机目录“-v d:\temp\data:/var/lib/mysql”



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

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

640

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

主要有以下几步操作:

1)进入MySQL容器

docker exec -it mysql /bin/bash

640

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

mysql -h localhost -u root -p

需要输入密码:

640

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

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

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

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

640

4)验证外部连接

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

640



管理MySQL


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



1. MySQL命令行工具

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

  • 查看数据库

640

  • 创建数据库

640

  • 执行其他查询

640



2. Visual Studio Code的MySQL插件

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

  • MySQL插件

使用起来非常简单:

640

  • SQLTools

支持多种数据库(MySQL、MSSQL、PostgreSQL、Oracle、SQLite、SAP HANA),支持书签、查询语句智能提示和自动完成以及将数据导出CSV或JSON:

640



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”):

640


往期内容

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

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爬网实战(二十二)

使用PHP搭建个人博客站点

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



640?wx_fmt=jpeg

640?wx_fmt=jpeg


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315585.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CF639F Bear and Chemistry(虚树,边双)

CF639F Bear and Chemistry Solution 显然题目的条件就是所有点在一个边双连通分量内。 所以我们先缩边双求出边双树。 然后对于每一个询问,对询问的点和边的端点建虚树,然后把询问的边连上跑tarjantarjantarjan求边双判断是否所有询问点在同一个边双…

Codeforces Round #694 (Div. 2) E. Strange Shuffle 交互 + 思维分块

link 题意: nnn个人围成一圈,一开始每个人都有kkk张卡片,每回合n−1n-1n−1个人会给左边⌊x2⌋\left \lfloor \frac{x}{2} \right \rfloor⌊2x​⌋,给右边⌈x2⌉\left \lceil \frac{x}{2} \right \rceil⌈2x​⌉,剩下…

Ocelot(五)- 流量限制、服务质量

作者:markjiang7m2原文地址:https://www.cnblogs.com/markjiang7m2/p/10965300.html源码地址:https://gitee.com/Sevenm2/OcelotDemo本文是我关于Ocelot系列文章的第五篇,流量限制、服务质量。Ocelot允许针对具体的服务接口进行流…

java中静态修饰符(static)的使用

static-静态 修饰属性 静态属性,也称为静态变量 类变量等 static 数据类型 属性名; 使用 静态内容独立存放在方法区 静态内容在内存中只有一份,被该类所有对象共享 普通属性所有对象在对象内容中都有一份 可以通过类名.静态属性名的方式直接访问静态属性 静态属性封装之…

ARC082F - Sandglass(思维)

ARC082 D - Sandglass Solution 这题睡觉的时候 想了挺久的。 一段时间Δt\Delta tΔt内要么是让xΔtx\Delta txΔt对XXX取minminmin,要么是让x−Δtx-\Delta tx−Δt对000取maxmaxmax。 如果没有对边界取max/minmax/minmax/min,就是一个单纯的前缀和…

Educational Codeforces Round 101 (Rated for Div. 2) D. Ceil Divisions 思维 + 根号数

传送门 题意: 给一个数组aiia_iiai​i,每次可以进行操作ax⌈axay⌉a_x\left \lceil \frac{a_x}{a_y} \right \rceilax​⌈ay​ax​​⌉,操作不能超过n5n5n5次,最终需要把数组中的数变成n−1n-1n−1个111和一个222。 思路&#x…

Ocelot(三)- 服务发现

作者:markjiang7m2原文地址:https://www.cnblogs.com/markjiang7m2/p/10907856.html源码地址:https://gitee.com/Sevenm2/OcelotDemo本文是我关于Ocelot系列文章的第三篇,主要是给大家介绍Ocelot的另一功能。与其说是给大家介绍&a…

Educational Codeforces Round 101 (Rated for Div. 2) F. Power Sockets 哈希 + 乱搞

传送门 题意: 给一个二进制串aaa,让后定义两个串相似为有至少一个相同位置相等。现在让你找一个字典序最小的长度为kkk的串使其与aaa中每个长度为kkk的字串相似。 思路: 首先我们知道所有可能的串一共有2k2^k2k,我们把aaa串全部…

LG P4198 楼房重建(线段树)

LG P4198 楼房重建 Solution 基础的线段树题,虽然我还不熟练就是了。 大概就是单点修改,求全局的极大子序列。 我们需要维护一个区间最大值aaa和极大子序列长度sss。 合并xxx的左右儿子ls,rsls,rsls,rs时,axa_xax​直接取max{als,ars}max…

P3527 [POI2011]MET-Meteors 整体二分 + 树状数组

洛谷 题意&#xff1a; 思路&#xff1a; 考虑整体二分前&#xff0c;一定要思考一下直接二分怎么做。显然对每个城市&#xff0c;当<pos<pos<pos的时候收集不够足够的陨石&#xff0c;>pos>pos>pos的时候能收集足够多陨石&#xff0c;这个时候pospospos即…

Ocelot(二)- 请求聚合与负载均衡

作者&#xff1a;markjiang7m2原文地址&#xff1a;https://www.cnblogs.com/markjiang7m2/p/10865511.html源码地址&#xff1a;https://gitee.com/Sevenm2/OcelotDemo在上一篇Ocelot的文章中&#xff0c;我已经给大家介绍了何为Ocelot以及如何简单使用它的路由功能&#xff0…

BZOJ #3064. Tyvj 1518 CPU监控(线段树,历史最值)

BZOJ #3064. Tyvj 1518 CPU监控(线段树&#xff0c;历史最值) Solution 我们考虑用线段树维护此题。 先不考虑历史最值。 大概需要维护一种特殊的懒标记(x,y)(x,y)(x,y)表示让区间内所有数ppp&#xff0c;pmax(px,y)pmax(px,y)pmax(px,y)。 对于区间加zzz&#xff0c;打一…

Codeforces Round #655 (Div. 2) B. Omkar and Last Class of Math 数学

传送门 题意&#xff1a; 找出ABnABnABn并且lcm⁡(A,B)\operatorname{lcm}(A,B)lcm(A,B)最小的AAA和BBB。 思路&#xff1a; nnn为偶数的时候答案肯定为都是n2\frac{n}{2}2n​。当nnn为奇数的时候&#xff0c;我们假设xxx为nnn的一个因子&#xff0c;那么nmodx0n \bmod x0nmo…

「分布式系统理论」系列专题

如今互联网已经成为整个社会的基础设施&#xff0c;分布式系统并不是少数大公司的专属&#xff0c;所以分布式系统理论可能是你迟早需要掌握的知识。如果你是程序员&#xff0c;相信这些文章你肯定能看懂&#xff1b;如果你不是程序员&#xff0c;相信这些能使你能更懂程序员&a…

AGC002F - Leftmost Ball(dp,组合计数)

AGC002F - Leftmost Ball Solution 设fi,jf_{i,j}fi,j​表示放iii个白球&#xff0c;确定了jjj个颜色的球的位置的方案数。 有两种转移&#xff1a; 放白球&#xff0c;fi,j−>fi1,jf_{i,j}->f_{i1,j}fi,j​−>fi1,j​放完一种颜色的球&#xff0c;fi,j−>fi,j…

Codeforces Round #655 (Div. 2) D. Omkar and Circle 思维 + 奇偶贪心

传送门 题意&#xff1a; 给一个长为nnn的数组(nnn为奇数)&#xff0c;iii与i−1i-1i−1相邻&#xff0c;111与nnn相邻&#xff0c;每次选择一个位置&#xff0c;将这个位置的值变成与它相邻的两个位置的和&#xff0c;让后将相邻位置删掉。求最终剩下一个数的时候最大值是多少…

AGC004E - Salvage Robots(dp,思维)

AGC004E - Salvage Robots Solution 怎么又双叒叕遇到和NOIP2020T4NOIP2020T4NOIP2020T4和那道CFCFCF题一样的题了啊&#xff0c;惨痛回忆QAQQAQQAQ。 大概就是把问题看成刚开始的点不动&#xff0c;整个网格图动&#xff0c;机器人向上111格等于网格整体向下111格&#xff…

SQL Server 2012如何打开2016的profiler文件

作者&#xff1a;markjiang7m2原文地址&#xff1a;https://www.cnblogs.com/markjiang7m2/p/10980191.html背景在上星期&#xff0c;公司负责support的同事接到反馈说某个项目生产环境上的某个页面加载很慢&#xff0c;一般遇到这种问题&#xff0c;我们的support同事都会先上…

Codeforces Round #655 (Div. 2) E. Omkar and Last Floor 区间dp + 巧妙的状态设计

传送门 题意&#xff1a; 思路&#xff1a; 按照贪心的思路来考虑的话&#xff0c;显然是每一列111的个数越多越好&#xff0c;所以我们能放到一列就放到一列。设f[l][r]f[l][r]f[l][r]为在[l,r][l,r][l,r]内&#xff0c;区间全部都在里面的贡献。显然这个贡献就是全部落在[l…

AKS使用Azure File实现动态持久化存储

本文作者|搪瓷小娃娃本文来源|搪瓷小娃娃博客园如我们所知&#xff0c;Kubernetes通过 Volume 为集群中的容器提供存储&#xff0c;通过Persistent Volume 和 Persistent Volume Claim实现Volume 的静态供给和动态供给。Azure File和Azure Disk 也在Kubernetes 支持的动态供给 …