|
| 1 | +package org.fp024.servlet.listener; |
| 2 | + |
| 3 | +import javax.servlet.ServletContext; |
| 4 | +import javax.servlet.ServletContextEvent; |
| 5 | +import javax.servlet.ServletContextListener; |
| 6 | +import javax.servlet.annotation.WebListener; |
| 7 | +import java.sql.DriverManager; |
| 8 | +import java.sql.SQLException; |
| 9 | +import java.util.Collections; |
| 10 | +import lombok.extern.slf4j.Slf4j; |
| 11 | + |
| 12 | +@Slf4j |
| 13 | +@WebListener |
| 14 | +public class JDBCDriverCleaner implements ServletContextListener { |
| 15 | + protected void deregisterJdbcDrivers(ServletContext servletContext) { |
| 16 | + Collections.list(DriverManager.getDrivers()) |
| 17 | + .forEach( |
| 18 | + driver -> { |
| 19 | + ClassLoader driverClassLoader = driver.getClass().getClassLoader(); |
| 20 | + ClassLoader contextClassLoader = servletContext.getClassLoader(); |
| 21 | + ClassLoader parentClassLoader = |
| 22 | + contextClassLoader != null ? contextClassLoader.getParent() : null; |
| 23 | + |
| 24 | + LOGGER.debug( |
| 25 | + "### {} 드라이버의 클래스 로더: {}", |
| 26 | + driver.getClass().getCanonicalName(), |
| 27 | + driverClassLoader != null |
| 28 | + ? driverClassLoader.getClass().getCanonicalName() |
| 29 | + : "Bootstrap ClassLoader"); |
| 30 | + LOGGER.debug( |
| 31 | + "### 현재 서블릿 컨텍스트의 클래스 로더: {}", |
| 32 | + contextClassLoader != null |
| 33 | + ? contextClassLoader.getClass().getCanonicalName() |
| 34 | + : "Bootstrap ClassLoader"); |
| 35 | + LOGGER.debug( |
| 36 | + "### 현재 서블릿 컨텍스트의 부모 클래스 로더: {}", |
| 37 | + parentClassLoader != null |
| 38 | + ? parentClassLoader.getClass().getCanonicalName() |
| 39 | + : "Bootstrap ClassLoader"); |
| 40 | + |
| 41 | + if (driverClassLoader == contextClassLoader |
| 42 | + || driverClassLoader == parentClassLoader) { |
| 43 | + try { |
| 44 | + DriverManager.deregisterDriver(driver); |
| 45 | + LOGGER.info("### {} 드라이버 등록 해제", driver.getClass().getCanonicalName()); |
| 46 | + } catch (SQLException ex) { |
| 47 | + LOGGER.warn("### {} 드라이버 등록 해제 실패", driver.getClass().getCanonicalName(), ex); |
| 48 | + } |
| 49 | + } |
| 50 | + }); |
| 51 | + } |
| 52 | + |
| 53 | + @Override |
| 54 | + public void contextDestroyed(ServletContextEvent event) { |
| 55 | + LOGGER.trace("contextDestroyed() 실행..."); |
| 56 | + deregisterJdbcDrivers(event.getServletContext()); |
| 57 | + } |
| 58 | +} |
0 commit comments