php redis 连接池,springboot redis配置?

用户投稿 22 0

关于“redis_php_连接池”的问题,小编就整理了【3】个相关介绍“redis_php_连接池”的解答:

springboot redis配置?

首先看你用的是boot几版本的,1版本只需要导入spring-boot-starter-data-redis 2版本的还需要commons-pool2包

1版本配置

spring:

redis:

host: Ip地址

port: 6379 # 下面这些可以不加

jedis:

pool:

max-active: 8 # 连接池最大连接数(使用负值表示没有限制)

max-idle: 8 # 连接池中的最大空闲连接 max-wait: -1 # 连接池最大阻塞等待时间(使用负值表示没有限制)

min-idle: 0 # 连接池中的最小空闲连接

2版本配置

spring.redis.host=Ip地址

spring.redis.port=6379

spring.redis.password=填写你的密码

# 连接超时时间(毫秒)

spring.redis.timeout=36000ms

# Redis默认情况下有16个分片,这里配置具体使用的分片,默认是0

spring.redis.database=0

# 连接池最大连接数(使用负值表示没有限制) 默认 8

spring.redis.lettuce.pool.max-active=8

redis集成规范?

    Redis是一个分布式(distributed)、容错(fault-tolerant)的 Redis 实现,集群可以使用的功能是普通单机 Redis 所能使用的功能的一个子集(subset)。redis的集成规范有:

1,冷热数据区分

   虽然 Redis支持持久化,但将所有数据存储在 Redis 中,成本非常昂贵。建议将热数据 (如 QPS超过 5k) 的数据加载到 Redis 中。低频数据可存储在 Mysql、 ElasticSearch中。

2,业务数据分离

    不要将不相关的数据业务都放到一个 Redis中。一方面避免业务相互影响,另一方面避免单实例膨胀,并能在故障时降低影响面,快速恢复。

3,消息大小限制

   由于 Redis 是单线程服务,消息过大会阻塞并拖慢其他操作。保持消息内容在 1KB 以下是个好的习惯。严禁超过 50KB 的单条记录。消息过大还会引起网络带宽的高占用,持久化到磁盘时的 IO 问题。

4,连接数限制

    连接的频繁创建和销毁,会浪费大量的系统资源,极限情况会造成宿主机当机。请确保使用了正确的 Redis 客户端连接池配置。

php使用redis怎么解决秒杀中的超卖问题?

使用redis 的队列+watch解决,把秒杀商品放入队列,抢到则pop商品,队列用完,则停止抢购

<?php

header("content-type:text/html;charset=utf-8");

$redis = new redis();

$result = $redis->connect('127.0.0.1', 6379);

$mywatchkey = $redis->get("mywatchkey");

$rob_total = 100; //抢购数量

if($mywatchkey<$rob_total){

$redis->watch("mywatchkey");

$redis->multi();

//设置延迟,方便测试效果。

sleep(5);

//插入抢购数据

$redis->hSet("mywatchlist","user_id_".mt_rand(1, 9999),time());

$redis->set("mywatchkey",$mywatchkey+1);

到此,以上就是小编对于“redis_php_连接池”的问题就介绍到这了,希望介绍关于“redis_php_连接池”的【3】点解答对大家有用。

抱歉,评论功能暂时关闭!