¿Tienes conexiones que se quedan colgadas después de cada redeploy en tu aplicación Spring? Resulta que seguramente estas utilizando el DBCP de Apache para conectarte a tus bases de datos y este no cierra las conexiones cuando la aplicación le dice que es hora de cerrar todo. Aquí les voy a poner el código y configuración necesaria para que no tengan que estar reiniciando tanto su servidor de aplicaciones (Tomcat, JBoss, Glassfish, etc).
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package edu.swau.forms.utils; | |
import java.sql.Driver; | |
import java.sql.DriverManager; | |
import java.sql.SQLException; | |
import java.util.Enumeration; | |
import java.util.Set; | |
import org.slf4j.Logger; | |
import org.slf4j.LoggerFactory; | |
import org.springframework.context.ApplicationListener; | |
import org.springframework.context.event.ContextClosedEvent; | |
/** | |
* | |
*/ | |
public class ContextFinalizer implements ApplicationListener<ContextClosedEvent> { | |
private static final Logger log = LoggerFactory.getLogger(ContextFinalizer.class); | |
@Override | |
public void onApplicationEvent(ContextClosedEvent e) { | |
log.info("Stopping connections"); | |
Enumeration<Driver> drivers = DriverManager.getDrivers(); | |
Driver d = null; | |
while (drivers.hasMoreElements()) { | |
try { | |
d = drivers.nextElement(); | |
DriverManager.deregisterDriver(d); | |
log.warn(String.format("Driver %s deregistered", d)); | |
} catch (SQLException ex) { | |
log.warn(String.format("Error deregistering driver %s", d), ex); | |
} | |
} | |
Set<Thread> threadSet = Thread.getAllStackTraces().keySet(); | |
Thread[] threadArray = threadSet.toArray(new Thread[threadSet.size()]); | |
for (Thread t : threadArray) { | |
if (t.getName().contains("Abandoned connection cleanup thread")) { | |
synchronized (t) { | |
t.stop(); //don't complain, it works | |
} | |
} | |
} | |
log.info("Finished stopping connections"); | |
} | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<bean id="contextFinalizer" class="edu.swau.forms.utils.ContextFinalizer" /> |
Comentarios