redis的应用场景

1.作为缓存

redis缓存使用get.set.setex缓存数据.setex语法:

//过期时间单位为s/秒
$redis->setex(key,过期时间/s,value);

应用场景实例:

//实例化redis
$redis = new \Redis();
//连接redis
$redis->connect(`127.0.0.1`,6379);
//选择数据库(数字为库的序号)
$redis->select(1);
//设置一个key
$key = 'key';
//获取redis中的value
$value = $redis->get($key);
//为空表示缓存过期或第一次访问
if(empty($value)){
    //设置一个过期时间为10秒的数据
    $redis->setex($key,10,1);
    //执行你的业务代码
    //...
}

2.作为消息队列

redis消息队列的思路是:
在遇到需要消耗大量时间的操作时间将操作需要的参数通过rpush()函数添加到redis队列,继续执行主业务.不影响业务的正常使用.
建立一个后台任务执行php脚本监听redis中rpush时的key,有新数据时则处理,无数据时死循环继续监听
具体实现:

/**
*  思路 
*  将需要更新的pid存入redis 
*  通过执行for循环的死循环脚本监听redis此key是否更新
*   有更新时执行更新
*/
$redis = new \Redis();
$redis->connect('127.0.0.1',6379);
$redis->select(5);
$update_team_num_key = 'update_team_num_key';
$redis->rpush($update_team_num_key,$data['pid']);
//继续执行主业务...
//...
//监听redis
//在php cli模式中执行监听
//在命令行中执行的方法(thinkphp)----php ./index.php /模块/控制器/方法
public function listenRedis(){
    $redis = new \Redis();
    $redis->connect('127.0.0.1',6379);
    $redis->select(5);
    $update_team_num_key = 'update_team_num_key';
    echo '****************start listenRedis begin*******************';
    while (true) {
        if($redis->get('stop_team') == 1){
        return;
        }
        //获取队列长度
        $len = $redis->llen($update_team_num_key);
        //判断长度是否为0
        if($len){
            //有需要更新的数据时取出pid
            $pid = $redis->lpop($update_team_num_key);
            //执行自动更新
            $this->m->update_reg($pid);
            $this->pidLevel($pid);
        }
    sleep(1);
    }
    echo 'stop listenRedis!';
}
Redis是一种高性能的内存数据库,它被广泛用于各种应用场景。以下是几个常见的Redis应用场景: 1. 缓存:由于Redis的高性能和低延迟,它通常被用作数据缓存层,将频繁访问的数据存储在内存中,从而加快数据访问速度。 2. 会话存储:在分布式系统中,可以使用Redis存储用户会话信息,包括用户登录状态、权限等。这样可以轻松实现会话共享和负载均衡。 3. 发布/订阅系统:Redis支持发布/订阅模式,可以用于实时消息传递、事件通知等场景。发布者将消息发布到指定频道,订阅者可以接收到相关消息并做出相应处理。 4. 计数器和排行榜:Redis提供了原子操作的支持,可以用于实现计数器和排行榜功能。例如,可以使用Redis的INCR操作来实现网站的访问计数器,或者根据用户的积分进行排行。 5. 分布式锁:在分布式系统中,为了保证数据的一致性和并发控制,可以使用Redis的分布式锁功能。通过使用Redis的SETNX操作来获取锁,并使用EXPIRE设置锁的过期时间,可以有效地实现分布式锁。 6. 消息队列:Redis的列表结构可以用作轻量级的消息队列。生产者将消息推入列表,消费者则从列表中弹出消息进行处理。这种方式简单高效,适用于需要异步处理的场景。 这只是一部分常见的Redis应用场景,实际上,由于Redis的灵活性和高性能,它在各种场景下都有不同的应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值