Created
November 17, 2017 15:00
-
-
Save Romeh/9200b77bb727cdb9d6de767ef9c2ce87 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
@Configuration | |
public class AlertManagerConfiguration { | |
@Value("${mail.service.baseUrl}") | |
private String baseUrl; | |
@Value("${mail.service.user}") | |
private String user; | |
@Value("${mail.service.password}") | |
private String password; | |
@Value("${enableFilePersistence}") | |
private boolean enableFilePersistence; | |
@Value("${igniteConnectorPort}") | |
private int igniteConnectorPort; | |
@Value("${igniteServerPortRange}") | |
private String igniteServerPortRange; | |
@Value("${ignitePersistenceFilePath}") | |
private String ignitePersistenceFilePath; | |
@Bean | |
IgniteConfiguration igniteConfiguration() { | |
IgniteConfiguration igniteConfiguration = new IgniteConfiguration(); | |
igniteConfiguration.setClientMode(false); | |
// durable file memory persistence | |
if(enableFilePersistence){ | |
PersistentStoreConfiguration persistentStoreConfiguration = new PersistentStoreConfiguration(); | |
persistentStoreConfiguration.setPersistentStorePath("./data/store"); | |
persistentStoreConfiguration.setWalArchivePath("./data/walArchive"); | |
persistentStoreConfiguration.setWalStorePath("./data/walStore"); | |
igniteConfiguration.setPersistentStoreConfiguration(persistentStoreConfiguration); | |
} | |
// connector configuration | |
ConnectorConfiguration connectorConfiguration=new ConnectorConfiguration(); | |
connectorConfiguration.setPort(igniteConnectorPort); | |
// common ignite configuration | |
igniteConfiguration.setMetricsLogFrequency(0); | |
igniteConfiguration.setQueryThreadPoolSize(2); | |
igniteConfiguration.setDataStreamerThreadPoolSize(1); | |
igniteConfiguration.setManagementThreadPoolSize(2); | |
igniteConfiguration.setPublicThreadPoolSize(2); | |
igniteConfiguration.setSystemThreadPoolSize(2); | |
igniteConfiguration.setRebalanceThreadPoolSize(1); | |
igniteConfiguration.setAsyncCallbackPoolSize(2); | |
igniteConfiguration.setPeerClassLoadingEnabled(false); | |
igniteConfiguration.setIgniteInstanceName("alertsGrid"); | |
BinaryConfiguration binaryConfiguration = new BinaryConfiguration(); | |
binaryConfiguration.setCompactFooter(false); | |
igniteConfiguration.setBinaryConfiguration(binaryConfiguration); | |
// cluster tcp configuration | |
TcpDiscoverySpi tcpDiscoverySpi=new TcpDiscoverySpi(); | |
TcpDiscoveryVmIpFinder tcpDiscoveryVmIpFinder=new TcpDiscoveryVmIpFinder(); | |
// need to be changed when it come to real cluster | |
tcpDiscoveryVmIpFinder.setAddresses(Arrays.asList("127.0.0.1:47500..47509")); | |
tcpDiscoverySpi.setIpFinder(tcpDiscoveryVmIpFinder); | |
igniteConfiguration.setDiscoverySpi(new TcpDiscoverySpi()); | |
// cache configuration | |
CacheConfiguration alerts=new CacheConfiguration(); | |
alerts.setCopyOnRead(false); | |
// as we have one node for now | |
alerts.setBackups(0); | |
alerts.setAtomicityMode(CacheAtomicityMode.ATOMIC); | |
alerts.setName("Alerts"); | |
alerts.setIndexedTypes(String.class,AlertEntry.class); | |
CacheConfiguration alertsConfig=new CacheConfiguration(); | |
alertsConfig.setCopyOnRead(false); | |
// as we have one node for now | |
alertsConfig.setBackups(0); | |
alertsConfig.setAtomicityMode(CacheAtomicityMode.ATOMIC); | |
alertsConfig.setName("AlertsConfig"); | |
alertsConfig.setIndexedTypes(String.class,AlertConfigEntry.class); | |
igniteConfiguration.setCacheConfiguration(alerts,alertsConfig); | |
return igniteConfiguration; | |
} | |
@Bean(destroyMethod = "close") | |
Ignite ignite(IgniteConfiguration igniteConfiguration) throws IgniteException { | |
final Ignite start = Ignition.start(igniteConfiguration); | |
start.active(true); | |
return start; | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment