Docker 下快速搭建 MySQL 和 Redis

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: Docker 下快速搭建 MySQL 和 Redis

       MySQL 和 Redis 在实际的项目中已经是非常常用的环境了,在开发时也是不能缺少的,总不至于用线上环境当作开发环境来用吧。一般情况下,这样的开发环境我们都有,但是在新机器上如果没有,找人要安装包、或者自己去网上找安装包又十分的麻烦。那么,不如试试通过 Docker 来搭建这些开发环境,既轻松也省事。

      这里安装 MySQL 5.7 和 最新版的 Redis 来进行简单的演示。


一、安装MySQL 5.7

1、直接通过 docker pull 拉取 MySQL 5.7

[root@localhost ~]# docker pull mysql:5.75.7: Pulling from library/mysql
9a0b9cd2dfe6: Pull complete
c637408ee7df: Pull complete
4c517093c276: Pull complete
301cc7d68c2a: Pull complete
17ca9bf9231a: Pull complete
9ae101e5c786: Pull complete
04baa409344e: Pull complete
f0b6015bf853: Pull complete
6005bb052ef8: Pull complete
99f303d57050: Pull complete
307a9a80c1df: Pull complete
Digest: sha256:0e3435e72c493aec752d8274379b1eac4d634f47a7781a7a92b8636fa1dc94c1
Status: Downloaded newer image for mysql:5.7
docker.io/library/mysql:5.7


2、查看拉取下来的镜像

[root@localhost ~]# docker imagesREPOSITORY   TAG       IMAGE ID       CREATED       SIZE
mysql        5.7       eef0fab001e8   2 weeks ago   495MB


3.启动 MySQL 5.7

docker run -p3306:3306 
--name mysql 
-v /mydata/mysql/log:/var/log/mysql 
-v /mydata/mysql/data:/var/lib/mysql 
-v /mydata/mysql/conf:/etc/mysql/conf 
-eMYSQL_ROOT_PASSWORD=root 
-d mysql:5.7

       这里需要说明一下,-e 用来设置环境变量,这里设置 MySQL 5.7 的 root 密码为 root。


4.查看 Docker 运行的容器

[root@localhost containers]# docker psCONTAINER ID   IMAGE       COMMAND                  CREATED         STATUS         PORTS NAMES
4f6de6ccec9f   mysql:5.7   "docker-entrypoint.s…"3 seconds ago   Up 2 seconds   0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp   mysql


5.创建 my.conf 文件并重启 MySQL

       在上面的步骤虽然挂载了 conf 目录,但是在 conf 目录下并没有具体的配置文件,这里可以在 /mydata/mysql/conf 目录下创建一个 my.conf 文件作为 mysql 的配置文件(去找一份现成的配置改改,或者直接用现成,改也不用改)。创建好文件以后,重启 MySQL 容器,命令如下:

[root@localhost containers]# docker restart 4f4f
[root@localhost containers]# docker psCONTAINER ID   IMAGE       COMMAND                  CREATED         STATUS         PORTS
                  NAMES
4f6de6ccec9f   mysql:5.7   "docker-entrypoint.s…"2 minutes ago   Up 2 seconds   0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp   mysql


6. 测试连接

       上面的步骤就已经完成了 MySQL 5.7 的安装,我们可以通过命令行,或者 Navicate 工具连接 MySQL 进行测试。发现 MySQL 可以被 Navicate 进行远程连接。


二、安装 Redis

       Redis 的安装与 MySQL 的安装基本是一样的,这里直接上操作。

1、直接通过 docker pull 拉取 Redis

[root@localhost containers]# docker pull redisUsing default tag: latest
latest: Pulling from library/redis
a603fa5e3b41: Pull complete
77631c3ef092: Pull complete
ed3847cf62b8: Pull complete
261a8b530567: Pull complete
7d9005a8af6d: Pull complete
828da1afb5be: Pull complete
Digest: sha256:1e3207c292225b6dd21cb74d59255748a50e8f739dd983040df38fa913927cf1
Status: Downloaded newer image for redis:latest
docker.io/library/redis:latest



2、创建 Redis 的配置文件并启动 Redis

       我们在 /mydata/redis/conf 目录下创建一个 Redis 的配置文件,这里一样是找个现成的配置文件即可。

[root@localhost conf]# docker run -d -p 6379:6379 --name mall-redis -v /mydata/redis/data:/data -v /mydata/redis/conf:/etc/redis redis redis-server /etc/redis/redis.conf6284d4089225fb0c311507cc14d11ca9e4d4ca02dd48f766bf70c604a1ccbcb3

       启动 MySQL 时没有 my.conf 文件是可以启动的,启动 Redis 的时候因为我们要指定一个配置文件,如果没有配置文件,则 Redis 会启动失败。因此提前准备一份 Redis 的配置文件即可。


3、修改配置并进行远程连接

       Redis 的默认配置不支持远程访问,只需要修改配置文件中的 bind 参数,并给 Redis 加一个密码,或者关掉它的保护模式的参数就可以了。


4、让容器可以开机自启动

       让我们的 MySQL 和 Redis 随着虚拟机的启动而启动,只需要使用 docker up --restart=always 进行设置即可。


       到此,一份Docker快速搭建MySQL和Redis的教程就完毕了!

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
7天前
|
关系型数据库 MySQL 数据库
docker高级篇(大厂进阶):安装mysql主从复制
docker高级篇(大厂进阶):安装mysql主从复制
66 24
|
8天前
|
NoSQL 算法 Redis
docker高级篇(大厂进阶):安装redis集群
docker高级篇(大厂进阶):安装redis集群
61 24
|
16天前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
89 26
|
2天前
|
NoSQL 关系型数据库 MySQL
Linux安装jdk、mysql、redis
Linux安装jdk、mysql、redis
52 7
|
1月前
|
存储 NoSQL 关系型数据库
MySQL和Redis的区别
**MySQL和Redis的区别** MySQL和Redis都是流行的数据存储解决方案,但它们在设计、用途和特性上有显著区别。理解这些区别有助于选择合适的数据库来满足不同的应用需求。本文将详细介绍MySQL和Redis的区别,包括它们的架构、使用场景、性能和其他关键特性。 ### 一、基本概述 **MySQL**: MySQL是一个关系型数据库管理系统(RDBMS),使用结构化查询语言(SQL)进行数据管理。它支持事务、复杂查询和多种存储引擎,广泛应用于各种Web应用、企业系统和数据分析项目。 **Redis**: Redis是一个基于内存的键值数据库,通常被称为NoSQL数
85 4
|
1月前
|
监控 前端开发 Java
【技术开发】接口管理平台要用什么技术栈?推荐:Java+Vue3+Docker+MySQL
该文档介绍了基于Java后端和Vue3前端构建的管理系统的技术栈及功能模块,涵盖管理后台的访问、登录、首页概览、API接口管理、接口权限设置、接口监控、计费管理、账号管理、应用管理、数据库配置、站点配置及管理员个人设置等内容,并提供了访问地址及操作指南。
|
3天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
13 3
|
3天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
18 3
|
3天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE 'log_%';`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
22 2
|
16天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
115 15