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文件配置一致