Redis 6.2 Docker 部署(单机)

这篇文章主要介绍 redis 6.2 单机 Docker 的部署安装方式。

1. 拉取镜像

1
2
3
4
5
6
7
8
# 搜索 Mysql 镜像
$ docker search redis

# 下载 Redis 镜像
$ docker pull redis:6.2

# 查看下载镜像
$ docker images

2. 创建挂载目录

在宿主机上创建 Reids 配置文件目录及数据目录。

1
2
3
4
5
6
7
8
9
$ cd /app/redis6.2

# 创建 conf & data 目录
$ mkdir conf
$ mkdir data

# 下载 redis 配置文件
$ cd conf
$ wget wget http://download.redis.io/redis-stable/redis.conf

3. 修改 redis.conf 文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

# 注释 bind,否则只允许本机访问
# bind 127.0.0.1 -::1

# 关闭安全模式
protected-mode no

# 开启持久化(可选)
appendonly yes

# 后台运行
daemonize yes

# 日志文件
logfile "access.log"

# 设置访问密码
requirepass 123456

4. 启动 Redis

1
2
3
4
5
6
7
# 启动 Redis 6.2
$ docker run -d \
-p 6379:6379 --name redis6.2 \
-v /app/redis6.2/conf/redis.conf:/etc/redis/redis.conf \
-v /app/redis6.2/data:/data \
--privileged=true redis:6.2 redis-server \
/etc/redis/redis.conf --appendonly yes

参数说明:

  • –name:容器名称;
  • -p:端口映射,宿主机端口:容器端口;
  • -v:挂载宿主机目录,宿主机目录(或文件):容器目录(或文件);
  • -d:后台运行
  • redis-server –appendonly yes: 在容器执行redis-server启动命令,并打开redis持久化配置

Redis 目录说明:

  • 配置文件: /etc/redis/redis.conf
  • 数据文件目录:/data

说明:
Redis docker 镜像默认无配置文件。

5. 访问 Redis 容器

执行 docker exec -it redis6.2 redis-cli 命令,进入终端。

1
2
3
4
5
6
7
8
9
10
# 查看容器列表
$ docker ps

# 进入容器
$ docker exec -it redis6.2 redis-cli
127.0.0.1:6379> auth default 123456

# 或者使用 bash 命令
$ docker exec -it redis6.2 bash
$ redis-cli

说明:
在 Redis6.0 之前的版本中,登陆 Redis Server 只需要输入密码(前提配置了密码 requirepass )即可,不需要输入用户名,而且密码也是明文配置到配置文件中,安全性不高。另外应用连接也使用该密码,导致应用有所有权限,风险极高。在 Redis6.0 引入了 ACL,可以按照不同的需求设置相关的用户和权限。
Redis ACL 是向后兼容的,即默认情况下用户为 default,使用的是 requirepass 配置的密码。如果不配置密码,输入任何字符串都可以认证通过,包括空字符串(不过密码字段不能省略)。要是不使用ACL功能,对旧版客户端来说完全一样。