Linux下的redis安装和发布订阅
redis介绍
Redis是一个开源(BSD许可)的, 内存中的数据结构存储系统, 它可以作为数据库, 缓存和消息中间件使用.
yum安装redis :
1. yum安装
#前提得配置好阿里云yum源,epel源 #查看是否有redis包 yum list redis #安装redis yum install redis -y #安装好,启动redis systemctl start redis
2. 检测redis是否工作
redis-cli #redis 客户端工具 #进入交互式环境后,执行ping,返回pong表示安装成功 127.0.0.1:6379> ping PONG
源码安装redis, 编译安装 :
用了yum之后, 相当省事好用, 但是有时候编译安装更具优势
编译安装优势 :
1. 编译安装时可以指定扩展的module(模块), php, apache, nginx都是一样有很多第三方扩展模块, 如mysql, 编译安装时候, 如果需要就定制存储引擎(innodb, 还是MyIASM)
2. 编译安装可以统一安装路径, linux软件约定好安装目录在/opt/下面
3. 软件仓库版本一把比较低, 编译源码安装可以根据需求, 安装最新的版本.
1.下载redis源码 wget http://download.redis.io/releases/redis-4.0.10.tar.gz 2.解压缩 tar -zxf redis-4.0.10.tar.gz 3.切换redis源码目录 cd redis-4.0.10.tar.gz 4.编译源文件(由于redis没有configure脚本, 直接就有了amkefile, 因此可以直接编译安装) make 5.编译好后,src/目录下有编译好的redis指令 6.make install 安装到指定目录,默认在/usr/local/bin
redis可执行文件 :
./redis-benchmark //用于进行redis性能测试的工具 ./redis-check-dump //用于修复出问题的dump.rdb文件 ./redis-cli //redis的客户端 ./redis-server //redis的服务端 ./redis-check-aof //用于修复出问题的AOF文件 ./redis-sentinel //用于集群管理
启动redis服务端 (主要加配置文件参数):
编译安装完成之后, redis默认会将redis命令添加环境变量/usr/local/bin下
启动redis非常简单,直接./redis-server就可以启动服务端了,
还可以用下面的方法指定要加载的配置文件: ./redis-server ../redis.conf 默认情况下,redis-server会以非daemon的方式来运行,且默认服务端口为6379。
---------------------------------------------------------------------------------
redis-server redis.conf
redis.conf配置 :
vim redis.conf ,写入以下内容(不要加上注释) port 6379 daemonize no #后台运行redis pidfile /data/6379/redis.pid #将redis进程的id写入到redis.pid这个文件 loglevel notice #日志级别 logfile "/data/6379/redis.log" dir /data/6379 #配置redis数据存放点 protected-mode yes #redis3.0之后的安全模式 requirepass qiangdademima #给redis添加密码 redis的安全模式,可能会阻挡你远程连接,为了解决这个安全模式,给redis设置一个密码
使用redis客户端 :
#执行客户端命令即可进入 ./redis-cli #测试是否连接上redis 127.0.0.1:6379 > ping 返回pong代表连接上了 //用set来设置key、value 127.0.0.1:6379 > set name "xd" OK //get获取name的值 127.0.0.1:6379 > get name "xd"
redis发布订阅
Redis通过PUBLISH, SUBSCRIBE等命令实现了订阅与发布模式.
Redis的发布订阅支持一个发布者, 多个订阅者, 也支持正则的匹配订阅者.
发布订阅的命令 :
PUBLISH channel msg 将信息 message 发送到指定的频道 channel SUBSCRIBE channel [channel ...] 订阅频道,可以同时订阅多个频道 UNSUBSCRIBE [channel ...] 取消订阅指定的频道, 如果不指定频道,则会取消订阅所有频道
PSUBSCRIBE pattern [pattern ...] 订阅一个或多个符合给定模式的频道,每个模式以 * 作为匹配符,比如 it* 匹配所 有以 it 开头的频道( it.news 、 it.blog 、 it.tweets 等等), news.* 匹配所有 以 news. 开头的频道( news.it 、 news.global.today 等等),诸如此类
PUNSUBSCRIBE [pattern [pattern ...]] 退订指定的规则, 如果没有参数则会退订所有规则
PUBSUB subcommand [argument [argument ...]] 查看订阅与发布系统状态
注意:使用发布订阅模式实现的消息队列,当有客户端订阅channel后只能收到后续发布到该频道的消息,之前发送的不会缓存,必须Provider和Consumer同时在线。
举个栗子(多个订阅者同时订阅一个发布者) :
举个栗子(一个或多个订阅者订阅多个发布者):