【转】Dubbo声明式缓存
缓存的应用非常广泛,为了提高数据访问的速度。Dubbo也不例外,它提供了声明式缓存,以减少用户加缓存的工作量。
一、Dubbo中缓存策略
- lru 基于最近最少使用原则删除多余缓存,保持最热的数据被缓存。
- threadlocal 当前线程缓存,比如一个页面渲染,用到很多portal,每个portal都要去查用户信息,通过线程缓存,可以减少这种多余访问。
- jcache 与JSR107集成,可以桥接各种缓存实现。
二、Provider
服务端包含接口和实现
接口:
- package com.tgb.cacheService;
- /**
- * 服务端 缓存 接口
- * @author xx
- *
- */
- public interface CacheService {
- String findCache(String id);
- }
实现:
- package com.tgb.cacheService;
- import java.util.concurrent.atomic.AtomicInteger;
- /**
- * 服务端 缓存 接口实现
- * @author xx
- *
- */
- public class CacheServiceImpl implements CacheService {
- private final AtomicInteger i = new AtomicInteger();
- public String findCache(String id) throws Exception {
- return "request: " + id + ", response: " + i.getAndIncrement();
- }
- }
spring配置文件:CacheProvider.xml
- <?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:dubbo="http://code.alibabatech.com/schema/dubbo"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans.xsd
- http://code.alibabatech.com/schema/dubbo
- http://code.alibabatech.com/schema/dubbo/dubbo.xsd
- ">
- <dubbo:application name="cache-provider" />
- <dubbo:registry protocol="zookeeper" address="192.168.24.140:2181" />
- <dubbo:protocol name="dubbo" port="20880" />
- <dubbo:service interface="com.tgb.cacheService.CacheService" ref="cacheService" /> <!-- 和本地bean一样实现服务 -->
- <bean id="cacheService" class="com.tgb.cacheService.CacheServiceImpl" />
- </beans>
程序入口:
- package com.tgb.main;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- /**
- * 服务端入口
- * @author xx
- *
- */
- public class CacheProvider {
- public static void main(String[] args) throws Exception{
- ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[] { "CacheProvider.xml" });
- context.start();
- System.out.println("按任意键退出");
- System.in.read();
- }
- }
三、Consumer
接口同服务端
spring配置文件:CacheConsumer.xml,配置缓存
- <?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:dubbo="http://code.alibabatech.com/schema/dubbo"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans.xsd
- http://code.alibabatech.com/schema/dubbo
- http://code.alibabatech.com/schema/dubbo/dubbo.xsd
- ">
- <!-- 消费方应用名,用于计算依赖关系,不是匹配条件,不要与提供方一样 192.9.145.19:2181,192.9.145.19:2182,192.9.145.19:2183-->
- <dubbo:application name="cache-consumer" /> <!-- 使用multicast广播注册中心暴露发现服务地址 -->
- <dubbo:registry protocol="zookeeper" address="192.168.24.140:2181" /> <!-- 生成远程服务代理,可以和本地bean一样使用demoService -->
- <dubbo:reference id="cacheService" interface="com.tgb.cacheService.CacheService" cache="true" />
- </beans>
程序入口:
- package com.tgb.main;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- import com.tgb.cacheService.CacheService;
- /**
- * 客户端入口
- * @author xx
- *
- */
- public class CacheConsumer {
- public static void main(String[] args) throws Exception {
- ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[] { "CacheConsumer.xml" });
- context.start();
- CacheService cacheService = (CacheService)context.getBean("cacheService");
- // 测试缓存生效,多次调用返回同样的结果。(服务器端自增长返回值)
- String fix = null;
- for (int i = 0; i < 5; i ++) {
- String result = cacheService.findCache("0"); //request: 0, response: 1001
- if (fix == null || fix.equals(result)) {
- System.out.println("OK: " + result);
- } else {
- System.err.println("ERROR: " + result);
- }
- fix = result;
- Thread.sleep(6000);
- }
- // LRU的缺省cache.size为1000,执行1001次,应有溢出,执行了1001次后1001*2=2002,所以result为2002
- for (int n = 0; n < 1001; n ++) {
- String pre = null;
- for (int i = 0; i < 10; i ++) {
- String result = cacheService.findCache(String.valueOf(n));
- if (pre != null && ! pre.equals(result)) {
- System.err.println("ERROR: " + result);
- }
- pre = result;
- }
- }
- // 测试LRU有移除最开始的一个缓存项
- String result = cacheService.findCache("0"); //request: 0, response: 2002
- if (fix != null && ! fix.equals(result)) {
- System.out.println("OK: " + result);
- } else {
- System.err.println("ERROR: " + result);
- }
- }
- }
三、测试
首先要启动zookeeper,然后依次启动provider和consumer,执行结果如下:
- OK: request: 0, response: 1003
- OK: request: 0, response: 1003
- OK: request: 0, response: 1003
- OK: request: 0, response: 1003
- OK: request: 0, response: 1003
- OK: request: 0, response: 2004
服务器端的response值是变化的,但是如果response结果是1000,那么在执行了1001次后,结果为2001,到执行入口中第三个循环的时候缓存中result值是最新的,最近最久不使用的已经被移除了。
原文:https://blog.csdn.net/ggibenben1314/article/details/47752661
【转】Dubbo声明式缓存的更多相关文章
- Dubbo声明式缓存
为了进一步提高消费者对用户的响应速度,减轻提供者的压力,Dubbo提供了基于结果的声明式缓存.该缓存是基于消费者端的,所以使用很简单,只需修改消费者配置文件,与提供者无关 一.创建消费者07-cons ...
- Spring 3.1新特性之三:Spring对声明式缓存的支持
一.概述: Spring 3.1 引入了激动人心的基于注释(annotation)的缓存(cache)技术,它本质上不是一个具体的缓存实现方案(例如EHCache 或者 OSCache),而是一个对缓 ...
- dubbo之结果缓存
结果缓存,用于加速热门数据的访问速度,Dubbo提供声明式缓存,以减少用户加缓存的工作量. lru 基于最近最少使用原则删除多余缓存,保持最热的数据被缓存. threadlocal 当前线程缓存,比如 ...
- Spring Cloud Eureka 分布式开发之服务注册中心、负载均衡、声明式服务调用实现
介绍 本示例主要介绍 Spring Cloud 系列中的 Eureka,使你能快速上手负载均衡.声明式服务.服务注册中心等 Eureka Server Eureka 是 Netflix 的子模块,它是 ...
- spring cloud深入学习(四)-----eureka源码解析、ribbon解析、声明式调用feign
基本概念 1.Registe 一一服务注册当eureka Client向Eureka Server注册时,Eureka Client提供自身的元数据,比如IP地址.端口.运行状况指标的Uri.主页地址 ...
- spring声明式事务管理总结
事务配置 首先在/WEB-INF/applicationContext.xml添加以下内容: <!-- 配置事务管理器 --> <bean id="transactionM ...
- PHP系统声明式事务处理
转自:http://www.jianshu.com/p/34261804bc45 1.数据库事务 事务(Transaction)是并发控制的基本单位.所谓的事务,它是一个操作序列,这些操作要么都执行, ...
- Spring声明式事务配置管理方法
环境配置 项目使用SSH架构,现在要添加Spring事务管理功能,针对当前环境,只需要添加Spring 2.0 AOP类库即可.添加方法: 点击项目右键->Build Path->Add ...
- Spring声明式事务配置管理方法(转)
项目使用SSH架构,现在要添加Spring事务管理功能,针对当前环境,只需要添加Spring 2.0 AOP类库即可.添加方法: 点击项目右键->Build Path->Add libra ...
随机推荐
- 第二章 ConcurrentHashMap源码解析
注:在看这篇文章之前,如果对HashMap的层不清楚的话,建议先去看看HashMap源码解析. http://www.cnblogs.com/java-zhao/p/5106189.html 1.对于 ...
- Android - "已安装了存在签名冲突的同名数据包",解决方法!
错误提示:已安装了存在签名冲突的同名数据包. 解决方法:打开Android Studio,打开logcat,用usb线连接你出错的手机,识别出手机之后,在你的项目后面,点击“run”按钮,随后AS会提 ...
- 通过网站统计或系统监视器查看IIS并发连接数
如果要查看IIS连接数,最简单方便的方法是通过“网站统计”来查看,“网站统计”的当前在线人数可以认为是当前IIS连接数;如果要想知道确切的当前网站IIS连接数的话,最有效的方法是通过windows自带 ...
- Exploit之初识Linux下缓冲区溢出
本文的目的不是为了介绍如何进行恶意的破坏性活动,而是为了教会你如何去防御此类破坏性活动,以帮助你扩大知识范围,完善自己的技能,如有读者运用本文所学技术从事破坏性活动,本人概不负责. 0×01 前言 1 ...
- SSH免密码远程登录Linux
1. 有A,B两台机(Linux/unix), 要想从A用ssh远程登录到B上(假设各自的IP,A:192.168.100:B:192.168.1.104). 2. 在A机上,用“ssh-keygen ...
- method swizzing
原理 类的方法类别中,选择子的名称通过映射表找到应该调用的方法.如下所示:  OC 的运行时提供了几个方法可以操作这张表.可以向其中新增选择子,改变选择子的实现,或者交换选择子映射到的指针.  在 ...
- 使用SUI框架下的<a>标签点击跳转页面不刷新的问题
最近写好了几个页面,今天试着将各个页面的链接打通,然后问题就来了...(╯︵╰) 这里看一下原来想要实现的两个页面跳转的效果--点击图一标注的栏目可以跳转到一个新的页面图二... 按照之前写a标签的跳 ...
- php-echo原理
1.语法分析 unticked_statement: | T_ECHO echo_expr_list ';' ; echo_expr_list: echo_expr_list TSRMLS_CC); ...
- SSH远程连接服务
一.SSH 原理图 二.SSH 原理描述 2.1:什么是SSH SSH是专门为了远程登录会话和其他网络服务提供的安全性协议,使用SSH协议可以有效的防止远程连接会话的时候出现信息泄密,在数据传输的时候 ...
- DIV居中的几种方法
1. body{ text-align:center; } 缺点:body内所有内容一并居中 2. .center{ position: fixed; left: 50%; } 缺点:需要设置posi ...