2 * Copyright (c) 2016 Brocade Communications Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.ovsdb.southbound.reconciliation.connection;
10 import java.net.UnknownHostException;
11 import java.util.concurrent.atomic.AtomicInteger;
12 import org.opendaylight.ovsdb.lib.OvsdbClient;
13 import org.opendaylight.ovsdb.southbound.OvsdbConnectionManager;
14 import org.opendaylight.ovsdb.southbound.reconciliation.ReconciliationManager;
15 import org.opendaylight.ovsdb.southbound.reconciliation.ReconciliationTask;
16 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.OvsdbNodeAugmentation;
17 import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.network.topology.topology.Node;
18 import org.opendaylight.yangtools.yang.binding.DataObject;
19 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
20 import org.slf4j.Logger;
21 import org.slf4j.LoggerFactory;
23 public class ConnectionReconciliationTask extends ReconciliationTask {
25 private static final Logger LOG = LoggerFactory.getLogger(ConnectionReconciliationTask.class);
27 private static final int RETRY_INTERVAL_FACTOR = 10000;
28 private static final int MAX_ATTEMPT = 10;
30 private AtomicInteger connectionAttempt = new AtomicInteger(0);
32 public ConnectionReconciliationTask(ReconciliationManager reconciliationManager, OvsdbConnectionManager
33 connectionManager, InstanceIdentifier<?> nodeIid, DataObject configData) {
34 super(reconciliationManager, connectionManager, nodeIid, configData);
39 public boolean reconcileConfiguration(OvsdbConnectionManager connectionManager) {
40 boolean result = false;
41 connectionAttempt.incrementAndGet();
42 InstanceIdentifier<Node> ndIid = (InstanceIdentifier<Node>) nodeIid;
43 OvsdbNodeAugmentation ovsdbNode = (OvsdbNodeAugmentation)configData;
45 LOG.info("Retry({}) connection to Ovsdb Node {} ", connectionAttempt.get(), ovsdbNode.getConnectionInfo());
46 OvsdbClient client = null;
48 client = connectionManager.connect(ndIid, ovsdbNode);
50 LOG.info("Successfully connected to Ovsdb Node {} ", ovsdbNode.getConnectionInfo());
53 LOG.warn("Connection retry({}) failed for {}.",
54 connectionAttempt.get(), ovsdbNode.getConnectionInfo());
56 } catch (UnknownHostException e) {
57 LOG.warn("Connection retry({}) failed with exception. ",connectionAttempt.get(), e);
63 public void doRetry(boolean wasLastAttemptSuccessful) {
65 if (!wasLastAttemptSuccessful && connectionAttempt.get() <= MAX_ATTEMPT) {
66 reconciliationManager.enqueueForRetry(ConnectionReconciliationTask.this);
68 reconciliationManager.dequeue(this);
73 public void checkReadinessAndProcess() {
74 reconciliationManager.enqueue(this);
78 public long retryDelayInMills() {
79 return connectionAttempt.get() * RETRY_INTERVAL_FACTOR;