/* * Licensed to the Apache Software Foundation (ASF) under one or more contributor license * agreements. See the NOTICE file distributed with this work for additional information regarding * copyright ownership. The ASF licenses this file to You under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance with the License. You may obtain a * copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software distributed under the License * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express * or implied. See the License for the specific language governing permissions and limitations under * the License. */ package com.main; import org.apache.geode.cache.Cache; import org.apache.geode.cache.CacheFactory; import org.apache.geode.cache.Region; import org.apache.geode.cache.wan.GatewaySender; import org.apache.geode.distributed.internal.DistributionConfig; import java.util.Set; import static org.apache.geode.distributed.ConfigurationProperties.*; /** * 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.) * * */ public class WANBootStrapping_Site1_Add { public static void main(String[] args) { System.setProperty(DistributionConfig.GEMFIRE_PREFIX + "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(MCAST_PORT, "0").set(DISTRIBUTED_SYSTEM_ID, "" + 1) .set(LOCATORS, "localhost[" + 10101 + "]") .set(START_LOCATOR, "localhost[" + 10101 + "],server=true,peer=true,hostname-for-clients=localhost") .set(LOG_LEVEL, "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); } }