异步写入数据库
对于高速读/写场合中单单使用Redis的场景,把这些需要高速读/写的数据,
缓存到Redis中,而在满足一定条件时,触发这些缓存的数据写入数据库中去。
细细解释一下这个问题,当一个请求发送数据当服务器时,一开始存储数据是
Redis缓存,没有进行任何关于数据库的操作,但是缓存不能持久化,因此需要
需要把这些数据存入数据库,因此会在一定条件时判断一个请求是否结束,一旦结束,
就会将缓存中的数据更新到数据库。而这个条件就像秒杀或者抢红包业务中红包数量
是否为0,如果为空,一次性写入数据库,完成持久化工作。
此部分需要从两个方面为读者解读,不管是配置也好还是代码堆积也好,他们之间紧紧地联系在一起,读者可以参考阅读。
-
Spring环境下的Redis配置细节
-
Java环境下的Jedis操作
Spring IOC原理简单回忆
SpringIoc控制反转技术简单的理解就是管理我们日常所用的JavaBean类或者对象,因为一个Bean对象拥有属性和它们各自对应的getter和setter方法等,(只是简单的举JavaBean对象,其他对象也可以),SpringIoc容器干了什么呢?通过我们人为的配置,SpringIOC会在容器中保存对应的Bean对象。下面代码介绍:
package com.ruider;
public class Person{
private String name;
private int age;
/** getter and setter **/
}
这是一个Person类,拥有属性name和age
初始化一个对象:
Person a=new Person();
a.setName(“a”);
a.setAge(20);
再看看我们的Spring中的配置
使用配置获取Person对象
@Autowired
Person a=null;
不管是Java代码式创建对象还是使用SpringIOC容器获取对象,他们都是等价的。
理解这一点会有助于后面的Redis原理解析。
###Redis属性以及连接池的属性
Redis:(connectionFactory常用的)
-
jedisCOnfig连接池配置信息
-
port端口,一般是6379
-
host或者localhost
-
password 密码
-
TIMEOUT 超时
Redis连接池:(JedisPoolConfig常用)
-
最大空闲数MaxIdle
-
最大连接数MaxTotal
-
最大等待时间MaxWaitingTimes
Redis使用对象RedisTemplate属性
-
connectionFactory连接工厂(相当于连接池)
-
keySerializer Redis键序列化转换类型
-
valueSerializer Redis值序列化转换类型
Redis配置式redis-config.xml
根据上述的三种属性介绍进行Redis的属性配置
<?xml version="1.0" encoding="UTF-8"?><beans xmlns=“http://www.springframework.org/schema/beans”
xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance” xmlns:aop=“http://www.springframework.org/schema/aop”
xmlns:tx=“http://www.springframework.org/schema/tx” xmlns:context=“http://www.springframework.org/schema/context”
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd"
default-autowire=“byName” default-lazy-init=“true”>
<bean id=“connectionFactory”
class=“org.springframework.data.redis.connection.jedis.JedisConnectionFactory”>
<bean
class=“org.springframework.data.redis.serializer.StringRedisSerializer” />
<bean
class=“org.springframework.data.redis.serializer.JdkSerializationRedisSerializer” />
(1)其中对于JedisPoolConfig连接池的配置
至此,JedisPoolConfig的对象已经存储在SpringIOC容器中,在程序应用中可以通过@Autowired
获取JedisPoolConfig的对象。
上面JedisPoolConfig的配置用Java语句实现如下:
public class JedisPoolDemo{
public static void main(String[] args){
JedisPoolConfig jedisPoolConfig=new JedisPoolConfig();
jedisPoolConfig.setMaxIdle(20); //连接池最大空闲数
jedisPoolConfig.setMaxTotal(100); //连接池最大连接数
jedisPoolConfig.setMaxWaitingMillis(2000);//最大等待时间为2秒
}
}
(2)其中ConnectionFactory的配置如下
<bean id=“connectionFactory”
class=“org.springframework.data.redis.connection.jedis.JedisConnectionFactory”>
至此ConnectionFactory的对象已经存储在SpringIOC容器中,在程序应用中可以通过@Autowired
获取JedisPoolConfig的对象。
上面ConnectionFactory的配置用Java语句实现如下:
//JedisPoolConfig设置
小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
最后
转存中…(img-lVLjJBU9-1710411026831)]
[外链图片转存中…(img-Xhz7iJto-1710411026831)]
[外链图片转存中…(img-zePbMIEn-1710411026832)]
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
[外链图片转存中…(img-eluwuiHS-1710411026832)]
最后
[外链图片转存中…(img-vNrFzD5E-1710411026833)]
[外链图片转存中…(img-md4hvE6m-1710411026833)]