redis的高并发处理方式
高并发出现的问题:
客户端连接混乱造成:
1、单线程的天性决定,高并发对同一个键的操作会排队处理,如果并发量很大,可能造成后来的请求超时。
2、在远程访问redis的时候,因为网络等原因造成高并发访问延迟返回的问题。
解决:
1.在客户端将连接进行池化,同时对客户端读写Redis操作采用内部锁synchronized。
解决方式:将Redis连接池化
首先,Redis也归属于数据库范凑,即便它是NoSQL类型,依然为C/S结构模式。客户端每次请求都需要建立数据库连接,在多客户端请求模式下服务端与客户端连接频繁将导致系列阻塞、超时等等系列问题,关系型数据库解决方式是采用连接池方式解决多请求连接问题,Redis数据库建立友好的连接数量让客户端与服务端保持一定数额的连接量,当客户端需要连接时,能直接从连接池中获取连接,然后直接访问Redis服务端。
2.服务器角度,利用setnx变向实现锁机制。
setnx 有两个参数。第一个参数表示键。第二个参数表值如果当前键不存在,那么会插入当前键,将第二个参数做值.返回 1。如果当前键存在,那么会返回0。