mirror of https://github.com/apache/archiva.git
use ConcurrentHashMap rather than synchronized block
git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1235558 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
92e0de2ef1
commit
5eed5ccf55
|
@ -79,6 +79,7 @@ import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* DefaultRepositoryProxyConnectors
|
* DefaultRepositoryProxyConnectors
|
||||||
|
@ -140,7 +141,7 @@ public class DefaultRepositoryProxyConnectors
|
||||||
|
|
||||||
private Map<String, List<ProxyConnector>> proxyConnectorMap = new HashMap<String, List<ProxyConnector>>();
|
private Map<String, List<ProxyConnector>> proxyConnectorMap = new HashMap<String, List<ProxyConnector>>();
|
||||||
|
|
||||||
private Map<String, ProxyInfo> networkProxyMap = new HashMap<String, ProxyInfo>();
|
private Map<String, ProxyInfo> networkProxyMap = new ConcurrentHashMap<String, ProxyInfo>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -168,13 +169,11 @@ public class DefaultRepositoryProxyConnectors
|
||||||
@SuppressWarnings( "unchecked" )
|
@SuppressWarnings( "unchecked" )
|
||||||
private void initConnectorsAndNetworkProxies()
|
private void initConnectorsAndNetworkProxies()
|
||||||
{
|
{
|
||||||
synchronized ( this.proxyConnectorMap )
|
|
||||||
{
|
|
||||||
ProxyConnectorOrderComparator proxyOrderSorter = new ProxyConnectorOrderComparator();
|
ProxyConnectorOrderComparator proxyOrderSorter = new ProxyConnectorOrderComparator();
|
||||||
this.proxyConnectorMap.clear();
|
this.proxyConnectorMap.clear();
|
||||||
|
|
||||||
List<ProxyConnectorConfiguration> proxyConfigs =
|
List<ProxyConnectorConfiguration> proxyConfigs = archivaConfiguration.getConfiguration().getProxyConnectors();
|
||||||
archivaConfiguration.getConfiguration().getProxyConnectors();
|
|
||||||
for ( ProxyConnectorConfiguration proxyConfig : proxyConfigs )
|
for ( ProxyConnectorConfiguration proxyConfig : proxyConfigs )
|
||||||
{
|
{
|
||||||
String key = proxyConfig.getSourceRepoId();
|
String key = proxyConfig.getSourceRepoId();
|
||||||
|
@ -235,16 +234,13 @@ public class DefaultRepositoryProxyConnectors
|
||||||
{
|
{
|
||||||
log.warn( "Unable to use proxy connector: " + e.getMessage(), e );
|
log.warn( "Unable to use proxy connector: " + e.getMessage(), e );
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
synchronized ( this.networkProxyMap )
|
|
||||||
{
|
|
||||||
this.networkProxyMap.clear();
|
this.networkProxyMap.clear();
|
||||||
|
|
||||||
List<NetworkProxyConfiguration> networkProxies =
|
List<NetworkProxyConfiguration> networkProxies = archivaConfiguration.getConfiguration().getNetworkProxies();
|
||||||
archivaConfiguration.getConfiguration().getNetworkProxies();
|
|
||||||
for ( NetworkProxyConfiguration networkProxyConfig : networkProxies )
|
for ( NetworkProxyConfiguration networkProxyConfig : networkProxies )
|
||||||
{
|
{
|
||||||
String key = networkProxyConfig.getId();
|
String key = networkProxyConfig.getId();
|
||||||
|
@ -259,7 +255,7 @@ public class DefaultRepositoryProxyConnectors
|
||||||
|
|
||||||
this.networkProxyMap.put( key, proxy );
|
this.networkProxyMap.put( key, proxy );
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public File fetchFromProxies( ManagedRepositoryContent repository, ArtifactReference artifact )
|
public File fetchFromProxies( ManagedRepositoryContent repository, ArtifactReference artifact )
|
||||||
|
@ -1046,11 +1042,8 @@ public class DefaultRepositoryProxyConnectors
|
||||||
{
|
{
|
||||||
boolean connected = false;
|
boolean connected = false;
|
||||||
|
|
||||||
final ProxyInfo networkProxy;
|
final ProxyInfo networkProxy = this.networkProxyMap.get( connector.getProxyId() );
|
||||||
synchronized ( this.networkProxyMap )
|
|
||||||
{
|
|
||||||
networkProxy = (ProxyInfo) this.networkProxyMap.get( connector.getProxyId() );
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( log.isDebugEnabled() )
|
if ( log.isDebugEnabled() )
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue