ignite有两种配置方式,一种是基于XML文件的配置,一种是基于JAVA代码的配置:

这里将ignite常用的配置集中罗列出来了,一般建议使用xml配置。

1,基于XML的配置


<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:util="http://www.springframework.org/schema/util"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/util
http://www.springframework.org/schema/util/spring-util.xsd"> <bean id="igniteCfg" class="org.apache.ignite.configuration.IgniteConfiguration"> <!-- Consistent globally unique node identifier which survives node restarts. -->
<!-- 全局一致性id -->
<!--<property name="consistentId" value="cord"/>--> <!--Set to true to enable distributed class loading for examples, default is false. -->
<!-- 分布式计算class传播 -->
<property name="peerClassLoadingEnabled" value="true"/> <!-- Set deployment mode. -->
<!-- 部署模式,控制类加载. -->
<property name="deploymentMode" value="CONTINUOUS"/> <!-- Disable missed resources caching. -->
<!-- 禁用丢失资源缓存 -->
<property name="peerClassLoadingMissedResourcesCacheSize" value="0"/> <!-- 设为false表示服务端模式 -->
<property name="clientMode" value="false"/> <!-- Network timeout -->
<!-- 连接超时时间 -->
<property name="networkTimeout" value="10000" /> <!--Exclude force peer class loading of a class, even if exists locally.-->
<!-- 配置需要传播的class的路径 -->
<property name="peerClassLoadingLocalClassPathExclude">
<list>
<value>org.cord.*</value>
</list>
</property> <!-- 配置需要监听的事件类型-->
<property name="includeEventTypes">
<list>
<util:constant static-field="org.apache.ignite.events.EventType.EVT_CACHE_OBJECT_PUT"/>
<util:constant static-field="org.apache.ignite.events.EventType.EVT_CACHE_OBJECT_READ"/>
<util:constant static-field="org.apache.ignite.events.EventType.EVT_CACHE_OBJECT_REMOVED"/>
</list>
</property> <!-- Configure internal thread pool. -->
<!-- 公共线程池大小-->
<property name="publicThreadPoolSize" value="64"/> <!-- Configure system thread pool. -->
<!-- 系统线程池大小-->
<property name="systemThreadPoolSize" value="32"/> <property name="cacheConfiguration">
<list>
<bean class="org.apache.ignite.configuration.CacheConfiguration">
<!-- 缓存名-->
<property name="name" value="IGNITE_CACHE_KEY_PCOMM_RATE"/>
<!-- 原子模式类型,ATOMIC:原子型,保证性能; TRANSACTIONAL:事务型,分布式锁-->
<property name="atomicityMode" value="ATOMIC"/>
<!--PARTITIONED:分区; REPLICATED:复制;LOCAL:本地 -->
<property name="cacheMode" value="REPLICATED"/>
<!-- 备份数量-->
<property name="backups" value="1"/>
<!-- 禁用jcache标准中缓存读取获取的是副本的机制 -->
<property name="copyOnRead" value="false"/>
<!-- 内存区名-->
<property name="dataRegionName" value="Default_Region"/>
<!-- 是否以二进制形式存储-->
<!--<property name="storeKeepBinary" value="true"/>-->
<!-- 索引类型-->
<property name="indexedTypes">
<list>
<value>java.lang.Long</value>
<value>com.palic.demo.data.domain.CommRate</value>
</list>
</property>
</bean>
</list>
</property> <!-- Redefining maximum memory size for the cluster node usage. -->
<property name="dataStorageConfiguration">
<bean class="org.apache.ignite.configuration.DataStorageConfiguration">
<!-- Redefining the default region's settings -->
<!-- 默认存储区间配置-->
<property name="defaultDataRegionConfiguration">
<bean class="org.apache.ignite.configuration.DataRegionConfiguration">
<!-- 存储区名-->
<property name="name" value="Default_Region"/>
<!-- 存储区大小-->
<!-- Setting the size of the default region to 1GB. -->
<!--<property name="maxSize" value="#{1L * 1024 * 1024 * 1024}"/>-->
<property name="maxSize" value="#{512 * 1024 * 1024}"/>
<!-- 是否开启持久化-->
<!-- Enabling Apache Ignite Persistent Store. -->
<!--<property name="persistenceEnabled" value="true"/>-->
</bean>
</property>
<property name="dataRegionConfigurations">
<list>
<!-- 自定义内存区-->
<!--
Defining a data region that will consume up to 500 MB of RAM and
will have eviction and persistence enabled.
-->
<bean class="org.apache.ignite.configuration.DataRegionConfiguration">
<!-- Custom region name. -->
<property name="name" value="500MB_Region"/>
<!-- 100 MB initial size. -->
<property name="initialSize" value="#{100L * 1024 * 1024}"/>
<!-- 500 MB maximum size. -->
<property name="maxSize" value="#{500L * 1024 * 1024}"/>
<!-- Enabling persistence for the region. -->
<!--<property name="persistenceEnabled" value="true"/>-->
</bean>
</list>
</property> <!-- 预写日志模式-->
<!-- Sets property that defines behavior of wal fsync. -->
<!--<property name="walMode">-->
<!--<util:constant static-field="org.apache.ignite.configuration.WALMode.DEFAULT"/>-->
<!--</property>-->
<property name="walMode" value="DEFAULT"/> <!-- 检查点频率-->
<!--Checkpointing frequency which is a minimal interval when the dirty pages will be written to the Persistent Store.-->
<property name="checkpointFrequency" value="180000"/>
<!--<property name="checkpointFrequency" value="10000"/>--> <!-- 检查点线程数-->
<!-- Number of threads for checkpointing.-->
<property name="checkpointThreads" value="4"/> <!-- 在检查点同步完成后预写日志历史保留数量 -->
<!-- Number of checkpoints to be kept in WAL after checkpoint is finished.-->
<property name="walHistorySize" value="20"/>
<!--<property name="walHistorySize" value="2"/>--> <!-- 持久化文件路径 -->
<!--&lt;!&ndash; Path where data and indexes will be persisted. &ndash;&gt;-->
<!--<property name="storagePath" value="D:\\Test\\db" />--> <!--&lt;!&ndash; Path to the directory where WAL (Write Ahead Log) is stored. &ndash;&gt;-->
<!--<property name="walPath" value="D:\\Test\\db\\wal" />--> <!--&lt;!&ndash; Path to the directory where WAL (Write Ahead Log) archive is stored. &ndash;&gt;-->
<!--<property name="walArchivePath" value="D:\\Test\\db\\wal\\archive" />--> </bean>
</property> <property name="discoverySpi">
<bean class="org.apache.ignite.spi.discovery.tcp.TcpDiscoverySpi">
<property name="localPort" value="48500"/>
<property name="localPortRange" value="20"/>
<property name="joinTimeout" value="0"/>
<property name="networkTimeout" value="5000" />
<property name="ipFinder">
<bean class="org.apache.ignite.spi.discovery.tcp.ipfinder.vm.TcpDiscoveryVmIpFinder">
<property name="addresses">
<!-- 集群ip列表-->
<list>
<value>127.0.0.1:48500..48520</value>
</list>
</property>
</bean>
</property>
</bean>
</property>
<property name="communicationSpi">
<bean class="org.apache.ignite.spi.communication.tcp.TcpCommunicationSpi">
<property name="localPort" value="48100"/>
</bean>
</property>
</bean>
</beans>

基于此XML配置启动ignite节点的方式如下:

@Configuration
public class IgniteConfig {
@Autowired
private IgniteConfiguration igniteCfg; @Bean
@ConditionalOnMissingBean
public Ignite initIgnite() {
//推荐借助spring bean的方式注入ignite配置信息,只需要将配置xml文件import即可
//启动类加上注解@ImportResource(locations={"classpath:default-config.xml"})
Ignite ignite = Ignition.start(igniteCfg);
//Ignite ignite = Ignition.start(classpath:default-config.xml)
}
}

2,基于JAVA代码的配置

......
IgniteConfiguration cfg = new IgniteConfiguration();
cfg.setClientMode(false);
//配置集群发现
cfg.setDiscoverySpi(new TcpDiscoverySpi().setLocalPort(48500).setLocalPortRange(20)
.setIpFinder(new TcpDiscoveryVmIpFinder().setAddresses(Arrays.asList("127.0.0.1:48500..48520"))));
//基本配置
cfg.setCommunicationSpi(new TcpCommunicationSpi().setLocalPort(48100));
cfg.setDeploymentMode(CONTINUOUS);
cfg.setPeerClassLoadingEnabled(true);
cfg.setPeerClassLoadingLocalClassPathExclude("com.org.ignite.*");
cfg.setIncludeEventTypes(EventType.EVT_TASK_STARTED, EventType.EVT_TASK_FINISHED, EventType.EVT_TASK_FAILED);
cfg.setPublicThreadPoolSize(64);
cfg.setSystemThreadPoolSize(32);
//添加cache配置
List<CacheConfiguration> cacheConf = new ArrayList<>();
CacheConfiguration<String, Integer> conf = new CacheConfiguration<String, Integer>("test")
.setCacheMode(CacheMode.REPLICATED)
.setIndexedTypes(String.class, Integer.class)
.setAtomicityMode(CacheAtomicityMode.ATOMIC)
.setCopyOnRead(false)
.setBackups(1);
cacheConf.add(conf);
cfg.setCacheConfiguration(cacheConf.toArray(new CacheConfiguration[]{})); //基于java代码配置启动
Ignition.start(cfg);
......

一般建议基于XML配置,spring bean注入,如果确实需要JAVA配置,可以结合XML配置灵活处理。

​ 在ignite集群中,配置信息是可以动态传播的,而如果是修改配置文件,则需要重启节点才可生效,并且如果有些关键配置不一致,也会导致启动节点报错,无法加入集群。所以最好的做法是,在普通节点中只配置节点相关配置,以及集群发现配置,至于变动性最大的缓存cache配置,可以由应用节点配置,这样便于的集中管控缓存配置。除此之外,使用xml配置,可以保证普通节点与应用节点的配置的一致性,而不需要单独再维护一套代码配置。

apache ignite系列(二):配置的更多相关文章

  1. apache ignite系列(九):ignite调优

    1,配置文件调优 1.1 设置页面大小(pagesize) 先查看系统pagesiz,使用PAGE_SIZE或者PAGESIZE # getconf PAGE_SIZE 4096 # getconf ...

  2. apache ignite系列(九):使用ddl和dml脚本初始化ignite并使用mybatis查询缓存

    博客又断了一段时间,本篇将记录一下基于ignite对jdbc支持的特性在实际使用过程中的使用. 使用ddl和dml脚本初始化ignite 由于spring-boot中支持通过spring.dataso ...

  3. apache ignite系列(八):问题汇总

    1,java.lang.ClassNotFoundException Unknown pair 1.Please try to turn on isStoreKeepBinary in cache s ...

  4. apache ignite系列(六): 服务网格

    简介 ​ 服务网格本质上还是远程方法调用(RPC),而在ignite中注册的服务本质体现还是以cache的形式存在,集群中的节点可以相互调用部署在其它节点上的服务,而且ignite集群会负责部署服务的 ...

  5. apache ignite系列(四):持久化

    ignite持久化与固化内存 1.持久化的机制 ignite持久化的关键点如下: ignite持久化可防止内存溢出导致数据丢失的情况: 持久化可以定制化配置,按需持久化; 持久化能解决在大量缓存数据情 ...

  6. apache ignite系列(三):数据处理(数据加载,数据并置,数据查询)

    ​ 使用ignite的一个常见思路就是将现有的关系型数据库中的数据导入到ignite中,然后直接使用ignite中的数据,相当于将ignite作为一个缓存服务,当然ignite的功能远不止于此,下面以 ...

  7. apache ignite系列(一): 简介

    apache-ignite简介(一) 1,简介 ​ ignite是分布式内存网格的一种实现,其基于java平台,具有可持久化,分布式事务,分布式计算等特点,此外还支持丰富的键值存储以及SQL语法(基于 ...

  8. apache ignite系列(五):分布式计算

    ignite分布式计算 在ignite中,有传统的MapReduce模型的分布式计算,也有基于分布式存储的并置计算,当数据分散到不同的节点上时,根据提供的并置键,计算会传播到数据所在的节点进行计算,再 ...

  9. 深入浅出Mybatis系列二-配置简介(mybatis源码篇)

    注:本文转载自南轲梦 注:博主 Chloneda:个人博客 | 博客园 | Github | Gitee | 知乎 上篇文章<深入浅出Mybatis系列(一)---Mybatis入门>, ...

随机推荐

  1. Consul的反熵

    熵 熵是衡量某个体系中事物混乱程度的一个指标,是从热力学第二定律借鉴过来的. 熵增原理 孤立系统的熵永不自动减少,熵在可逆过程中不变,在不可逆过程中增加.熵增加原理是热力学第二定律的又一种表述,它更为 ...

  2. 深度搜索(dfs)+典型例题(八皇后)

    深度优先搜索简称深搜,从起点出发,走过的点要做标记,发现有没走过的点,就随意挑一个往前走,走不了就回退,此种路径搜索策略就称为“深度优先搜索”,简称“深搜”. 如上面的图所示:加入我们要找一个从V0到 ...

  3. Yii 三表关联 角色表、角色权限连接表、权限表

    Yii 三表关联 角色表.角色权限连接表.权限表 角色表 role----------------id 唯一序号name 角色名称---------------- 角色权限连接表 lp-------- ...

  4. (18)ASP.NET Core 基于现有数据库创建EF模型(反向工程)

    1.简介 Entity Framework Core可通过数据库提供给应用程序的插件访问许多不同的数据库.我们可以通过使用Entity Framework Core构建执行基本数据访问的ASP.NET ...

  5. spring-boot-plus项目配置文件(四)

    spring-boot-plus项目配置文件 配置文件说明 配置说明 项目中配置文件主要使用yml格式 配置文件位置:spring-boot-plus\src\main\resources\confi ...

  6. Python爬虫(一)抓取指定的页面

    (以下是在windows环境下的操作,python版本为3) 1.urllib库介绍 官方文档上的解释是: urllib is a package that collects several modu ...

  7. Django--路由层、伪静态页面、虚拟环境、视图层

    路由层: 在路由匹配的时候,第一个参数是一个正则表达式,这也就意味着在路由匹配的时候按照正则匹配的规则去匹配,路由匹配的顺序是从上往下依次匹配的,只要匹配到一个,就会执行对应的函数,就不会执行下面的函 ...

  8. python 31 升级版解决粘包现象

    目录 1. recv 工作原理 2.升级版解决粘包问题 3. 基于UDP协议的socket通信 1. recv 工作原理 1.能够接收来自socket缓冲区的字节数据: 2.当缓冲区没有数据可以读取时 ...

  9. python 18 re模块

    目录 re 模块 1. 正则表达式 2. 匹配模式 3. 常用方法 re 模块 1. 正则表达式 \w 匹配字母(包含中文)或数字或下划线 \W 匹配非字母(包含中文)或数字或下划线 \s 匹配任意的 ...

  10. Codeforces 976F

    题意略. 思路:为了保证每个点都有至少k条边覆盖,我们可以让二分图的左半边与源点s相连,连容量为indegree[i] - k的边(如果正着想不好想,我们可以想它的反面, 限制它反面的上限,从而保证我 ...