Redis字符串类型的应用场景

这篇文章运用了实例代码展示redis字符串类型的几种应用场景,代码非常详细,可供感兴趣的小伙伴们参考借鉴,希望对大家有所帮助。

创新互联是一家集网站建设,永仁企业网站建设,永仁品牌网站建设,网站定制,永仁网站建设报价,网络营销,网络优化,永仁网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。

限流

使用redis可以做到限流的作用。redis本身性能极高,可以用它来抵挡部分请求。

防御大流量

现在网站攻击日渐猖獗,静态的资源可以用cdn,但动态的程序如何防御。下面,展示一个redis来防御大量请求的解决方案。

基本思路是限制一个ip一定时间内请求数,比如一个ip一秒的请求数不能超过10次。

伪代码如下:

function ip_limit($cnt = 10)
{
    $ip = $_SERVER['SERVER_ADDR'];
    $key = "limit:$ip:cnt";
    $isExisit = $redis->set($key, 1, ['nx', 'ex'=>1]);
    
    if (!$isExisit || $redis->incr($key) <= $cnt) {
        // 通过
        return true;
    } else {
        // 不通过
        return false;
    }
}

获取验证码频率限制

短信验证码现在已经成为了web应用的标配的,许多的地方都会需要短信验证码。如:注册时、修改密码时、一些对安全要求比较高的操作。当然,验证码获取不是免费的,所以,我们不希望用户无限制的获取验证码。

也是相同的思路,我们可以写一个获取短信验证码频率的限制应用。

完成一个一分钟内,只准获取一次验证码的应用,伪代码如下:

function code_limit($mobile, $time = 60)
{
    $key = "limit:$mobile:cnt";
    $isExisit = $redis->set($key, 1, ['nx', 'ex'=>$time]);
    
    if (!$isExisit) {
        // 通过
        return true;
    } else {
        // 不通过
        return false;
    }
}

存放session

使用redis存放session,是现在推荐的方式,他的好处是性能高,到期自动销魂。(PHP自身的session垃圾回收机制不是可靠的,过期销魂是有概率的)。

该方式非常简单,只需在修改php.ini文件即可。

找到session.save_handler这行,修改为

session.save_handler = redis

将session.save_path修改为

session.save_path = "tcp://localhost:6379"

如何redis设置了密码的话,只需修改为

session.save_path = "tcp://localhost:6379?auth=password"

如果不是单机应用,而是分布式的话,怎么样使用redis来集中管理session呢?

也很简单。也是只要修改php.ini文件即可。如session集中管理在192.168.1.220这个机器上,其他机器的php.ini文件修改如下:

session.save_handler = redis
session.save_path = "tcp://192.168.1.220:6379?auth=password"

以上就是Redis字符串类型的几种应用场景,如果在日常工作遇到这个问题,希望你能通过这篇文章解决问题。如果想了解更多相关内容,欢迎关注创新互联行业资讯频道!


标题名称:Redis字符串类型的应用场景
链接分享:http://scyanting.com/article/podigo.html