web项目启动时自动启动mysql数据库

背景介绍:

    最近在学习spring,看到容器事件ApplicationEvent时,突然想到一个问题,因为在本地搭建了一套学习环境,每次启动web项目时都要首先手动启动mysql,有时忘了启动mysql时,控制台就会抛出数据库连接失败的异常信息,所以就在想,能否利用容器事件功能,在项目启动时自动启动mysql,项目停止时自动关闭mysql。

实现:


import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;

import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;

/**
 * web项目启动时启动mysql;
 * web项目停止时关闭mysql
 * 
 * @author Administrator
 *
 */
public class MySqlListener implements ServletContextListener {

	public void contextDestroyed(ServletContextEvent arg0) {
		try {
			Runtime runtime = Runtime.getRuntime();
			Process process = runtime.exec("net stop mysql");
			InputStream is = process.getInputStream();
			BufferedReader reader = new BufferedReader(new InputStreamReader(is));
			String line = "";
			while ((line = reader.readLine()) != null) {
				line += line + "\n";
			}
			//process.waitFor();
			reader.close();
			is.close();
			process.destroy();
			System.out.println("正在关闭mysql数据库......");
			System.out.println(line);
		} catch (IOException e) {
			e.printStackTrace();
		} 
	}

	public void contextInitialized(ServletContextEvent arg0) {
		try {
			Runtime runtime = Runtime.getRuntime();
			Process process = runtime.exec("net start mysql");
			InputStream is = process.getInputStream();
			BufferedReader reader = new BufferedReader(new InputStreamReader(is));
			String line = "";
			while ((line = reader.readLine()) != null) {
				System.out.println(line);
				line += line + "\n";
			}
			reader.close();
			is.close();
			process.destroy();
			System.out.println("正在启动mysql数据库......");
			System.out.println(line);
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
}

将监听器配置到web.xml中

  <listener>
  	<listener-class>com....listener.MySqlListener</listener-class>
  </listener>

这样就可以实现我想要的功能,大家有什么好的建议请留言!

 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值