`
li_sir
  • 浏览: 114791 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

ssh使用oscache 做分布式缓存初篇

    博客分类:
  • java
 
阅读更多
依赖jar包:
jgroups-all.jar
concurrent.jar
oscache-2.1.jar
日志包等不一一列出。

hibernate使用oscache作为二级缓存,首先在hibernate配置二级缓存:
<property name="hibernateProperties">
			<props>
				<prop key="hibernate.show_sql">
					true
				</prop>
				<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
				<prop key="hibernate.jdbc.fetch_size">25</prop>
				<prop key="hibernate.jdbc.batch_size">50</prop>
				<prop key="hibernate.cache.use_query_cache">true</prop>
				<prop key="hibernate.connection.pool_size">50</prop>
				<prop key="hibernate.cache.provider_class">org.hibernate.cache.OSCacheProvider</prop>
				<prop key="hibernate.jdbc.use_scrollable_resultset">true</prop>
				<prop key="hibernate.generate_statistics">true</prop>
				<prop key="current_session_context_class">thread</prop>
				<prop key="hibernate.bytecode.provider">cglib</prop>
				<!--  <prop key="hibernate.default_schema">${jdbc.username}</prop>-->
			</props>
			</property>

使用JGroups(消息可靠)做为消息中间件。
在oscache.properties配置:
cache.memory=true
cache.event.listeners=com.opensymphony.oscache.plugins.clustersupport.JavaGroupsBroadcastingListener
 cache.algorithm=com.opensymphony.oscache.base.algorithm.LRUCache
cache.blocking=true
cache.capacity=10000
cache.cluster.properties=UDP(mcast_addr=231.12.21.132;mcast_port=45566;ip_ttl=32;\
mcast_send_buf_size=150000;mcast_recv_buf_size=80000):\
PING(timeout=2000;num_initial_members=3):\
MERGE2(min_interval=5000;max_interval=10000):\
FD_SOCK:VERIFY_SUSPECT(timeout=1500):\
pbcast.NAKACK(gc_lag=50;retransmit_timeout=300,600,1200,2400,4800;max_xmit_size=8192):\
UNICAST(timeout=300,600,1200,2400):\
pbcast.STABLE(desired_avg_gossip=20000):\
FRAG(frag_size=8096;down_thread=false;up_thread=false):\
pbcast.GMS(join_timeout=5000;join_retry_timeout=2000;shun=false;print_local_addr=true)
cache.cluster.multicast.ip=231.12.21.132


配置过程中遇到问题:
1、hibernate配置文件缓存如果配置为<cache usage="read-write"/>则发现缓存无法同步。
故需要设置为:nonstrict-read-write
2、concurrent.jar不能缺。
3、win7下出现failed to join /224.0.0.75:7500 on net5: java.net.SocketException: Unrecognized Windows Sockets error: 0: no Inet4Address associated with interface异常。
需要在jvm配置-Djava.net.preferIPv4Stack=true参数。
分享到:
评论

相关推荐

    SSH开发SSH开发SSH开发SSH开发

    - `oscache-2.3.jar`:OSCache是开源的缓存解决方案,可以提高应用性能,减少对数据库的访问。 - `mysql-connector-java-5.1.6-bin.jar`:MySQL的Java连接器,用于连接Java应用到MySQL数据库。 - `joddform.jar`...

    ssh 面试题 全面总结

    - **分布式缓存**:适合集群环境,如EhCache、OSCache等。 - **第三方缓存**:如使用Terracotta等。 #### 五、Hibernate的查询方式 1. **SQL**:直接使用SQL语句查询。 2. **Criteria API**:使用标准的Java接口...

    SSH面试题总结

    - **分布式缓存**:在多台服务器间共享的数据缓存。 - **条件**:使用二级缓存前需要考虑数据是否会由第三方修改、数据大小、更新频率等因素。 - **实现**:通常需要借助第三方缓存解决方案,如EhCache、OSCache...

    SSH面试题

    二级缓存可进一步分为本地缓存和分布式缓存,如EHCache或OSCache。 **查询方式**:除了SQL,Hibernate提供HQL(Hibernate Query Language)和Criteria API,支持属性查询、参数查询、关联查询、分页查询和统计函数...

    SSH 中jar包说明

    为了更好地理解和使用SSH框架,我们有必要深入解析这些框架中所涉及的关键Jar包及其功能。 #### 1. **antlr-2.76.jar** - **用途**:ANTLR(ANother Tool for Language Recognition)是一个强大的解析工具,主要...

    SSH三大框架笔试面试题

    - **分布式缓存:** 多个应用实例之间共享缓存。 - **第三方缓存实现:** 如EHCache、OSCache等。 #### 五、Hibernate的查询方式 - **SQL查询:** 直接使用SQL语句查询数据库。 - **HQL查询:** 使用Hibernate ...

    2012年最权威,最完整SSH面试题(Struts+Spring+Hibernate面试题问答23题,选择30题) 问答23题,选择30题(附答案)

    - **分布式缓存:** 在集群环境中使用的缓存机制。 - **第三方缓存实现:** 如 Ehcache、OSCache 等。 **使用条件:** - 数据不会被第三方修改。 - 数据大小在可接受范围内。 - 数据更新频率较低。 - 同一数据被...

    struts+spring+hibernate资料

    - **分布式缓存**:如 Redis、Memcached。 - **第三方缓存组件**:如 EhCache、OSCache。 使用二级缓存的条件: - 数据不会被第三方修改。 - 数据大小在可接受范围内。 - 数据更新频率较低。 - 同一数据被频繁访问...

    00.2、知识点1

    包括但不限于lua脚本、SSH shell、HBase分布式数据库、网络协议(TCP/IP、HTTP(S)、SNMP)、SOA服务导向架构、jQuery和Bootstrap前端框架、MongoDB文档型数据库、Netty高性能NIO框架、Oracle数据库维护、SSO单点登录...

    原创-java岗位技能与职业规划

    - **缓存**: oscache,ehcache,Memcached等。 - **调度**: Quartz,Java Timer Scheduler,Spring Scheduler。 - **连接池**: dbcp,c3p0等。 - **规则引擎**: jBoss Rules。 - **搜索引擎**: Lucene等。 - *...

Global site tag (gtag.js) - Google Analytics