【Mysql系列】从零开始学MySQL:Docker部署快速上手

news2024/11/24 15:29:02

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。
img

  • 推荐:kwan 的首页,持续学习,不断总结,共同进步,活到老学到老
  • 导航
    • 檀越剑指大厂系列:全面总结 java 核心技术点,如集合,jvm,并发编程 redis,kafka,Spring,微服务,Netty 等
    • 常用开发工具系列:罗列常用的开发工具,如 IDEA,Mac,Alfred,electerm,Git,typora,apifox 等
    • 数据库系列:详细总结了常用数据库 mysql 技术点,以及工作中遇到的 mysql 问题等
    • 懒人运维系列:总结好用的命令,解放双手不香吗?能用一个命令完成绝不用两个操作
    • 数据结构与算法系列:总结数据结构和算法,不同类型针对性训练,提升编程思维,剑指大厂

非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。💝💝💝 ✨✨ 欢迎订阅本专栏 ✨✨

博客目录

    • 一.简单介绍
      • 1.docker 安装 mysql 优点
      • 2.docker 安装 mysql 缺点
    • 二.安装步骤
      • 1.查询镜像
      • 2.下载镜像
      • 3.启动容器
      • 4.查看容器
    • 三.自定义配置
      • 1.进入容器
      • 2.进入 mysql 目录
      • 3.新增配置文件
      • 4.重启容器
      • 5.自动启动 mysql
      • 6.重启容器
    • 四.授权远程访问
      • 1.进入容器
      • 2.连接 mysql
      • 3.选定库
      • 4.查看用户的连接权限
      • 5.修改 root 用户的连接权限
      • 6.退出 mysql
      • 7.退出容器
      • 8.验证

一.简单介绍

1.docker 安装 mysql 优点

使用 Docker 安装 MySQL 具有一些优点和一些潜在的缺点,下面我会列出它们:

优点:

  1. 隔离性: Docker 容器提供了隔离的环境,可以防止 MySQL 与主机系统或其他应用程序之间发生冲突。这可以防止由于不同版本的库或依赖关系引起的问题。

  2. 便携性: 使用 Docker 安装 MySQL 可以轻松迁移、复制和共享数据库环境。容器可以在不同的环境中运行,而不受主机操作系统的差异影响。

  3. 快速部署: Docker 容器可以快速部署,减少了配置和设置的时间。这使得快速创建和销毁测试环境非常容易。

  4. 版本管理: 您可以使用 Docker 来管理不同版本的 MySQL。这对于测试、升级和回滚非常有用。

  5. 可伸缩性: Docker 容器可以更容易地进行扩展,以满足应用程序的需求,通过简单的复制容器并加入容器编排工具如 Docker Compose 或 Kubernetes 来实现。

  6. 社区支持: Docker 和 MySQL 都有强大的社区支持,您可以轻松地找到相关问题的解决方案和教程。

2.docker 安装 mysql 缺点

缺点:

  1. 性能: Docker 容器引入了一定的性能开销,尤其是在 I/O 密集型应用程序中。这可能会影响 MySQL 的性能。

  2. 复杂性: Docker 容器的设置和管理可能会更加复杂,特别是在需要复杂网络配置或数据卷挂载时。这可能需要更多的学习和配置。

  3. 安全性: Docker 容器的安全性需要谨慎处理,确保适当的安全配置。不正确的配置可能会导致安全漏洞。

  4. 资源占用: Docker 容器需要额外的资源(CPU、内存等)来运行。如果主机系统资源有限,可能会导致资源争夺问题。

  5. 数据管理: 数据持久性是一个挑战,因为容器本质上是短暂的。您需要考虑如何处理数据的备份、恢复和持久性。

Docker 安装 MySQL 是一种强大的方法,尤其适用于开发、测试和短期部署。然而,它可能不适用于所有生产环境,特别是在需要高性能、高可用性和数据持久性的情况下。在选择是否使用 Docker 安装 MySQL 时,需要权衡这些优点和缺点,并根据具体的用例和需求来决定。

二.安装步骤

1.查询镜像

docker search mysql

2.下载镜像

# 拉取镜像
docker pull mysql

# 或者
docker pull mysql:latest

#查看下载的镜像
docker images

3.启动容器

docker run -p 3306:3306 --name mysql --restart=always --privileged=true \
-v /usr/local/mysql/log:/var/log/mysql \
-v /usr/local/mysql/data:/var/lib/mysql \
-v /usr/local/mysql/conf:/etc/mysql \
-v /etc/localtime:/etc/localtime:ro \
-e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest
  • -p 3306:3306:指定宿主机端口与容器端口映射关系
  • –name mysql:创建的容器名称
  • –restart=always:总是跟随 docker 启动
  • –privileged=true:获取宿主机 root 权限
  • -v /usr/local/mysql/log:/var/log/mysql:映射日志目录,宿主机:容器
  • -v /usr/local/mysql/data:/var/lib/mysql:映射数据目录,宿主机:容器
  • -v /usr/local/mysql/conf:/etc/mysql:映射配置目录,宿主机:容器
  • -v /etc/localtime:/etc/localtime:ro:让容器的时钟与宿主机时钟同步,避免时区的问题,ro 是 read only 的意思,就是只读。
  • -e MYSQL_ROOT_PASSWORD=123456:指定 mysql 环境变量,root 用户的密码为 123456
  • -d mysql:latest:后台运行 mysql 容器,版本是 latest。

4.查看容器

# 查看正在运行的容器
docker ps
# 查看所有的docker容器
docker ps -a

这个时候如果显示的是 up 状态,那就是启动成功了。如果是 restarting,说明是有问题的。

#查看日志
docker logs -f --tail 500 mysql

Failed to access directory for --secure-file-priv. Please make sure that dir

如果出现失败的情况,请看第三步自定义配置

三.自定义配置

1.进入容器

docker exec -it mysql /bin/bash

2.进入 mysql 目录

#mysql安装目录
cd /usr/local/mysql

#进入配置目录
cd conf

3.新增配置文件

vim my.cnf
[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4
[mysqld]
# 设置东八区时区
default-time_zone = '+8:00'
# 设置密码验证规则,default_authentication_plugin参数已被废弃
# 改为authentication_policy
#default_authentication_plugin=mysql_native_password
authentication_policy=mysql_native_password
# 限制导入和导出的数据目录
# 为空,不限制导入到处的数据目录;
# 指定目录,必须从该目录导入到处,且MySQL不会自动创建该目录;
# 为NULL,禁止导入与导出功能
#secure_file_priv=/var/lib/mysql
secure_file_priv=
init_connect='SET collation_connection = utf8mb4_0900_ai_ci'
init_connect='SET NAMES utf8mb4'
character-set-server=utf8mb4
collation-server=utf8mb4_0900_ai_ci
skip-character-set-client-handshake
skip-name-resolve

默认的鉴权方式,我们修改为 mysql_native_password,不然的话连接会报错。因为在 mysql8 以后的默认加密方式改变了,由 mysql_native_password 改为了 caching_sha2_password。这种加密凡是在客户端无法访问,客户端支持的是 mysql_native_password 。

4.重启容器

docker restart mysql

5.自动启动 mysql

docker update mysql --restart=always

6.重启容器

docker restart mysql

四.授权远程访问

1.进入容器

docker exec -it mysql /bin/bash

2.连接 mysql

mysql -u root -p

上面的密码不要输入,直接回车进入。

3.选定库

#查看库
show databases;

#选定库
use mysql;

4.查看用户的连接权限

select host, user, plugin,  authentication_string, password_expired from user;

root 用户只有 localhost 的连接权限

5.修改 root 用户的连接权限

#更新root用户的信息
update user set host='%' where user='root';

#更新root用户的权限
ALTER USER root@'%' IDENTIFIED WITH mysql_native_password BY '123456';

#刷新权限
FLUSH PRIVILEGES;

6.退出 mysql

exit

7.退出容器

exit

8.验证

使用 dbeaver 进行连接验证

# 输出8.0.27
SELECT VERSION()

觉得有用的话点个赞 👍🏻 呗。
❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄

💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍

🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

img

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

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

相关文章

【代码学习】voxel 或者 pillar,稀疏张量 转 稠密张量 的代码理解,理解了很久

需要 feature 和 对应 的坐标 coords debug:转置,不然维度不匹配! 对应的代码,向量化 应该 比 for循环快 def voxel_indexing(self, sparse_features, coords): # sparse_features: [N, C], coords:[N, 4]dim sparse_features.…

前端学习之webpack的使用

概述 webpack是一个流行的前端项目构建工具(打包工具),可以解决当前web开发中所面临的问题。 webpack提供了友好的模块化支持,以及代码压缩混淆、处理js兼容问题、性能优化等强大的功能,从而让程序员把工作重心放到具…

华为是怎么做全面预算管理的?

大家好,我是老原。 在之前的文章分享中,都穿插着一个很重要但是不被你们重视的的部分,就是预算管理这块。 有很多新手项目经理在做计划的时候,发现自己设备和步骤都不熟悉,根本无从下手,不知道怎么做。 …

大模型 其他方案的进度

Llama2 1、中文提问,英文的回答,对于中文不友好 2、网上还没有看到很详细的微调教程 3、虽然Llama2的预训练数据相对于第一代LLaMA扩大了一倍,但是中文预训练数据的比例依然非常少,仅占0.13%,这也导致了原始Llama2的中…

启用 EGO 的 LSF

启用 EGO 的 LSF 具有 LSF 的企业网格协调器(enterprise grid orchestrator EGO)能够提供系统基础结构,来控制和管理集群资源。 资源是应用程序使用的物理和逻辑实体。 LSF 资源按照 EGO资源分配计划中的定义进行共享。 一、EGO 组件概览 …

antd Cascader级联菜单无法赋值回显问题

说起来太丢人了,自己还拿官网例子在这里调试半天,最后发现是一个特别小儿科的问题哈哈 Cascader级联数据是服务端返回然后自己处理过的,使用了cascader的fileNames属性重置字段名,最后发现服务端回传的数据无法赋值回显在组件上&…

python如何使用gspread读取google在线excel数据?

一、背景 公司使用google在线excel管理测试用例,为了方便把手工测试用到的测试数据用来做自动化用例测试数据,所以就想使用python读取在线excel数据,通过数据驱动方式,完成自动化回归测试,提升手动复制,粘…

Swing自定义标题栏

文章目录 Swing自定义标题栏需求最终效果如图步骤额外需求 Swing自定义标题栏 需求 想要实现IDEA类似的标题栏效果&#xff0c;菜单栏放在标题栏同一行&#xff0c;标题居中&#xff0c;右侧为按钮。如图&#xff1a; 最终效果如图 步骤 使用依赖FlatLaf <!-- https://mvn…

虚拟串口软件使用介绍

对于上位机开发来说(特别是串口通信应用),上机位软件的调试尤为重要,但是上机位软件的调试并不关心硬件,只需要关注验证发送的数据帧的接收情况,为了便于调试,可以将上机位软件与串口软件互通,实现数据的交互,但由于互通需要串口,可以借助串口虚拟软件(VSPD),虚拟出…

lazada商品评论API接口(评论内容|日期|买家昵称|追评内容|评论图片|评论视频..)

Lazada商品评论API接口是Lazada开放平台提供的一种API接口&#xff0c;可以帮助开发者获取Lazada平台上的商品评论数据。 通过该接口&#xff0c;开发者可以获取到用户对商品的评论信息&#xff0c;包括评论内容、评价等级、评论时间等&#xff0c;从而了解用户对商品的反馈和…

用android studio调试react native中的原生代码(windows+android)

要用Android Studio调试React Native原生代码&#xff0c; 1. 需要先在终端中运行react-native start命令启动React Native服务器。 2. 然后&#xff0c;在Android Studio中打开你的React Native项目&#xff08;\android\build.gradle&#xff09;&#xff0c;连接你的设备或…

修改YOLOv5的模型结构

YOLOv5 模型结构 C3模块结构图 修改目标 修改目标是移除C3模块concat后的卷积操作 YOLOv5的模型存储在项目目录下的models目录中。 一些以yaml为后缀的文件保存了一些模型的超参数&#xff0c;通过不同的参数&#xff0c;形成了yolov5s,yolov5n,yolov5l等不同参数等级&#…

【java零基础入门到就业】第四天:Notepad++软件的下载和安装

文章目录 Notepad软件简介下载安装 Notepad软件 简介 Notepad&#xff08;又称Notepad Plus Plus&#xff09;是一款免费的文本编辑器&#xff0c;是Windows操作系统下非常受欢迎的开源软件。它提供了许多强大的功能&#xff0c;适合用于编写各种编程语言的源代码、编辑文本文…

【vscode】Window11环境下vscode使用Fira Code字体【教程】

【vscode】Window11环境下vscode使用Fira Code字体【教程】 文章目录 【vscode】Window11环境下vscode使用Fira Code字体【教程】1. 下载Fira Code字体2. 安装Fira Code字体3. 配置vscode4. 效果如下Reference 如果想要在Ubuntu环境下使用Fira Code字体&#xff0c;可以参考我的…

IP路由配置

一、路由协议分类 路由协议是路由器之间维护路由表的规则,用于发现路由并生成路由表以指导报文转发。可分为: 通过链路层协议发现的直连路由通过网络管理员手动配置的静态路由通过动态路由协议发现的动态路由其中,动态路由根据作用范围分为: 内部网关协议(IGP):包括rip…

linux系统SQL server数据库定时收缩

问题现象 出现下图问题&#xff0c;导致连接该数据库的程序不能正常启动 解决办法 定时收缩数据库 数据库定时收缩脚本 需要三个脚本文件 linux_sqlcmd_timing_task_shrink.sh&#xff1a;主脚本文件 # 设置数据库名称、用户名、密码等信息 # db_name"volador"…

OpenHarmony 入门——搭建OpenHarmony本地应用开发环境

文章大纲 引言一、应用开发工具下载SDK替换1、本地SDK目录查找2、OpenHarmony SDK编译3、SDK替换4、sdk node_modules依赖包下载5、验证 三、镜像烧写工具及指南1、下载烧录工具2、安装usb驱动3、rk3568镜像编译5、 镜像配置&烧录 引言 OpenHarmony是由开放原子开源基金会…

Unity中Shader的烘培分支的判断

文章目录 前言一、上一篇文章中所需要的 lightmapUV 只有在烘焙时才会使用1、查看帮助文档后&#xff0c;Unity中判断烘培是否开启&#xff0c;使用的是LIGHTMAP_ON2、我们在 appdata 和 v2f 中&#xff0c;定义第二套UV 前言 Unity中Shader的烘培分支的判断&#xff0c;基于上…

AITO问界崛起的“临门一脚”,落在了赛力斯汽车的智慧工厂里

文 | 智能相对论 作者 | 沈浪 AITO问界新M7的销量爆了&#xff0c;口碑也紧接着“爆”了。 AITO问界新M7系列上市以来50天&#xff0c;累计大定突破8万辆。AITO问界M9预计今年12月上市&#xff0c;预订超过了1.5万辆。根据最新公布的产销数据&#xff0c;在过去的10月份&…

Contec SolarView Compact < 6.00 远程命令执行漏洞 (CVE-2023-23333)

Contec SolarView Compact < 6.00 远程命令执行漏洞 &#xff08;CVE-2023-23333&#xff09; 免责声明漏洞描述漏洞影响漏洞危害网络测绘Fofa: body"SolarView Compact" 漏洞复现1. 构造poc2. 执行命令id命令pwd命令 免责声明 仅用于技术交流,目的是向相关安全人…