同福

使用redis:6.0-bullseye镜像部署Redis数据库服务

介绍

介绍

前面福哥已经带着大家学会了搭建MySQL数据库服务了,今天我们来搭建Redis数据库服务。Redis数据库是一个key-value型的数据库。Redis数据库的数据存储在内存当中,有着读写速读极快的特点。Redis主要用于实现web应用的数据缓存,在常规的关系型数据库前面建立一层数据缓存可以大大提高web应用程序的运行速度。

今天福哥就带着大家使用redis:6.0-bullseye基础镜像来搭建Redis数据库环境。

环境

镜像版本redis:6.0-bullseye
操作系统CentOS 7 x86_64 2009
服务器TFCentOS7x64
IP192.168.168.68
端口6379

安装

Dockerfile

基础镜像

福哥选择的是redis:6.0-bullseye这个基础镜像,这个镜像是基于debian“bullseye”系统的。

https://hub.docker.com/_/redis/tags?page=1&name=6.0-bullseye

home/topic/2023/0404/14/dbb30288b8936ae098b9e4d212f4a94c.png

现在hub.docker.com依然打不开,大家就选这个版本吧!

拉取镜像redis:6.0-bullseye,添加到registry.tongfu.net:5000私有仓库里面。

docker pull redis:6.0-bullseye
docker tag redis:6.0-bullseye registry.tongfu.net:5000/redis:6.0-bullseye
docker rmi redis:6.0-bullseye
docker images | grep mysql

home/topic/2023/0802/22/f1e5ff63c746c6a59777b27c24918986.png

创建镜像目录

创建镜像目录tfredis并切换到tfredis目录下面。

mkdir /tongfu.net/data/dockerfile/tfredis
cd /tongfu.net/data/dockerfile/tfredis

home/topic/2023/0802/22/f07f5f3ea62a3f52fbf8cc641558d6e7.png

依赖镜像

第一行写上依赖镜像redis:6.0-bullseye。

FROM registry.tongfu.net:5000/redis:6.0-bullseye

维护者信息

这是福哥写的维护者信息。

# for MAINTAINER
MAINTAINER Author: Andy Bogate
MAINTAINER Email: tongfu@tongfu.net
MAINTAINER Home page: https://tongfu.net
MAINTAINER Datetime: 2023/04/03
MAINTAINER Version: v1.0

系统目录

这个redis镜像默认没有系统目录,所以福哥要自己创建了一套。

# dirs
RUN mkdir -p /usr/local/etc/redis \
&& mkdir -p /var/lib/redis \
&& mkdir -p /var/log/redis

ENTRYPOINT

这个redis镜像默认启动方式是不带配置文件的,所以福哥要设置自定义的ENTRYPOINT。

# entry point
ENTRYPOINT ["redis-server", "/usr/local/etc/redis/redis.conf"]

配置文件

redis.conf

这个redis镜像默认是没有配置文件的,所以福哥自己建立了一个,设置了一些常用的参数,大家可以参考~

# db filename
dbfilename dump.rdb

# db directory
dir /var/lib/redis/

# logfile
logfile /var/log/redis/redis.log

# ip
bind 0.0.0.0

# port
port 6379

# password
requirepass tongfu.net

在创建新的镜像的时候把redis.conf配置文件拷贝进去。

# user configure
COPY redis.conf /usr/local/etc/redis/redis.conf

创建镜像

使用下面的命令创建tfredis:6.0-1.0.0镜像。

docker build -f Dockerfile \
-t registry.tongfu.net:5000/tfredis:6.0-1.0.0 ./

home/topic/2023/0802/22/9b460d127c57498eab0800a6af0b05db.png

查看镜像

看看tfredis:6.0-1.0.0镜像。

docker images | grep tfredis

home/topic/2023/0802/22/ddb649090c1a1f5f4d7f7fb70a0aff40.png

启动容器

Redis数据目录

在宿主机建立一个用来存放Redis数据的目录,它将被映射到容器的Redis数据目录上面。

mkdir -p /tongfu.net/data/docker/data/tfredis
chown 999.999 /tongfu.net/data/docker/data/tfredis

启动容器

使用下面的命令基于tfredis:6.0-1.0.0镜像启动一个容器,将6379端口映射到宿主机上面,将/var/lib/redis这个redis数据目录映射到前面建立的目录上面。

docker run -tid \
--name tfredis \
-h tfredis \
-p 6379:6379 \
-v /tongfu.net/data/docker/data/tfredis:/var/lib/redis \
registry.tongfu.net:5000/tfredis:6.0-1.0.0

home/topic/2023/0802/22/52661912b04af0875a0ed952634e662e.png

Redis基本操作

登录客户端

登录redis-cli客户端。

docker exec -ti tfredis redis-cli -a tongfu.net

home/topic/2023/0802/22/97a340c36189383978ac760535a42d13.png

String类型

字符串类型就是向一个键里面存储一个字符串。

home/topic/2023/0802/22/38c5bdae6907cd28e4e06fc9e791c252.png

Hash类型

Hash类型就是可以向一个键里存储一个结构,结构包括多个Key-Value项目。

home/topic/2023/0802/22/062fd51c70c1e71e252a39f70f607663.png

List类型

List类型就是建立一个链表,写数据的时候可以往最前面增加数据,也可以往最后面增加数据。取数据的时候可以从最前面取数据,也可以从最后面取数据。

List类型比较厉害的是可以通过阻塞方式取数据,达到一个“监听”数据变化的效果,可以用来当作消息队列使用。

重新打开一个redis-cli客户端B,启动一个监听等待chatMsg键的数据。

home/topic/2023/0802/22/03759cc7861805314e3fe6f964bb2c05.png

在第一个客户端里向chatMsg键里放一个数据。

home/topic/2023/0802/22/f11b0121e65333fb1d3982b3e69449ee.png

可以看到客户端B里立即就收到了刚刚在第一个客户端里放的数据了。

home/topic/2023/0802/22/bfae11b11bcb79bd102e9a548937d49e.png

Set类型

Set类型是一个无序集合,可以往集合里面随便放数据。

可以取多个集合的交集、并集、差集。取交集使用sinter命令,取并集使用sunion命令,取差集使用sdiff命令。

home/topic/2023/0802/22/ef6abfd43888a7c5ab5dfcb66e4e3761.png

ZSet类型

ZSet类型是一个有序集合,可以往集合里面放多个项目,每个项目都有一个评分score。取数据的时候可以根据这个项目的评分score进行正序、反序排序。可以针对集合里的项目调整评分score数值。

ZSet类型比较适合做排行榜之类的功能!

home/topic/2023/0802/22/5d34e537f1a042058fc8cdd9939bd64c.png

Redis的持久化

持久化

正常情况下redis的数据会在一定时间之后存储到本地数据库里实现数据持久化的目的。不过这个持久化的调度并不是那么积极的。但是我们可以通过手动执行save命令调用持久化存储操作。

save

home/topic/2023/0802/22/9b32e80f7466a2c625fa6a3ae942b277.png

查看持久化数据库文件dump.rdb被建立出来了。

ls /tongfu.net/data/docker/data/tfredis/

home/topic/2023/0802/22/a9f2249eaefe0c1bd666528e967cef94.png重启tfredis容器。

docker restart tfredis

home/topic/2023/0802/22/a1090e40b39e1bec208944e16501ecd7.png

再次获取userNick数据还是存在的。

home/topic/2023/0802/22/fab5b257a782bec7f3059644dac6e550.png

PHP操作Redis

查看tfredis容器IP地址

使用inspect命令查询tfmysql容器的IP地址,tfmysql的IP地址是172.17.0.4。

docker inspect tfredis | grep IPAddress

home/topic/2023/0802/22/9de2c633a51727b0d3560e4d0f649fda.png

tfredis.php

在/tongfu.net/data/docker/data/tfphp/html/目录下面建立tfredis.php程序文件,编写连接Redis数据库的程序,这里面会用到刚刚查到的tfredis容器的IP地址172.17.0.3。

<?php

$redis = new \Redis();
$redis->connect("172.17.0.3", 6379);
$redis->auth("tongfu.net");

echo "<b>String</b><br>";
print_r($redis->get("userNick"));
echo "<br><br><b>Hash</b><br>";
print_r($redis->hgetall("user"));
echo "<br><br><b>Set inter</b><br>";
print_r($redis->sinter("userTags", "userTags2"));
echo "<br><br><b>Set diff</b><br>";
print_r($redis->sdiff("userTags", "userTags2"));
echo "<br><br><b>Set union</b><br>";
print_r($redis->sunion("userTags", "userTags2"));
echo "<br><br><b>ZSet</b><br>";
print_r($redis->zrevrange("hotSubDomains", 0, -1));

启动tfphp容器

因为福哥把TFCentOS7x64虚拟机重新启动了,所以之前启动的所有容器都停止了。现在我们要用到tfphp容器,通过下面的命令把它启动起来。

docker start tfphp

home/topic/2023/0802/22/1b54c7078913a4b2e3a04ea7d3358836.png

浏览器访问

打开浏览器访问http://192.168.168.68/tfredis.php,可以看到前面从redis-cli客户端创建的各种数据。

home/topic/2023/0802/22/fac91bfeed661d083ec9b31cf0d5fd7e.png

总结

今天福哥在TFCentOS7x64服务器上面通过Dockerfile创建了一个镜像tfredis:6.0-1.0.0,并且通过这个新创建的镜像tfredis:6.0-1.0.0启动了一个容器,这个镜像用来运行Redis数据库服务。

后面福哥会教给大家使用各种编程语言去操作Redis数据库的方法,敬请期待~