需求:最近做了個後臺運行的jar包應用,沒有采用web容器,採用java -jar xxxxx的方式運行。數據庫連接池採用c3p0,關閉應用後
發現數據庫會話依然存在。
解決方案:採用Runtime.getRuntime().addShutdownHook(Thread hook)在應用關閉前關閉數據庫連接,該方法適用於採用
System.exit(int)退出應用的方式。 因爲jar包採用的是main方法啓動(main方法是應用的入口和出口),因此直接將
Runtime.getRuntime().addShutdownHook(Thread hook)放在了main方法中。(Runtime 就是java.lang.Runtime).
因爲我採用Guice管理數據源,所以下面通過Injector獲取應用的DataSource。
代碼:
import javax.sql.DataSource;
import com.google.inject.Injector;
import com.mchange.v2.c3p0.ComboPooledDataSource;
public class ShutdownHookTest {
private static Injector injector;
static {
// TODO initiate injector
System.out.println("injector has been initiated.");
}
public static void main(String[] args) {
Runtime.getRuntime().addShutdownHook(new Thread(){
@Override
public void run() {
DataSource ds = injector.getInstance(DataSource.class);
((ComboPooledDataSource) ds).close();
System.out.println("Successfully closed the dataSource.");
}
});
}
}