blob: ef48cc5342d16bd2c0d9ce73341157f3d0893580 [file] [log] [blame]
/*=========================================================================
* Copyright (c) 2010-2014 Pivotal Software, Inc. All Rights Reserved.
* This product is protected by U.S. and international copyright
* and intellectual property laws. Pivotal products are covered by
* one or more patents listed at http://www.pivotal.io/patents.
*=========================================================================
*/
package com.main;
import java.util.List;
import java.util.Set;
import com.gemstone.gemfire.cache.Cache;
import com.gemstone.gemfire.cache.CacheFactory;
import com.gemstone.gemfire.cache.Region;
import com.gemstone.gemfire.cache.wan.GatewaySender;
import com.gemstone.gemfire.distributed.internal.DistributionConfig;
/**
* This is a member representing site 1 who wants to send data to site 2
*
* On this member a locator with distributed-system-id = 1 is created. On this
* member a cache is created.
*
* A Region and a GatewaySender is created on this member through
* MyDistributedSustemListener#addedDistributedSystemConnection
* (When a remote locator with distributed-system-id = 2 connects to this site,
* MyDistributedSustemListener's addedDistributedSystemConnection will be
* invoked who will create a region and a GatewaySender.)
*
* This member does put for 100 keys on the region. (We have to check that this
* data for 100 entries are sent to remote site)
*
* This member also check for the sender's running status.
*
* A GatewaySender will be stopped through
* MyDistributedSustemListener#removedDistributedSystem
* (When a remote locator with distributed-system-id = -2 connects to this site,
* MyDistributedSustemListener's removedDistributedSystem will be invoked who
* will stop a GatewaySender.)
*
* @author kbachhav
*
*/
public class WANBootStrapping_Site1_Add {
public static void main(String[] args) {
System.setProperty("gemfire.DistributedSystemListener",
"com.main.MyDistributedSystemListener");
// Create a locator and a cache
System.out.println("Creating cache ...It will take some time..");
Cache cache = new CacheFactory().set(DistributionConfig.MCAST_PORT_NAME,
"0").set(DistributionConfig.DISTRIBUTED_SYSTEM_ID_NAME, "" + 1).set(
DistributionConfig.LOCATORS_NAME, "localhost[" + 10101 + "]").set(
DistributionConfig.START_LOCATOR_NAME,
"localhost[" + 10101
+ "],server=true,peer=true,hostname-for-clients=localhost").set(
DistributionConfig.LOG_LEVEL_NAME, "warning").create();
System.out.println("Cache Created");
// to create region and a gateway sender ask to run
// WANBootStrapping_Site2_Add program
System.out.println("Run WANBootStrapping_Site2_Add");
// get the region
Region region = cache.getRegion("MyRegion");
while (region == null) {
region = cache.getRegion("MyRegion");
try {
Thread.sleep(5000);
}
catch (InterruptedException e) {
e.printStackTrace();
}
}
// put data in region
for (int i = 0; i < 100; i++) {
System.out.println("Create Entry : key_" + i + ", value_" + i);
region.put("key_" + i, "value_" + i);
}
System.out.println("Entry Create Operation completed");
Set<GatewaySender> gatewaySenders = cache.getGatewaySenders();
GatewaySender sender = gatewaySenders.iterator().next();
// make sure that gateway sender is running
if (sender.isRunning()) {
System.out.println("Sender " + sender.getId() + " is running");
}
// to stop gateway sender ask to run WANBootStrapping_Site2_Remove program
while (sender.isRunning()) {
System.out
.println("Waitng for sender to stop through DistributedSystemListener");
System.out.println("Start WANBootStrapping_Site2_Remove");
try {
Thread.sleep(5000);
}
catch (InterruptedException e) {
e.printStackTrace();
}
}
System.out.println("Sender " + sender.getId() + " is stopped");
System.exit(0);
}
}