介绍
介绍
前面福哥已经带着大家学会了搭建MySQL数据库服务了,今天我们来搭建Redis数据库服务。Redis数据库是一个key-value型的数据库。Redis数据库的数据存储在内存当中,有着读写速读极快的特点。Redis主要用于实现web应用的数据缓存,在常规的关系型数据库前面建立一层数据缓存可以大大提高web应用程序的运行速度。
今天福哥就带着大家使用redis:6.0-bullseye基础镜像来搭建Redis数据库环境。
环境
镜像版本 | redis:6.0-bullseye |
操作系统 | CentOS 7 x86_64 2009 |
服务器 | TFCentOS7x64 |
IP | 192.168.168.68 |
端口 | 6379 |
安装
Dockerfile
基础镜像
福哥选择的是redis:6.0-bullseye这个基础镜像,这个镜像是基于debian“bullseye”系统的。
https://hub.docker.com/_/redis/tags?page=1&name=6.0-bullseye
现在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
创建镜像目录
创建镜像目录tfredis并切换到tfredis目录下面。
mkdir /tongfu.net/data/dockerfile/tfredis cd /tongfu.net/data/dockerfile/tfredis
依赖镜像
第一行写上依赖镜像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 ./
查看镜像
看看tfredis:6.0-1.0.0镜像。
docker images | grep tfredis
启动容器
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
Redis基本操作
登录客户端
登录redis-cli客户端。
docker exec -ti tfredis redis-cli -a tongfu.net
String类型
字符串类型就是向一个键里面存储一个字符串。
Hash类型
Hash类型就是可以向一个键里存储一个结构,结构包括多个Key-Value项目。
List类型
List类型就是建立一个链表,写数据的时候可以往最前面增加数据,也可以往最后面增加数据。取数据的时候可以从最前面取数据,也可以从最后面取数据。
List类型比较厉害的是可以通过阻塞方式取数据,达到一个“监听”数据变化的效果,可以用来当作消息队列使用。
重新打开一个redis-cli客户端B,启动一个监听等待chatMsg键的数据。
在第一个客户端里向chatMsg键里放一个数据。
可以看到客户端B里立即就收到了刚刚在第一个客户端里放的数据了。
Set类型
Set类型是一个无序集合,可以往集合里面随便放数据。
可以取多个集合的交集、并集、差集。取交集使用sinter命令,取并集使用sunion命令,取差集使用sdiff命令。
ZSet类型
ZSet类型是一个有序集合,可以往集合里面放多个项目,每个项目都有一个评分score。取数据的时候可以根据这个项目的评分score进行正序、反序排序。可以针对集合里的项目调整评分score数值。
ZSet类型比较适合做排行榜之类的功能!
Redis的持久化
持久化
正常情况下redis的数据会在一定时间之后存储到本地数据库里实现数据持久化的目的。不过这个持久化的调度并不是那么积极的。但是我们可以通过手动执行save命令调用持久化存储操作。
save
查看持久化数据库文件dump.rdb被建立出来了。
ls /tongfu.net/data/docker/data/tfredis/
重启tfredis容器。
docker restart tfredis
再次获取userNick数据还是存在的。
PHP操作Redis
查看tfredis容器IP地址
使用inspect命令查询tfmysql容器的IP地址,tfmysql的IP地址是172.17.0.4。
docker inspect tfredis | grep IPAddress
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
浏览器访问
打开浏览器访问http://192.168.168.68/tfredis.php,可以看到前面从redis-cli客户端创建的各种数据。
总结
今天福哥在TFCentOS7x64服务器上面通过Dockerfile创建了一个镜像tfredis:6.0-1.0.0,并且通过这个新创建的镜像tfredis:6.0-1.0.0启动了一个容器,这个镜像用来运行Redis数据库服务。
后面福哥会教给大家使用各种编程语言去操作Redis数据库的方法,敬请期待~