X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fnetconf%2Fconfig-persister-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fnetconf%2Fpersist%2Fimpl%2FConfigPusher.java;h=3c968f8e2013423d4c405e1e95b8c4c711e5640e;hp=a47d6dd842e43a911891920cbf99317961080836;hb=07c30f447bd1366ba18e6f0f41ac768a16dbc901;hpb=07389b7beb8d85acd7739ccb1b27c5a1cf1a0ce7 diff --git a/opendaylight/netconf/config-persister-impl/src/main/java/org/opendaylight/controller/netconf/persist/impl/ConfigPusher.java b/opendaylight/netconf/config-persister-impl/src/main/java/org/opendaylight/controller/netconf/persist/impl/ConfigPusher.java index a47d6dd842..3c968f8e20 100644 --- a/opendaylight/netconf/config-persister-impl/src/main/java/org/opendaylight/controller/netconf/persist/impl/ConfigPusher.java +++ b/opendaylight/netconf/config-persister-impl/src/main/java/org/opendaylight/controller/netconf/persist/impl/ConfigPusher.java @@ -35,6 +35,7 @@ import java.util.Collections; import java.util.HashSet; import java.util.List; import java.util.Set; +import java.util.concurrent.TimeUnit; @Immutable public class ConfigPusher { @@ -45,20 +46,24 @@ public class ConfigPusher { private final InetSocketAddress address; private final EventLoopGroup nettyThreadgroup; - - public static final long DEFAULT_TIMEOUT = 120000L;// 120 seconds until netconf must be stable - private final long timeout; + // Default timeout for netconf becoming stable + public static final long DEFAULT_TIMEOUT = TimeUnit.MINUTES.toNanos(2); + private final int delayMillis = 5000; + private final long timeoutNanos; public ConfigPusher(InetSocketAddress address, EventLoopGroup nettyThreadgroup) { - this(address, DEFAULT_TIMEOUT, nettyThreadgroup); + this(address, nettyThreadgroup, DEFAULT_TIMEOUT); + } + @Deprecated + public ConfigPusher(InetSocketAddress address, long timeoutMillis, EventLoopGroup nettyThreadgroup) { + this(address, nettyThreadgroup, TimeUnit.MILLISECONDS.toNanos(timeoutMillis)); } - public ConfigPusher(InetSocketAddress address, long timeout, EventLoopGroup nettyThreadgroup) { + public ConfigPusher(InetSocketAddress address, EventLoopGroup nettyThreadgroup, long timeoutNanos) { this.address = address; - this.timeout = timeout; - this.nettyThreadgroup = nettyThreadgroup; + this.timeoutNanos = timeoutNanos; } public synchronized NetconfClient init(List configs) throws InterruptedException { @@ -67,7 +72,9 @@ public class ConfigPusher { } private synchronized NetconfClient pushAllConfigs(List configs) throws InterruptedException { + // first just make sure we can connect to netconf, even if nothing is being pushed NetconfClient netconfClient = makeNetconfConnection(Collections.emptySet(), Optional.absent()); + // start pushing snapshots: for (ConfigSnapshotHolder configSnapshotHolder: configs){ netconfClient = pushSnapshotWithRetries(configSnapshotHolder, Optional.of(netconfClient)); } @@ -101,59 +108,51 @@ public class ConfigPusher { /** * @param expectedCaps capabilities that server hello must contain. Will retry until all are found or throws RuntimeException. * If empty set is provided, will only make sure netconf client successfuly connected to the server. - * @param oldClientForPossibleReuse if present, try to get expected capabilities from it before closing it and retrying with - * new client connection. + * @param maybeOldClient if present, close it. * @return NetconfClient that has all required capabilities from server. */ private synchronized NetconfClient makeNetconfConnection(Set expectedCaps, - Optional oldClientForPossibleReuse) + Optional maybeOldClient) throws InterruptedException { - if (oldClientForPossibleReuse.isPresent()) { - NetconfClient oldClient = oldClientForPossibleReuse.get(); - if (Util.isSubset(oldClient, expectedCaps)) { - return oldClient; - } else { - Util.closeClientAndDispatcher(oldClient); - } + if (maybeOldClient.isPresent()) { + NetconfClient oldClient = maybeOldClient.get(); + Util.closeClientAndDispatcher(oldClient); } // TODO think about moving capability subset check to netconf client // could be utilized by integration tests - long pollingStart = System.currentTimeMillis(); - int delay = 5000; - + final long pollingStart = System.nanoTime(); + final long deadline = pollingStart + timeoutNanos; int attempt = 0; - long deadline = pollingStart + timeout; - String additionalHeader = NetconfMessageAdditionalHeader.toString("unknown", address.getAddress().getHostAddress(), Integer.toString(address.getPort()), "tcp", Optional.of("persister")); Set latestCapabilities = new HashSet<>(); - while (System.currentTimeMillis() < deadline) { + while (System.nanoTime() < deadline) { attempt++; NetconfClientDispatcher netconfClientDispatcher = new NetconfClientDispatcher(nettyThreadgroup, nettyThreadgroup, additionalHeader); NetconfClient netconfClient; try { - netconfClient = new NetconfClient(this.toString(), address, delay, netconfClientDispatcher); + netconfClient = new NetconfClient(this.toString(), address, delayMillis, netconfClientDispatcher); } catch (IllegalStateException e) { logger.debug("Netconf {} was not initialized or is not stable, attempt {}", address, attempt, e); netconfClientDispatcher.close(); - Thread.sleep(delay); + Thread.sleep(delayMillis); continue; } latestCapabilities = netconfClient.getCapabilities(); if (Util.isSubset(netconfClient, expectedCaps)) { logger.debug("Hello from netconf stable with {} capabilities", latestCapabilities); - logger.info("Session id received from netconf server: {}", netconfClient.getClientSession()); + logger.trace("Session id received from netconf server: {}", netconfClient.getClientSession()); return netconfClient; } logger.debug("Polling hello from netconf, attempt {}, capabilities {}", attempt, latestCapabilities); Util.closeClientAndDispatcher(netconfClient); - Thread.sleep(delay); + Thread.sleep(delayMillis); } Set allNotFound = new HashSet<>(expectedCaps); allNotFound.removeAll(latestCapabilities); @@ -167,7 +166,7 @@ public class ConfigPusher { throws ConflictingVersionException, IOException, SAXException { Element xmlToBePersisted = XmlUtil.readXmlToElement(configSnapshotHolder.getConfigSnapshot()); - logger.info("Pushing last configuration to netconf: {}", configSnapshotHolder); + logger.trace("Pushing last configuration to netconf: {}", configSnapshotHolder); StringBuilder response = new StringBuilder("editConfig response = {"); NetconfMessage message = createEditConfigMessage(xmlToBePersisted, "/netconfOp/editConfig.xml"); @@ -186,7 +185,7 @@ public class ConfigPusher { response.append("commit response = {"); response.append(XmlUtil.toString(responseMessage.getDocument())); response.append("}"); - logger.info("Last configuration loaded successfully"); + logger.trace("Last configuration loaded successfully"); logger.trace("Detailed message {}", response); }