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

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

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

  • 相关阅读:
    django rest framework renderer
    django集成celery
    Celery
    ajax csrftoken
    验证码刷新、倒计时
    C++ const关键字以及static关键字
    git 查看当前仓库地址以及设置新的仓库地址
    C++ explicit关键字
    SSD训练网络参数计算
    C++ opencv调用resize修改插值方式遇到的坑
  • 原文地址:https://www.cnblogs.com/dong-/p/10079923.html
Copyright © 2020-2023  润新知