<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 495,comments - 227,trackbacks - 0
    http://m.tkk7.com/AllanZ/archive/2013/02/22/cache-hazelcast.html

    做去皮兒網(wǎng)(http://www.qupier.com),內(nèi)容管理是一個 系統(tǒng),前端網(wǎng)站是一個系統(tǒng),這兩個系統(tǒng)之間獨立部署,但是緩存要能夠互通。例如后臺修改了某個消息類型的說明,在前段網(wǎng)站上要能夠展現(xiàn)出來(使用了 hibernate的查詢緩存)。其他的一些場景也許要緩存,例如網(wǎng)站的shiro權(quán)限信息緩存,不過這個不需要和后端系統(tǒng)互通。但是既然開搞,也不好意 思再掛著ehcache。于是一并升級。

    前面一篇日志各種碰壁后,終于找到了理論上能夠?qū)崿F(xiàn)功能的兩個產(chǎn)品:gemfire和hazelcast。于是,開始嘗試。

    首先是gemfire,有l(wèi)ocator等概念。官方也看到了gemfire-hibernate模塊。但是很奇怪,各種配置各種報錯。

    然后前面一篇日志的評論里面網(wǎng)友@吳勇智提到了hazelcast。所以也來試試。結(jié)果出奇的順利。記錄一下過程。

    1.下載、運(yùn)行hazelcast

    下載后隨便解壓,其實直接執(zhí)行bin/server.bat即可。但是為了能夠眼見為實,于是首先把包中的mancenter.war找了個tomcat部署起來,然后修改bin/hazelcast.xml,把
    management-center打開。并指向剛部署的mancenter訪問路徑。然后再啟動hazelcast服務(wù):bin/server.bat。

    2.hibernate二級緩存和查詢緩存

    我用spring結(jié)合hibernate使用,但是沒有用jpa。最后配置如下:

     1 <bean id="sessionFactory"
     2         class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
     3         <property name="dataSource">
     4             <ref bean="dataSource" />
     5         </property>
     6         <property name="packagesToScan">
     7             <list>
     8                 <value>com.my.**.model</value>
     9             </list>
    10         </property>
    11         <property name="hibernateProperties">
    12             <props>
    13                 <prop key="hibernate.dialect">${hibernate.dialect}</prop>
    14                 <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
    15                 <prop key="hibernate.jdbc.fetch_size">${hibernate.jdbc.fetch_size}</prop>
    16                 <prop key="hibernate.jdbc.batch_size">${hibernate.jdbc.batch_size}</prop>
    17                 <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>
    18                 <prop key="hibernate.cache.use_second_level_cache">${hibernate.cache.use_second_level_cache}</prop>
    19                 <prop key="hibernate.cache.use_query_cache">${hibernate.cache.use_query_cache}</prop>
    20                 <prop key="hibernate.validator.autoregister_listeners">${hibernate.validator.autoregister_listeners}</prop>
    21                 <prop key="hibernate.validator.apply_to_ddl">${hibernate.validator.apply_to_ddl}</prop>
    22                 <prop key="javax.persistence.validation.mode">${javax.persistence.validation.mode}</prop>
    23         
    24                 <prop key="hibernate.cache.region.factory_class">${hibernate.cache.region.factory_class}</prop>
    25                 <prop key="hibernate.cache.use_minimal_puts">${hibernate.cache.use_minimal_puts}</prop>
    26                 <prop key="hibernate.cache.hazelcast.use_native_client">${hibernate.cache.hazelcast.use_native_client}</prop>
    27                 <prop key="hibernate.cache.hazelcast.native_client_address">${hibernate.cache.hazelcast.native_client_address}</prop>
    28                 <prop key="hibernate.cache.hazelcast.native_client_group">${hibernate.cache.hazelcast.native_client_group}</prop>
    29                 <prop key="hibernate.cache.hazelcast.native_client_password">${hibernate.cache.hazelcast.native_client_password}</prop>
    30             </props>
    31         </property>
    32     </bean>

    然后是properties配置文件:

     1 hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect
     2 hibernate.show_sql=true
     3 hibernate.jdbc.fetch_size=25
     4 hibernate.jdbc.batch_size=30
     5 hibernate.hbm2ddl.auto=update
     6 hibernate.cache.region.factory_class=com.hazelcast.hibernate.HazelcastCacheRegionFactory
     7 hibernate.cache.use_query_cache=true
     8 hibernate.cache.use_second_level_cache=true
     9 
    10 hibernate.validator.autoregister_listeners=false
    11 hibernate.validator.apply_to_ddl=false
    12 javax.persistence.validation.mode=none
    13 
    14 hibernate.cache.use_minimal_puts=true
    15 hibernate.cache.hazelcast.use_native_client=true
    16 hibernate.cache.hazelcast.native_client_address=localhost
    17 hibernate.cache.hazelcast.native_client_group=dev
    18 hibernate.cache.hazelcast.native_client_password=dev-pass

    然后就OK了。

    另外封裝了一個可以直接使用的cache。內(nèi)部調(diào)用hazelcast。不同的cache region就簡單的使用了hazelcast的map。

    折騰了幾天,總算告一段落。
    posted on 2013-02-22 17:43 SIMONE 閱讀(2891) 評論(0)  編輯  收藏

    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 亚洲A∨无码一区二区三区| 亚洲无码精品浪潮| 中文字幕亚洲综合精品一区| 国产在线观a免费观看| 亚洲精品无码成人AAA片| 中文字幕视频免费在线观看| 中文字幕亚洲不卡在线亚瑟| a级毛片免费网站| 美腿丝袜亚洲综合| 女人隐私秘视频黄www免费| 国产亚洲综合一区柠檬导航| 最新国产乱人伦偷精品免费网站| 亚洲va国产va天堂va久久| 久久99青青精品免费观看| 337p日本欧洲亚洲大胆精品555588| 99爱在线精品视频免费观看9| 亚洲老熟女@TubeumTV| 97人伦色伦成人免费视频| 久久久久久亚洲av无码蜜芽| 国产一区二区三区在线免费| 一区二区三区免费看| 亚洲AV无码国产精品色午友在线 | 亚洲人成小说网站色| 麻豆国产精品入口免费观看| 无码AV动漫精品一区二区免费| 在线亚洲精品福利网址导航| 免费无码一区二区三区| 日韩亚洲人成在线| 亚洲人成无码久久电影网站| 日韩精品免费在线视频| 成人亚洲国产va天堂| 久久久久亚洲AV成人网| 免费AA片少妇人AA片直播| 青草青草视频2免费观看| 亚洲国产精品高清久久久| 日韩精品福利片午夜免费观着| 国产精品亚洲精品爽爽| 亚洲AV无码久久| 日日AV拍夜夜添久久免费| 免费人成在线观看网站| 久久亚洲精品无码网站|