mirror of
https://github.com/Qortal/altcoinj.git
synced 2025-07-30 03:21:23 +00:00
PeerGroup: Don't stop peer discovery if one peer discoverer throws an exception.
This commit is contained in:
committed by
Andreas Schildbach
parent
a9b40c358f
commit
76f6f0c21f
@@ -460,11 +460,7 @@ public class PeerGroup implements TransactionBroadcaster {
|
||||
// Don't hold the lock across discovery as this process can be very slow.
|
||||
boolean discoverySuccess = false;
|
||||
if (doDiscovery) {
|
||||
try {
|
||||
discoverySuccess = discoverPeers() > 0;
|
||||
} catch (PeerDiscoveryException e) {
|
||||
log.error("Peer discovery failure", e);
|
||||
}
|
||||
discoverySuccess = discoverPeers() > 0;
|
||||
}
|
||||
|
||||
long retryTime;
|
||||
@@ -922,7 +918,7 @@ public class PeerGroup implements TransactionBroadcaster {
|
||||
}
|
||||
|
||||
/** Returns number of discovered peers. */
|
||||
protected int discoverPeers() throws PeerDiscoveryException {
|
||||
protected int discoverPeers() {
|
||||
// Don't hold the lock whilst doing peer discovery: it can take a long time and cause high API latency.
|
||||
checkState(!lock.isHeldByCurrentThread());
|
||||
int maxPeersToDiscoverCount = this.vMaxPeersToDiscoverCount;
|
||||
@@ -931,7 +927,12 @@ public class PeerGroup implements TransactionBroadcaster {
|
||||
final List<PeerAddress> addressList = Lists.newLinkedList();
|
||||
for (PeerDiscovery peerDiscovery : peerDiscoverers /* COW */) {
|
||||
InetSocketAddress[] addresses;
|
||||
addresses = peerDiscovery.getPeers(requiredServices, peerDiscoveryTimeoutMillis, TimeUnit.MILLISECONDS);
|
||||
try {
|
||||
addresses = peerDiscovery.getPeers(requiredServices, peerDiscoveryTimeoutMillis, TimeUnit.MILLISECONDS);
|
||||
} catch (PeerDiscoveryException e) {
|
||||
log.warn(e.getMessage());
|
||||
continue;
|
||||
}
|
||||
for (InetSocketAddress address : addresses) addressList.add(new PeerAddress(params, address));
|
||||
if (addressList.size() >= maxPeersToDiscoverCount) break;
|
||||
}
|
||||
|
Reference in New Issue
Block a user