Docker 下快速搭建 MySQL 和 Redis

本文涉及的产品
云原生内存数据库 Tair,内存型 2GB
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
简介: 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
相关文章
|
8天前
|
关系型数据库 MySQL Docker
Docker 安装 MySQL
Docker 安装 MySQL
37 1
|
8天前
|
NoSQL Redis Docker
Docker 安装 Redis
Docker 安装 Redis
34 2
|
7天前
|
NoSQL 关系型数据库 MySQL
无法访问Docker 里的 mysql, redis
无法访问Docker 里的 mysql, redis
9 0
|
11天前
|
SQL 关系型数据库 MySQL
MySQL运行在docker容器中会损失多少性能
MySQL运行在docker容器中会损失多少性能
|
11天前
|
NoSQL Redis 数据安全/隐私保护
[redis]定制封装redis的docker镜像
[redis]定制封装redis的docker镜像
|
5天前
|
存储 关系型数据库 MySQL
MySQL——数据库备份上传到阿里云OSS存储
MySQL——数据库备份上传到阿里云OSS存储
18 0
|
8天前
|
SQL 存储 关系型数据库
"MySQL增列必锁表?揭秘InnoDB在线DDL,让你的数据库操作飞一般,性能无忧!"
【8月更文挑战第11天】在数据库领域,MySQL凭借其稳定高效的表现深受开发者喜爱。对于是否会在给数据表添加列时锁表的问题,MySQL的行为受版本、存储引擎等因素影响。从5.6版起,InnoDB支持在线DDL,可在改动表结构时保持表的可访问性,避免长时间锁表。而MyISAM等则需锁表完成操作。例如,在使用InnoDB的表上运行`ALTER TABLE users ADD COLUMN email VARCHAR(255);`时,通常不会完全锁表。虽然在线DDL提高了灵活性,但复杂操作或大表变更仍可能暂时影响性能。因此,进行结构变更前应评估其影响并择机执行。
29 6
|
5天前
|
缓存 NoSQL Redis
一天五道Java面试题----第九天(简述MySQL中索引类型对数据库的性能的影响--------->缓存雪崩、缓存穿透、缓存击穿)
这篇文章是关于Java面试中可能会遇到的五个问题,包括MySQL索引类型及其对数据库性能的影响、Redis的RDB和AOF持久化机制、Redis的过期键删除策略、Redis的单线程模型为何高效,以及缓存雪崩、缓存穿透和缓存击穿的概念及其解决方案。
|
7天前
|
Oracle 关系型数据库 MySQL
Mysql和Oracle数据库死锁查看以及解决
【8月更文挑战第11天】本文介绍了解决MySQL与Oracle数据库死锁的方法。MySQL可通过`SHOW ENGINE INNODB STATUS`查看死锁详情,并自动回滚一个事务解除死锁;也可手动KILL事务。Oracle则通过查询V$LOCK与V$SESSION视图定位死锁,并用`ALTER SYSTEM KILL SESSION`命令终止相关会话。预防措施包括遵循ACID原则、优化索引及拆分大型事务。
|
8天前
|
固态存储 关系型数据库 MySQL
"惊!20亿数据秒速入MySQL,揭秘数据库极速插入的黑科技,你不可不知的绝密技巧!"
【8月更文挑战第11天】面对20亿级数据量,高效插入MySQL成为挑战。本文探讨优化策略:合理设计数据库减少不必要的字段和索引;使用批量插入减少网络往返;优化硬件如SSD和内存及调整MySQL配置;并行处理加速插入;附Python示例代码实现分批导入。这些方法将有效提升大规模数据处理能力。
24 2

热门文章

最新文章