博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linux下的redis安装和发布订阅
阅读量:5014 次
发布时间:2019-06-12

本文共 2637 字,大约阅读时间需要 8 分钟。

redis介绍

Redis是一个开源(BSD许可)的, 内存中的数据结构存储系统, 它可以作为数据库, 缓存和消息中间件使用.

yum安装redis :

1. yum安装

#前提得配置好阿里云yum源,epel源#查看是否有redis包yum list redis#安装redisyum install redis -y#安装好,启动redissystemctl start redis

2. 检测redis是否工作

redis-cli    #redis 客户端工具#进入交互式环境后,执行ping,返回pong表示安装成功127.0.0.1:6379> pingPONG

源码安装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.gz2.解压缩tar -zxf redis-4.0.10.tar.gz3.切换redis源码目录cd redis-4.0.10.tar.gz4.编译源文件(由于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  #测试是否连接上redis127.0.0.1:6379 > ping返回pong代表连接上了//用set来设置key、value127.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 发送到指定的频道 channelSUBSCRIBE 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同时在线。

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

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

 

转载于:https://www.cnblogs.com/dong-/p/10079923.html

你可能感兴趣的文章
LeetCode:组合总数III【216】
查看>>
Thinkphp框架回顾(三)之怎么实现平常的sql操作数据库
查看>>
虚函数的效率问题
查看>>
POJ 1860 Currency Exchange(SPFA 判断有无“正”环)
查看>>
广告地址屏蔽
查看>>
收缩SqlServer数据库日记方法
查看>>
每日英语:15 places to find inspiration
查看>>
学习方法--提问
查看>>
【转】每天一个linux命令(3):pwd命令
查看>>
merge-two-sorted-lists
查看>>
MySQL(3)
查看>>
poj1061——扩展gcd水题
查看>>
UVa400.Unix ls
查看>>
POJ 2299 Ultra-QuickSort 归并排序、二叉排序树,求逆序数
查看>>
Educational Codeforces Round 60 (Rated for Div. 2) C. Magic Ship
查看>>
Windows 2008 R2系统开机时如何不让Windows进行磁盘检测?
查看>>
WP7应用开发笔记(18) 本地化与多语言
查看>>
解决 .so文件64与32不兼容问题
查看>>
归并排序法
查看>>
【剑指offer】面试题26:复杂链表的复制
查看>>