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

这篇具有很好参考价值的文章主要介绍了【Mysql系列】从零开始学MySQL:Docker部署快速上手。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。
【Mysql系列】从零开始学MySQL:Docker部署快速上手,s5 数据库,mysql,docker,数据库

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

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

一.简单介绍

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 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

【Mysql系列】从零开始学MySQL:Docker部署快速上手,s5 数据库,mysql,docker,数据库文章来源地址https://www.toymoban.com/news/detail-742506.html

到了这里,关于【Mysql系列】从零开始学MySQL:Docker部署快速上手的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MySQL 从零开始:02 MySQL 安装

    要操作 MySQL ,首先要安装 MySQL ,本文将一步步展示如何安装 MySQL,简直详细到令人发指。 环境: 操作系统:Windows10 64位 MySQL版本:社区版 8.0.11.0 下载MySQL数据库可以访问官方网站:https://www.mysql.com/ 点击 DOWNLOADS 点击 Community 点击 MySQL Community Server 下面的 DOWNLOAD 进入一个新

    2024年02月02日
    浏览(31)
  • 通过 docker-compose 快速部署 MySQL保姆级教程

    MySQL 是一种开源的关系型数据库管理系统( RDBMS ),以其快速、可靠和易于使用而受到广泛的欢迎。 MySQL 使用 SQL (结构化查询语言)进行查询、管理和操作数据。 MySQL 是一种跨平台的数据库,支持在各种操作系统(如 Windows、Linux、MacOS 等)上运行。 MySQL 中的重要概念包括

    2024年02月04日
    浏览(49)
  • 从零开始学Docker(一):Docker的安装部署

    前述:本次学习与整理来至B站【Python开发_老6哥】老师分享的课程,有兴趣的小伙伴可以去加油啦,附链接 宿主机环境:RockyLinux 9 Docker引擎主要有两个版本:企业版(EE)和社区版(CE) 每个季度(1-3,4-6,7-9,10-12),企业版和社区版都会发布一个稳定版本(Stable)。社区版本会

    2024年02月15日
    浏览(49)
  • 『MySQL快速上手』Centos 7安装MySQL详解

    说明 : 在环境安装中始终保持 root 身份; 以下为 Centos 7 安装 MySQL 的详细步骤。若在安装过程中,本文章有未提及的地方,请私信我~ 为了确保你的机器上是否自带MySQL或者你曾经是否手动安装过MySQL,我们需要先进行检查。如果你曾经自己下载过某个版本的MySQL并且感觉不错

    2024年02月12日
    浏览(89)
  • docker从零开始(2)----应用部署/dockerfile

    通信 容器内的网络服务和外部机器不能直接通信 外部机器和宿主机可以直接通信 宿主机和机器可以直接通信 当容器中的网络服务需要被外部机器访问时,可以将容器中提供服务的端口映射到宿主机的端口上。外部机器访问宿主机的该端口,从而间接访问容器的服务。这种操

    2024年02月07日
    浏览(58)
  • 『MySQL快速上手』-①-Centos 7安装MySQL详解

    说明 : 在环境安装中始终保持 root 身份; 以下为 Centos 7 安装 MySQL 的详细步骤。若在安装过程中,本文章有未提及的地方,请私信我~ 为了确保你的机器上是否自带MySQL或者你曾经是否手动安装过MySQL,我们需要先进行检查。如果你曾经自己下载过某个版本的MySQL并且感觉不错

    2024年02月05日
    浏览(41)
  • MySQL从入门到快速上手

    主键:表中每一行都应该有一列(或几列)可以唯一标识自己。 主键可以是一列构成,也可以是几列共同构成。 唯一 非空 不允许修改 关于通配符:一般而言,除非你确实需要表中的每一列,否则最好别使用 * 通配符。 检索不同的值:DISTINCT 不能部分使用 DISTINCT , DISTINCT 关

    2024年02月08日
    浏览(58)
  • 『MySQL快速上手』-⑩-索引特性

    提高数据库的性能,索引是物美价廉的东西了。不用加内存,不用改程序,不用调sql,只要执行正确的 create index ,查询速度就可能提高成百上千倍。但是天下没有免费的午餐,查询速度的提高是以插入、更新、删除的速度为代价的,这些写操作,增加了大量的IO。所以它的价

    2024年01月21日
    浏览(40)
  • MySQL 从零开始:04 增删改查

    在上一小节中介绍了 MySQL 数据库的一些最最最基础的入门级也是必须要掌握的10条语句,本节将继续深入学习 MySQL 的增删改查语句。本节讲的增删改查是相对于 表 而言的。 想要对表进行增删改查,首先应该有张表,假设我们要统计大学同学工作之后的工作情况,建立了如下

    2024年01月25日
    浏览(33)
  • 从零开始学习MySQL调试跟踪(1)

    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。 GreatSQL是MySQL的国产分支版本,使用上与MySQL一致。 作者: Yejinrong/叶金荣 文章来源:GreatSQL社区投稿 编译GreatSQL 安装gdb 开始调试GreatSQL源码 3.1 利用gdb设置断点 3.2 使用 Trace 文件调试 有时为了跟踪故障

    2023年04月11日
    浏览(28)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包