使用Docker安装MySQL5.7.36

拉取镜像并查看

docker pull mysql:5.7.36

拉取成功后查看(非必须)

docker images

在这里插入图片描述

创建并设置宿主机 mysql 配置文件目录和数据文件目录

创建相关文件夹将容器中的mysql数据保存到本地,这样即使容器被删除,数据也不会丢失。

mkdir -p  /opt/soft/mysql/5.7.36/data   /opt/soft/mysql/5.7.36/conf   /opt/soft/mysql/5.7.36/logs

创建实例并启动

docker run -p 13306:3306 --name mysql5.7.36 \
-v /opt/soft/mysql/5.7.36/logs:/var/log/mysql \
-v /opt/soft/mysql/5.7.36/data:/var/lib/mysql \
-v /opt/soft/mysql/5.7.36/conf:/etc/mysql \
-v /etc/localtime:/etc/localtime:ro \
-e MYSQL_ROOT_PASSWORD=root \
-d mysql:5.7.36

这个Docker命令是用来启动一个基于MySQL 5.7.36版本的容器,并进行一些定制化的配置。下面是对这条命令中各个部分的详细解释:

- docker run: 命令用来创建一个新的容器并运行一个命令。
- p 13306:3306: 这个选项映射容器内部的3306端口到主机的13306端口,允许外部通过主机的13306端口访问容器中的MySQL服务。
-name mysql5.7.36: 为这个容器指定一个名字,这里是mysql5.7.36,便于后续管理和识别。
- v /opt/soft/mysql/5.7.36/logs:/var/log/mysql: 将主机上的/opt/soft/mysql/5.7.36/logs目录挂载到容器内的/var/log/mysql,用于存放MySQL的日志文件。这样做的好处是即使容器被删除,日志也不会丢失。
- v /opt/soft/mysql/5.7.36/data:/var/lib/mysql: 类似地,将主机的/opt/soft/mysql/5.7.36/data目录挂载到容器的/var/lib/mysql,这是MySQL的数据存储目录。挂载数据卷可以持久化数据,保证数据不因容器重启或删除而丢失。
- v /opt/soft/mysql/5.7.36/conf:/etc/mysql: 将主机的/opt/soft/mysql/5.7.36/conf目录挂载到容器的/etc/mysql,允许使用自定义的MySQL配置文件,而不是容器默认的配置。
- v /etc/localtime:/etc/localtime:ro: 将主机的系统时间文件挂载到容器中,确保容器内的时间与主机同步,并且以只读模式挂载(ro),防止容器内部修改主机的时间设置。
- e MYSQL_ROOT_PASSWORD=root: 设置环境变量MYSQL_ROOT_PASSWORD,用于指定MySQL的root用户的密码。在这个例子中,密码被设置为root。请根据实际情况修改为强密码以确保安全。
- d mysql:5.7.36: 最后一部分指定了要运行的镜像名称和标签,这里是mysql:5.7.36,即MySQL 5.7.36版本的官方镜像,并且使用d参数让容器在后台运行。

综上所述,这条命令会创建并启动一个MySQL 5.7.36的容器,配置了日志、数据、配置文件的持久化存储,以及时间同步,并设置了root用户的密码。
在这里插入图片描述

添加宿主机配置文件

vim /opt/soft/mysql/5.7.36/conf/my.cnf
[client]
# 设置客户端默认字符集
default-character-set=utf8mb4

[mysql]
default-character-set=utf8mb4

[mysqld]
# 设置最大连接数
max_connections = 500
# 字符集和排序规则  
character-set-server = utf8mb4  
collation-server = utf8mb4_unicode_ci  
# 设置服务器的时区
default-time-zone = '+08:00'
# 设置是否允许MySQL对表名大小写敏感(1为不敏感)
lower_case_table_names = 1

重启MySQL服务并验证配置是否生效

宿主机执行命令

docker restart mysql5.7.36

启动后连接数据库,查询一下修改的配置是否生效,例如

mysql> SHOW VARIABLES LIKE 'max_connections';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| max_connections | 500   |
+-----------------+-------+

至此,使用Docker安装MySQL5.7.36已经完成,如果还需要修改相关配置,继续修改my.cnf,并重启即可。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

销量?模糊销量?精准销量?如何获取淘宝商品销量数据接口

淘宝爬虫商品销量数据采集通常涉及以下几个步骤: 1、确定采集目标:需要明确要采集的商品类别、筛选条件(如天猫、价格区间)、销量和金额等数据。例如,如果您想了解“小鱼零食”的销量和金额,您需要设定好价…

解决3D模型只显示线框材质的方法---模大狮模型网

在3D建模和渲染过程中,正确的材质和纹理是呈现逼真效果的关键。然而,有时候用户可能会遇到一个常见问题,即3D模型在渲染或查看时只显示线框材质,而没有正确的表面纹理和颜色。本文将介绍解决这一问题的几种方法,帮助用…

一文了解CRM系统帮助中心:从认识到搭建

客户关系管理(CRM)系统是企业的一个重要部分。而CRM系统帮助中心为用户提供了便捷的支持服务,提升了用户体验,减少了企业运营成本。本文将从认识到搭建,带你全面了解CRM系统帮助中心。 一、认识CRM系统帮助中心 CRM系统…

网络安全与IP地址的关联

网络安全与IP地址之间存在着密不可分的关系。IP地址作为网络通信的基础,对于网络安全的保障具有至关重要的作用。以下将详细探讨网络安全与IP地址之间的关联,以及IP地址在网络安全中的应用。 一、IP地址与网络安全的关系 IP地址是网络通信的基础&#x…

Facebook之道:探索社交媒体领域的未来

随着科技的不断发展,社交媒体已经成为我们日常生活中不可或缺的一部分。而在这个领域中,Facebook一直是引领者和领头羊。然而,随着时间的推移,社交媒体领域正在发生着翻天覆地的变化,而Facebook又将何去何从&#xff1…

使用 OpenCV 创建视频(74)

返回:OpenCV系列文章目录(持续更新中......) 上一篇:OpenCV 库来捕获和处理视频输入和相似度测量(73) 下一篇 :OpenCV系列文章目录(持续更新中......) 目标 每当您使用视频源时,您最终可能希望将图像处理结果保存为…

【go从入门到精通】go命令使用

作者简介: 高科,先后在 IBM PlatformComputing从事网格计算,淘米网,网易从事游戏服务器开发,拥有丰富的C++,go等语言开发经验,mysql,mongo,redis等数据库,设计模式和网络库开发经验,对战棋类,回合制,moba类页游,手游有丰富的架构设计和开发经验。 (谢谢…

矩阵相关运算1

矩阵运算是线性代数中的一个核心部分,它包含了许多不同类型的操作,可以应用于各种科学和工程问题中。 矩阵加法和减法 矩阵加法和减法需要两个矩阵具有相同的维度。操作是逐元素进行的: CAB or CA−B其中 A,B 和 C 是矩阵,且 C…

第12章 软件测试基础(第三部分)测试类型、测试工具

七、测试类型(按工程阶段划分) 单集系确收 (一)单元测试 1、单元测试/模块测试 单元就是软件中最小单位(或模块)。可以是一个函数、一个过程、一个类。主要依据是模块的详细设计文档。价值在于尽早发现…

2024年全域电商矩阵109节线上课

《24年全域电商矩阵109节线上课》是一门全面介绍电子商务领域的课程。从电子商务的基本概念到全球电子商务趋势,再到电子商务的营销策略和实际操作技巧,本课程涵盖了丰富多样的主题。学员将通过109节在线课程系统全面了解电子商务,并获得在这…

如何安全可控地进行内外网跨网络传输文件?

跨网络传输文件通常指的是在不同的网络环境之间移动数据,这在现代企业运营中非常常见。随着网络技术的高速发展,为了有效地保护内部的核心数据资产,企业一般会采用内外网隔离的策略。在进行内外网跨网络传输文件时,需要考虑多种因…

全国各地区劳动力流动、外出务工劳动力数、总劳动力数(2006-2021年)

01、数据简介 劳动力流动是指劳动力在不同地区、行业、职业、岗位之间的流动。它是劳动力市场运行的重要特征,也是实现劳动力资源优化配置的必要条件。劳动力流动可以促进劳动力资源的优化配置,提高劳动生产率和经济效益。据名称:全国各地区…

初始C++(一)

目录 前言: 命名空间: 总结: 前言: C语言学好了,现在当然要进阶了,那么就是从C开始。 C兼容C,支持其中90%的语法。可能有很多同学听说过C#,C#和C没有关系,是微软研究出…

SD-WAN对云服务的优化

在云服务日益普及的当下,SD-WAN技术正成为众多企业优化网络连接的首选方案。其通过优化云集成和连接,以及增强应用程序性能,为企业带来了前所未有的业务效益。这种革新性的云连接方式极大地促进了企业对全球劳动力和潜在客户的触达能力。 软件…

Java中Maven的依赖管理

依赖介绍 是指当前项目运行所需要的jar包&#xff0c;一个项目中可以引入多个依赖 配置 在pom.xml中编写<dependencies>标签 在<dependencies>中使用<dependency>引入标签 定义坐标的groupId、rtifactId、version 点击刷新按钮、引入新坐标 例如引入下…

git bash各分支修改内容不同但合并后不显示冲突问题

在跟着廖雪峰老师的git学习时&#xff0c;按部就班的执行明后&#xff0c;发现 而不是出现原文的结果 解决方法&#xff1a; 切换位feature分支&#xff0c;再合并 git switch feature1 git merge master 此时我们发现&#xff1a; 后面再跟着原文敲就可以了

【spark RDD】spark 之 Kryo高性能序列化框架

文章目录 一. RDD序列化的原因二. Kryo序列化框架三. spark 配置 kryo 序列化1. 设定kryo序列化2. 注册序列化类&#xff08;非必须&#xff0c;但是强烈建议做&#xff09;3. 配置 spark.kryoserializer.buffer 一. RDD序列化的原因 Spark初始化工作是在Driver端进行的&#…

机器人系统ros2-开发实践07-将机器人的状态广播到 tf2(Python)

上个教程将静态坐标系广播到 tf2&#xff0c;基于这个基础原理这个教程将演示机器人的点位状态发布到tf2 1. 写入广播节点 我们首先创建源文件。转到learning_tf2_py我们在上一教程中创建的包。在src/learning_tf2_py/learning_tf2_py目录中输入以下命令来下载示例广播示例代码…

【机器学习与实现】线性回归示例——波士顿房价分析

目录 一、创建Pandas对象并查看数据的基本情况二、使用皮尔逊相关系数分析特征之间的相关性三、可视化不同特征与因变量MEDV&#xff08;房价中值&#xff09;间的相关性四、划分训练集和测试集并进行回归分析 一、创建Pandas对象并查看数据的基本情况 boston.csv数据集下载&a…

Grotesque系列靶机Grotesque1

第一步信息收集&#xff1a; 靶机ip&#xff1a;192.168.108.131 攻击机IP&#xff1a;192.168.108.128 nmap扫描靶机的可用端口&#xff1a; 发现http服务的端口存在66端口和80端口 扫描一下靶机端口的http服务&#xff1a; 可以看到&#xff0c;默认的80端口是不存在的&am…