当前位置: 首页 > news >正文

Docker 技术系列之安装多版本Mysql5.6和Mysql5.7

image

大家好,后面的就不是关于MAC专有的内容,基本是跟Java环境,基础技术方面有关。所以这个教程对于在linux系统还是macOS都是通用的,不用担心。

上一篇,我们安装好对应的Docker之后,感受到了它的便利。接下来我们来安装Mysql吧,它在开发中经常需要用到。

MySQL 是世界上最受欢迎的开源数据库。凭借其可靠性、易用性和性能,MySQL 已成为 Web 应用程序的数据库优先选择。

说个痛点,如果是在windows,不可想像,你要安装不同版本的mysql进行测试,而且不想让他们版本之间有什么交集。比如说,公司用着稳定版本的5.6,但是目前市面上比较新的课程都采用mysql5.7 进行教学,想尝尝鲜。这安装简直是一个噩梦,有了docker,轻松就能解决这个问题,端口和配置也不会冲突。

image

如果是centos安装还好点,如果是通过源码编译安装还是得折腾一会的。所以接下来,我们一起通过docker来安装mysql。

一、查看可用的 MySQL 版本

方式一:网页端访问 MySQL 镜像库地址:

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

方式二:我们还可以用命令来查看可用版本。

 docker search mysql

看看效果图:

image

二、官网获取 MySQL 镜像

以下版本供您选择

# 拉取 mysql 5.7docker pull mysql:5.7# 拉取最新版mysql镜像,如果不写后面的版本号则会自动拉取最新版docker pull mysql

这里以5.7版本为例。

docker pull mysql:5.7

第一次拉去,会比较久一点,需要去下载对应的镜像。

三、查看本地镜像

使用以下命令来查看是否已安装了 mysql

docker images

四、运行Mysql容器

安装完成后,我们可以使用以下命令来运行 mysql 容器:

  • 1、创建挂载目录

创建挂载目录,主要是方便修改配置文件达到方便控制的目的。

mkdir -p $HOME/docker/mysql57

是为了方便管理建的目录,主要是表示docker项目下放置的一些配置文件。mysql57表示应用名字

cd $HOME/docker/mysql57
  • 2、运行Mysql容器

方式一:不需要挂载目录(不推荐)

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

方式二:需要挂载目录(推荐)

docker run -p 3306:3306 --name mysql57 \ 
-v $PWD/conf:/etc/mysql \
-v $PWD/logs:/var/log/mysql \
-v $PWD/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql:5.7 \
--character-set-server=utf8mb4 \
--collation-server=utf8mb4_unicode_ci

参数说明

  • –name:容器名,此处命名为mysql57
  • -v :挂载目录
  • -e:配置信息,此处配置mysql的root用户的登陆密码
  • -p:端口映射,此处映射 主机3306端口 到 容器的3306端口
  • -d:源镜像名,此处为 mysql:5.7并后台运行 后面为设置mysql的默认编码

3、选项执行,如果不需要mysql56,可以不需要执行。

image

创建目录

mkdir -p $HOME/docker/mysql56

进去该目录

cd $HOME/docker/mysql56

拉取镜像

docker pull mysql:5.6

mysql5.6 安装

docker run -p 3307:3306 --name mysql56 \
-v $PWD/conf:/etc/mysql \
-v $PWD/logs:/var/log/mysql \
-v $PWD/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql:5.6 \--character-set-server=utf8mb4 \
--collation-server=utf8mb4_unicode_ci

可能会遇到的问题,如果一开始没有执行拉取镜像的命令,会自动拉取镜像,然后默认已经创建了一个镜像mysql56,我们通过命令查找回来,然后启动即可。

查看所有容器

docker ps -a

删除容器

docker rm 容器id

启动容器

docker start 容器id

额外提供俩个快速命令

# 停止所有容器docker stop $(docker ps -a -q)# remove删除所有容器$ docker rm $(docker ps -a -q)

五、安装成功

通过 docker ps 命令查看是否安装成功。

docker ps -a

容器状态的Up状态,表示容器正在运行,并且可以看到主机和容器的端口映射关系。

重启mysql容器

docker restart mysql57

查看mysql日志

docker logs -f mysql57

六、Mysql 测试

进入到mysql容器

docker exec -ti mysql57 /bin/bash

参数说明

  • -t 在容器里生产一个伪终端
  • -i 对容器内的标准输入 (STDIN) 进行交互

登陆到mysql服务器

方式一

mysql -h 127.0.0.1 -u root -p

方式二

mysql -u root -p123456

查询测试语句

use mysql;SELECT VERSION(), CURRENT_DATE;

如果需要远程登录的,需要执行授权命令 1、直接让root也可以远程登陆(不建议)

GRANT ALL PRIVILEGES ON *.* TO root@"%" IDENTIFIED BY '123456' WITH GRANT OPTION;

2、创建一个用户admin远程登陆(建议)

GRANT ALL PRIVILEGES ON *.* TO admin@"%" IDENTIFIED BY '123456' WITH GRANT OPTION;

3、刷新权限

FLUSH PRIVILEGES;

4、查看用户

select host,user from user;

5、备份数据

$ docker exec mysql57 sh -c 'exec mysqldump --all-databases -uroot -p"123456"' > /some/path/on/your/host/all-databases.sql

6、恢复数据

$ docker exec -i mysql57 sh -c 'exec mysql -uroot -p"123456"' < /some/path/on/your/host/all-databases.sql

七、其他配置

  • 1、only_full_group_by 问题

如果安装的版本是 5.7版本, 查询数据时出现如下错误

this is incompatible with sql_mode=only_full_group_by

可以使用使用下列方式解决

  • 2、查询 sql_mode
select @@sql_mode

结果如下

ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
  • 3、重置

删除其中的 ONLY_FULL_GROUP_BY配置,重新设置到 config-file.cnf中

[mysqld]# 表名不区分大小写lower_case_table_names=1#server-id=1datadir=/var/lib/mysql#socket=/var/lib/mysql/mysqlx.sock#symbolic-links=0sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION[mysqld_safe]log-error=/var/log/mysqld.logpid-file=/var/run/mysqld/mysqld.pid

涉及比较深的部分,如果有机会更新mysql方面的教程,再讲讲。

总结

1、一句命令即可完成mysql的安装,方便快捷。

2、多实例,不同端口相互之间不影响。

推荐阅读

Docker 技术系列之安装Docker Desktop for Mac

最后编辑于:2024-12-10 21:55:11


喜欢的朋友记得点赞、收藏、关注哦!!!

相关文章:

Docker 技术系列之安装多版本Mysql5.6和Mysql5.7

image 大家好&#xff0c;后面的就不是关于MAC专有的内容&#xff0c;基本是跟Java环境&#xff0c;基础技术方面有关。所以这个教程对于在linux系统还是macOS都是通用的&#xff0c;不用担心。 上一篇&#xff0c;我们安装好对应的Docker之后&#xff0c;感受到了它的便利。接…...

理解并使用Linux 内核中的 Tracepoint

理解并使用Linux 内核中的 Tracepoint 1. 引言 1.1 为什么需要 Tracepoint&#xff1f; 在内核调试与性能分析中&#xff0c;传统的 printk 方法虽然简单直接&#xff0c;但存在几个显著的局限性&#xff1a; 日志噪音&#xff1a;printk 会将所有输出无差别地记录到系统日…...

centos7中Gbase8s数据库安装,以及数据导入遇到的一系列问题

centos7中Gbase8s数据库安装&#xff0c;以及遇到的一系列问题 以下是我在centos7上安装gbase8s数据库遇到的一系列问题&#xff0c;包括数据库安装&#xff0c;数据导入&#xff0c;数据连接&#xff0c;不能完全作为标准&#xff0c;只可作为类似问题参考&#xff0c;有问题…...

AW36518芯片手册解读(3)

接前一篇文章&#xff1a;AW36518芯片手册解读&#xff08;2&#xff09; 二、详述 3. 功能描述 &#xff08;1&#xff09;上电复位 当电源电压VIN降至预定义电压VPOR&#xff08;典型值为2.0V&#xff09;以下时&#xff0c;该设备会产生复位信号以执行上电复位操作&#x…...

MySQL的REPEATABLE READ事务隔离级别

本文隔离级别&#xff1a; T1内读T2的update数据 首先开两个事务&#xff08;左二&#xff09; 事务1修改成李四,提交 事务2再读还是张三&#xff0c;也就是说&#xff0c;记录的数据从事务开始时一直到结束&#xff0c;读的都是同一个版本,读不到T2未提交的此条记录修改&…...

sqoop的参数有哪些?

Sqoop 是一款用于在 Hadoop 与关系型数据库之间进行数据传输的工具&#xff0c;它有很多参数&#xff0c;可分为通用参数、导入参数和导出参数等&#xff0c;以下是一些常见的参数介绍&#xff1a; 通用参数 --connect 说明&#xff1a;指定要连接的关系型数据库的 JDBC URL。…...

动态规划<四> 回文串问题(含对应LeetcodeOJ题)

目录 引例 其余经典OJ题 1.第一题 2.第二题 3.第三题 4.第四题 5.第五题 引例 OJ 传送门Leetcode<647>回文子串 画图分析&#xff1a; 使用动态规划解决 原理&#xff1a;能够将所有子串是否是回文的信息保存在dp表中 在使用暴力方法枚举出所有子串&#xff0c;是…...

跨模态知识迁移:基于预训练语言模型的时序数据建模

在NLP和CV领域&#xff0c;通常通过在统一的预训练模型上进行微调&#xff0c;能够在各自领域的下游任务中实现SOTA&#xff08;最先进&#xff09;的结果。然而&#xff0c;在时序预测领域&#xff0c;由于数据量相对较少&#xff0c;难以训练出一个统一的预训练模型来覆盖所有…...

重温设计模式--职责链模式

文章目录 职责链模式的详细介绍C 代码示例C示例代码2 职责链模式的详细介绍 定义与概念 职责链模式&#xff08;Chain of Responsibility Pattern&#xff09;是一种行为型设计模式&#xff0c;它旨在将请求的发送者和多个接收者解耦&#xff0c;让多个对象都有机会处理请求&a…...

git冲突解决

git冲突解决 最近遇到了一次git冲突的问题 起因是因为最近公司数据推送部分重构&#xff0c;负责重构的同事就改动了我的一小部分推送的代码&#xff0c;然后等我开发完合并到远程master的时候&#xff0c;报了merge冲突。我对于git工具确实不是很熟练&#xff0c;只是学习了…...

Java学习笔记(14)--面向对象编程

面向对象基础 学习资料来自多态 - Java教程 - 廖雪峰的官方网站 目录 面向对象基础 Override 多态 举个例子 覆写Object方法 调用super final 练习 小结 Override 在继承关系中&#xff0c;子类如果定义了一个与父类方法签名完全相同的方法&#xff0c;被称为覆写&…...

《Swift 字面量》

《Swift 字面量》 介绍 在 Swift 编程语言中&#xff0c;字面量是一种表示源代码中固定值的表达方式。字面量可以直接表示数字、字符串、布尔值等基本数据类型&#xff0c;为编程提供了简洁和直观的方式。Swift 支持多种类型的字面量&#xff0c;包括整数字面量、浮点数字面量…...

数据库 SQL 常用语句全解析

数据库 SQL 常用语句全解析 在数据库领域&#xff0c;SQL&#xff08;Structured Query Language&#xff09;作为标准语言&#xff0c;掌控着数据的查询、插入、更新与删除等关键操作。无论是新手入门数据库&#xff0c;还是经验丰富的开发者日常工作&#xff0c;熟练掌握 SQ…...

SQLite 命令

关于《SQLite 命令》的文章&#xff0c;我可以为您概述一些关键点。SQLite是一个轻量级的数据库管理系统&#xff0c;它被广泛用于各种应用程序中。SQLite命令主要分为两类&#xff1a;一类是SQL命令&#xff0c;另一类是SQLite特定的点命令。 SQL命令&#xff1a;这些命令用于…...

本地如何启动casdoor

1、下载代码 GitHub - casdoor/casdoor at v1.777.0 下载对应tag的代码&#xff0c;我这里选择的时v1.777.0版本 通过网盘分享的文件&#xff1a;casdoor-1.777.0.zip 链接: https://pan.baidu.com/s/1fPNqyJYeyfZnem_LtEc0hw 提取码: avpd 2、启动后端 1、使用goland编译…...

目标检测-R-CNN

R-CNN在2014年被提出&#xff0c;算法流程可以概括如下&#xff1a; 候选区域生成&#xff1a;利用选择性搜索(selective search)方法找出图片中可能存在目标的候选区域(region proposal) CNN网络提取特征&#xff1a;对候选区域进行特征提取(可以使用AlexNet、VGG等网络) 目…...

【持续更新】Github实用命令

Intro 最近高强度使用github&#xff0c;遂小计于此作为备忘。 Basic github是一个代码管理软件&#xff0c;能够track文件变动并且管理版本&#xff0c;是当代coding必不可少的工具。当你安装好github在本地以后&#xff0c;你可以通过以下命令初始化当前文件夹&#xff08…...

docker 容器的基本使用

docker 容器 一、docker是什么&#xff1f; 软件的打包技术&#xff0c;就是将算乱的多个文件打包为一个整体&#xff0c;打包技术在没有docker容器之前&#xff0c;一直是有这种需求的&#xff0c;比如上节课我把我安装的虚拟机给你们打包了&#xff0c;前面的这种打包方式是…...

css让按钮放在最右侧

要将 el-button 按钮放在最右侧&#xff0c;可以使用多种方法&#xff0c;具体取决于使用的布局方式和样式库。以下是几种常见的解决方案&#xff1a; 方法 1&#xff1a;使用 CSS Flexbox Flexbox 是一种非常灵活的布局方式&#xff0c;可以轻松实现水平或垂直对齐。你可以将…...

8K+Red+Raw+ProRes422分享5个影视级视频素材网站

Hello&#xff0c;大家好&#xff0c;我是后期圈&#xff01; 在视频创作中&#xff0c;电影级的视频素材能够为作品增添专业质感&#xff0c;让画面更具冲击力。无论是广告、电影短片&#xff0c;还是品牌宣传&#xff0c;高质量的视频素材都是不可或缺的资源。然而&#xff…...

建议大家都去油管学ai agent真的能打破信息差

① Jeff su 视频节奏快、内容直给&#xff0c;特别适合普通人想用AI做点实际事儿的&#xff0c;比较入门和实用&#xff1b;比如他用8分钟说清楚怎么写好prompt、怎么用AI agent&#xff0c;讲得清楚又好跟&#xff0c;新手照做就能上手。 ② Andrej Karpathy 大神本神&…...

MySQL分区实战指南:从原理到落地的完整攻略

作为一名长期深耕后端开发的工程师&#xff0c;相信很多同学都遇到过这样的痛点&#xff1a;随着业务增长&#xff0c;单表数据量突破千万甚至亿级后&#xff0c;即使加了索引&#xff0c;查询依然卡顿&#xff1b;定期清理历史数据时&#xff0c;delete 语句执行几小时还会导致…...

ZTE ONU工厂模式解锁:3个关键步骤告别运维困境

ZTE ONU工厂模式解锁&#xff1a;3个关键步骤告别运维困境 【免费下载链接】zteOnu A tool that can open ZTE onu device factory mode 项目地址: https://gitcode.com/gh_mirrors/zt/zteOnu zteOnu是一款专为网络运维工程师设计的专业工具&#xff0c;能够快速解锁ZTE…...

Xinference-v1.17.1应用案例:快速部署LSTM,实现智能金融预测

Xinference-v1.17.1应用案例&#xff1a;快速部署LSTM&#xff0c;实现智能金融预测 1. 金融预测与Xinference的完美结合 在金融数据分析领域&#xff0c;时间序列预测一直是个重要课题。无论是股票价格预测、交易量分析还是风险评估&#xff0c;都需要对历史数据进行建模&am…...

文生图模型Z-Image:低配电脑也能玩的AI绘画工具

文生图模型Z-Image&#xff1a;低配电脑也能玩的AI绘画工具 1. 项目介绍 1.1 什么是Z-Image-GGUF&#xff1f; Z-Image-GGUF是一个基于阿里巴巴通义实验室Z-Image模型的文生图AI工具。它最大的特点是通过GGUF量化技术&#xff0c;大幅降低了硬件要求&#xff0c;让普通配置的…...

终极加速方案:Surge与Core ML集成指南,让机器学习推理性能提升300%

终极加速方案&#xff1a;Surge与Core ML集成指南&#xff0c;让机器学习推理性能提升300% 在当今AI应用爆炸式增长的时代&#xff0c;机器学习模型推理速度已成为决定用户体验的关键因素。如果你正在为iOS或macOS应用开发机器学习功能&#xff0c;那么Surge这个基于Accelerat…...

D3KeyHelper完全指南:暗黑3图形化宏工具实战配置与效率优化

D3KeyHelper完全指南&#xff1a;暗黑3图形化宏工具实战配置与效率优化 【免费下载链接】D3keyHelper D3KeyHelper是一个有图形界面&#xff0c;可自定义配置的暗黑3鼠标宏工具。 项目地址: https://gitcode.com/gh_mirrors/d3/D3keyHelper D3KeyHelper是一款专为《暗黑…...

告别SQL拼接!鸿蒙HarmonyOS RdbPredicates实战:从增删改查到动态查询,一篇搞定

鸿蒙HarmonyOS RdbPredicates深度实战&#xff1a;构建安全高效的数据库查询体系 在移动应用开发领域&#xff0c;数据持久化一直是核心需求之一。传统Android开发中&#xff0c;我们习惯了直接编写SQL语句进行数据库操作&#xff0c;但这种做法往往伴随着字符串拼接的安全隐患…...

代码即提示词,测试即推理验证:AI原生研发流水线落地手册(附GitHub千星开源工具链清单)

第一章&#xff1a;从传统开发到AI原生&#xff1a;软件研发范式革命 2026奇点智能技术大会(https://ml-summit.org) 软件研发正经历一场静默却深刻的范式迁移——从以人类编码为中心、面向确定性逻辑的工程实践&#xff0c;转向以提示驱动、模型协同、反馈闭环为特征的AI原生…...

探索【脑机接口 × 人工智能】的融合实践与避坑指南

1. 脑机接口与人工智能的融合基础 第一次接触脑机接口技术是在2015年的一个神经科学实验室。当时看到研究人员通过电极帽捕捉到的脑电信号控制机械臂抓取咖啡杯时&#xff0c;那种震撼感至今难忘。如今&#xff0c;随着深度学习技术的爆发式发展&#xff0c;脑机接口人工智能的…...