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

1. 介绍

1.1 介绍

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

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

1.2 环境

镜像版本

redis:6.0-bullseye

操作系统

CentOS 7 x86_64 2003

服务器

TFCentOS7x64

IP

192.168.168.68

端口

6379

2. 安装

2.1 Dockerfile

2.1.1 基础镜像

福哥选择的是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

2.1.2 创建镜像目录

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

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

2.1.3 依赖镜像

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

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

2.1.4 维护者信息

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

# 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

2.1.5 系统目录

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

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

2.1.6 ENTRYPOINT

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

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

2.2 配置文件

2.2.1 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

2.3 创建镜像

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

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

2.4 查看镜像

看看tfredis:6.0-1.0.0镜像。

docker images | grep tfredis

3. 启动容器

3.1 Redis数据目录

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

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

3.2 启动容器

使用下面的命令基于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

4. Redis基本操作

4.1 登录客户端

登录redis-cli客户端。

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

4.2 String类型

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

4.3 Hash类型

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

4.4 List类型

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

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

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

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

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

4.5 Set类型

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

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

4.6 ZSet类型

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

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

5. Redis的持久化

5.1 持久化

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

save

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

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

重启tfredis容器。

docker restart tfredis

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

6. PHP操作Redis

6.1 查看tfredis容器IP地址

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

docker inspect tfredis | grep IPAddress

6.2 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 "String
"; print_r($redis->get("userNick")); echo "

Hash
"; print_r($redis->hgetall("user")); echo "

Set inter
"; print_r($redis->sinter("userTags", "userTags2")); echo "

Set diff
"; print_r($redis->sdiff("userTags", "userTags2")); echo "

Set union
"; print_r($redis->sunion("userTags", "userTags2")); echo "

ZSet
"; print_r($redis->zrevrange("hotSubDomains", 0, -1));

6.3 启动tfphp容器

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

docker start tfphp

6.4 浏览器访问

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

7. 总结

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

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


https://m.tongfu.net/home/35/blog/513987.html

展开阅读全文

页面更新:2024-06-06

标签:数据库   容器   持久   客户端   以往   命令   类型   目录   项目   数据

1 2 3 4 5

上滑加载更多 ↓
推荐阅读:
友情链接:
更多:

本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828  

© CopyRight 2020-2024 All Rights Reserved. Powered By 71396.com 闽ICP备11008920号-4
闽公网安备35020302034903号

Top