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同时在线。

 举个栗子(多个订阅者同时订阅一个发布者) :

 举个栗子(一个或多个订阅者订阅多个发布者):

 

posted @ 2018-12-06 22:04  唯你如我心  阅读(550)  评论(0编辑  收藏  举报