8159822: Non-synchronized access to shared members of com.sun.jndi.ldap.pool.Pool

Reviewed-by: coffeys
This commit is contained in:
Ivan Gerasimov 2016-07-03 05:30:47 +03:00
parent 50e42d2212
commit 06075b3f8b

View File

@ -118,7 +118,11 @@ final public class Pool {
PooledConnectionFactory factory) throws NamingException { PooledConnectionFactory factory) throws NamingException {
d("get(): ", id); d("get(): ", id);
if (debug) {
synchronized (map) {
d("size: ", map.size()); d("size: ", map.size());
}
}
expungeStaleConnections(); expungeStaleConnections();
@ -141,9 +145,8 @@ final public class Pool {
// Keep the weak reference through the element of a linked list // Keep the weak reference through the element of a linked list
weakRefs.add(weakRef); weakRefs.add(weakRef);
} }
}
d("get(): size after: ", map.size()); d("get(): size after: ", map.size());
}
return conns.get(timeout, factory); // get one connection from list return conns.get(timeout, factory); // get one connection from list
} }
@ -209,6 +212,8 @@ final public class Pool {
out.println("maximum pool size: " + maxSize); out.println("maximum pool size: " + maxSize);
out.println("preferred pool size: " + prefSize); out.println("preferred pool size: " + prefSize);
out.println("initial pool size: " + initSize); out.println("initial pool size: " + initSize);
synchronized (map) {
out.println("current pool size: " + map.size()); out.println("current pool size: " + map.size());
for (Map.Entry<Object, ConnectionsRef> entry : map.entrySet()) { for (Map.Entry<Object, ConnectionsRef> entry : map.entrySet()) {
@ -216,13 +221,16 @@ final public class Pool {
conns = entry.getValue().getConnections(); conns = entry.getValue().getConnections();
out.println(" " + id + ":" + conns.getStats()); out.println(" " + id + ":" + conns.getStats());
} }
}
out.println("====== Pool end ====================="); out.println("====== Pool end =====================");
} }
public String toString() { public String toString() {
synchronized (map) {
return super.toString() + " " + map.toString(); return super.toString() + " " + map.toString();
} }
}
private void d(String msg, int i) { private void d(String msg, int i) {
if (debug) { if (debug) {