目录
通过docker部署redis,比起我们自己编译安装的方式,会更加方便容易管理。今天就来简单分享一下使用docker部署redis数据库。
1,拉取镜像
通过下列命令:
docker pull redis
2,创建数据卷
通常,类似于mysql,redis作为数据库,我们最好还是需要将其配置和数据等等挂载到数据卷以持久化到宿主机。
仍然是使用具名挂载的方式方便管理。
docker volume create redis-config docker volume create redis-data
这样就创建了两个数据卷分别是存放配置文件和数据,大家也可以自行命名。
3,创建并编写配置文件
先进入到配置文件的数据卷目录,可以通过docker volume inspect
命令查看数据卷的位置:
docker volume inspect redis-config
进入目录后创建名为redis.conf
的文件,并加入如下内容:
requirepass 12345678 dir /data
这里设置了密码为12345678
,设定了数据文件存放目录为/data
,这些配置都可以自定义,更多配置可以参考。
4,创建并启动容器
执行下列命令:
docker run -id --name=redis -v redis-config:/usr/local/etc/redis -v redis-data:/data -p 6379:6379 -e lang=c.utf-8 redis su -l root -c "redis-server /usr/local/etc/redis/redis.conf"
上述参数如下:
-v
指定数据卷,可见将容器内/usr/local/etc/redis
挂载至了数据卷redis-config
,将容器内/data
挂载至数据卷redis-data
,可见这里挂载数据卷的容器内路径和我们上述预先写的配置文件中对应的路径是要一致的-p
用于暴露端口-e
用于指定容器内环境变量,设置容器的语言环境变量lang
值为c.utf-8
,这个最好是要设置,否则容器内默认是英文环境,使得redis可能无法存放中文内容
末尾是启动命令,单独拿出来看一下:
su -l root -c "redis-server /usr/local/etc/redis/redis.conf"
意思是在容器内以root
身份运行redis-server
并指定了配置文件位置。
之所以要以root
身份运行,是因为防止其没有权限将数据写入到磁盘。也可见最后指定的配置文件路径,和前面-v
挂载的配置文件数据卷的容器内路径一致,这里好理解,但是要注意,如果你是自定义别的路径与文件名就需要在-v
挂载时和最后启动指定配置时做一下变化了。
最后,就可以使用客户端连接服务器上的redis了!