spring boot 2.1.4 缓存 Hazelcast实现(四)

hazelcast.xml文件可以拆分成多个,并且在hazelcast.xml文件中默认可以从系统配置项读取配置属性,这里转成在spring配置文件中配置

private static final String GROUP_NAME = "group.name";
	private static final String MANAGERMENT_CENTER = "spring.cache.management-center";

	private void setCacheProperty() {
		String applicationName = environment.getProperty("spring.application.name", "");
		Assert.hasLength(applicationName, "配置项:spring.application.name不能为空");
		System.setProperty(GROUP_NAME, applicationName);
		String centerUrl = environment.getProperty(MANAGERMENT_CENTER, "");
		System.setProperty(MANAGERMENT_CENTER, centerUrl);
		System.setProperty(MANAGERMENT_CENTER + ".enable", StringUtils.isNotEmpty(centerUrl) + "");
	}

hazelcast.xml文件中使用

<group>
        <name>${group.name}</name>
    </group>
    <management-center enabled="${spring.cache.management-center.enable}">${spring.cache.management-center}</management-center>
    <import resource="network-config.xml"/>
    <import resource="cache-config.xml"/>

 

nework-config.xml文件单独提取出来方便分布式配置,这里单机都没有启用

<?xml version="1.0" encoding="UTF-8"?>
<hazelcast xmlns="http://www.hazelcast.com/schema/config"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xsi:schemaLocation="http://www.hazelcast.com/schema/config
           http://www.hazelcast.com/schema/config/hazelcast-config-3.11.xsd">
	<network>
		<port auto-increment="true" port-count="100">5701</port>
		<outbound-ports>
            <!--
            Allowed port range when connecting to other nodes.
            0 or * means use system provided port.
            -->
            <ports>0</ports>
        </outbound-ports>
		<join>
			<multicast enabled="false">
				<multicast-group>224.2.2.3</multicast-group>
				<multicast-port>54327</multicast-port>
			</multicast>
			<tcp-ip enabled="false">
				<interface>127.0.0.1</interface>
				<member-list>
					<member>127.0.0.1</member>
				</member-list>
			</tcp-ip>
		</join>
	</network>
</hazelcast>

 

cache-config缓存配置比较常用,也单独提取出来

<?xml version="1.0" encoding="UTF-8"?>
<hazelcast xmlns="http://www.hazelcast.com/schema/config"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://www.hazelcast.com/schema/config
           http://www.hazelcast.com/schema/config/hazelcast-config-3.11.xsd">
	<cache name="default">
		<key-type class-name="java.lang.Object" />
		<value-type class-name="java.lang.Object" />
		<statistics-enabled>true</statistics-enabled>
		<management-enabled>true</management-enabled>
		<read-through>true</read-through>
		<write-through>true</write-through>
		<backup-count>1</backup-count>
		<async-backup-count>1</async-backup-count>
		<in-memory-format>BINARY</in-memory-format>
		<eviction size="10000" max-size-policy="ENTRY_COUNT"
			eviction-policy="LRU" />
		<quorum-ref>quorum-name</quorum-ref>
		<disable-per-entry-invalidation-events>true
		</disable-per-entry-invalidation-events>
		<!-- 
		<cache-loader-factory class-name="com.example.cache.MyCacheLoaderFactory" />
		<cache-writer-factory class-name="com.example.cache.MyCacheWriterFactory" />
		<expiry-policy-factory class-name="com.example.cache.MyExpiryPolicyFactory" />
		<cache-entry-listeners>
			<cache-entry-listener old-value-required="false"
				synchronous="false">
				<cache-entry-listener-factory
					class-name="com.example.cache.MyEntryListenerFactory" />
				<cache-entry-event-filter-factory
					class-name="com.example.cache.MyEntryEventFilterFactory" />
			</cache-entry-listener>
		</cache-entry-listeners> 
		-->
	</cache>
</hazelcast>

 

其他的配置项跟hazelcast的jar包中hazelcast-default.xml文件配置一致

转载于:https://my.oschina.net/u/1428688/blog/3064003

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值