MyException - 我的异常网
当前位置:我的异常网» 编程 » signal信号捕杀

signal信号捕杀

www.MyException.Cn  网友分享于:2015-08-26  浏览:16次
signal信号捕捉

Signal 顾名思义是信号的意思,为什么要用到这个东西了?

原因:由于现在在负责写网游的后台loginServer,里面写了不少配置文件,当我们的产品上线后,loginServer开启后这时配置文件的数据就被读取进去了,但是当我们想修改这些配置数据怎么办呢?不可能让把loginServer关掉吧! 假如在线几万了,你导致关闭服务弄的几千上万的用户进不去,你知道会损失多少用户,多少钱吗?还会被老板搞死的..

有两种方法:

1.Signal

2.通过协议发送一个消息过来,然后重新读取一下配置文件

如果朋友知道更好的办法的朋友也希望能分享一下,告诉下我..

由于博文标题是signal信号捕捉,第二种方法通过协议消息来重新读取配置数据,就不说了...

一、首先看下java中Signal枚举有哪些各代表什么含义:

USR1:用户自定义信号1
USR2:用户自定义信号2

推荐:用户自定义信号USR1和USR2,其他信号我同事说可能会隐患别的问题,最好不用.

TERM:终止信号

KILL:Kill信号

INT:键盘中断

HUP :终端挂起或者控制进程终止

BUS:总线错误

上面这5个出现的比较多,下面是其他的信号

ALRM:警告

CHLD子进程结束信号

CONT:进程继续(曾被停止的进程)

FPE:浮点异常

ILL:非法指令

IO:某I/O操作现在可以进行了

IOT:IO捕获指令

PIPE:管道破裂: 写一个没有读端口的管道

PROF:Profiling定时器到

PWR:电源故障

QUIT:键盘的退出键被按下

SEGV:无效的内存引用

STKFLT:协处理器堆栈错误

STOP:终止进程
TRAP:跟踪/断点捕获

TSTP:控制终端(tty)上按下停止键

TTIN:后台进程企图从控制终端读

TTOU:后台进程企图从控制终端写

VTALRM: 实际时间报警时钟信号

WINCH:窗口大小改变

XCPU:超出设定的CPU时间限制

XFSZ:超出设定的文件大小限制

二、老样子上传我的demo

package com.back;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.log4j.PropertyConfigurator;

import sun.misc.Signal;
import sun.misc.SignalHandler;

/***
* java信号捕获处理demo
*/
public class SignalHandlerExample implements SignalHandler {
	static Log log=LogFactory.getLog(SignalHandlerExample.class);
	
	private boolean Running = true;
	 
	public SignalHandlerExample() {
		 this.setupHandler();
	 }
	 
	private void setupHandler() {
		 this.handleSignal("INT");
		 this.handleSignal("TERM");
		 this.handleSignal("HUP");
	 }
	 
	public void handleSignal(final String signalName) {
		 try {
			 Signal.handle(new Signal(signalName), this);
		 } catch (IllegalArgumentException e) {
			 // 可能这个信号,并不支持这个平台或JVM作为目前配置
			 e.printStackTrace();
		 }
	 }
	 
	/**
	 * 捕获信号
	 * @param signal The {@link sun.misc.Signal} that we received
	 **/
	 public synchronized void handle(Signal signal) {
		 // we are only interested in catching the "TERM" signal
		 if ( signal.getName().equals("TERM") ) {
			 log.info(" TERM received " + signal.getName() );
			 log.info("threadName" + Thread.currentThread().getName());
			 System.exit(-1);
		 } else if ( signal.getName().equals("INT") ||signal.getName().equals("HUP") ) {
			 setRunningStatus( false );
			 notifyAll(); //TODO - clarify if notify OR notifyall
		 }
		 log.info( signal.getName() + " " + signal.getNumber() );
		 log.info( getRunningStatus()+"" );
	 }
	 
	public void setRunningStatus( boolean Status ) {
		this.Running = Status;
	}
	 
	public boolean getRunningStatus() {
		return Running;
	}
	 
	/**
	 * General "clean up" method which is called when we receive a TERM
	 signal
	 * This will likely be superseeded by specific cleanup code
	 *
	 **/
	 public boolean cleanUp() {
		 // TODO - we need to decide what we are going to do one we trap a
		 //	 TERMinate signal.
		 // We need to complete all our threads nicely.
		 log.info("Cleaning up!");
		 return true;
	 }
	 
	public synchronized void myWait() {
		 try{
			 wait();
		 }catch (InterruptedException e){
			 log.info( "myWait WOKEN UP" + e );
		 }
	}
	 
	public static void main(final String[] args) {
	    PropertyConfigurator.configure("./config/log4j.properties");
		 
		SignalHandlerExample mySignalHandler = new SignalHandlerExample();
	 
		while ( mySignalHandler.getRunningStatus() ) {
			log.info("waiting");
			mySignalHandler.myWait();
			log.info("woken up");
		}
	}
}

补充:sun.misc.Signal和SignalHandler引入不进来解决方法:

设置设计到了日志的打印,如果不知道请参看我java日志打印那篇文章

我们上次SignalTest.jar到linux服务器上运行如下:

1.Ctrl+C:

2.INT:kill -s INT 端口号

这个时候我们就可以利用这种方式来重读我们的配置文件了...

 


参看文章:

http://coding.derkeiler.com/Archive/Java/comp.lang.java.help/2006-10/msg00248.html

http://wangym.iteye.com/blog/733693

http://blog.chinaunix.net/uid-20441206-id-3138952.html

相关文章:

http://blog.csdn.net/qinghua9/article/details/5295934

http://www.csl.mtu.edu/cs4411.ck/www/NOTES/signal/install.html

文章评论

一个程序员的时间管理
一个程序员的时间管理
不懂技术不要对懂技术的人说这很容易实现
不懂技术不要对懂技术的人说这很容易实现
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
10个帮程序员减压放松的网站
10个帮程序员减压放松的网站
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
我的丈夫是个程序员
我的丈夫是个程序员
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
中美印日四国程序员比较
中美印日四国程序员比较
鲜为人知的编程真相
鲜为人知的编程真相
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
旅行,写作,编程
旅行,写作,编程
程序员必看的十大电影
程序员必看的十大电影
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
老程序员的下场
老程序员的下场
编程语言是女人
编程语言是女人
程序员的鄙视链
程序员的鄙视链
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
每天工作4小时的程序员
每天工作4小时的程序员
代码女神横空出世
代码女神横空出世
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
漫画:程序员的工作
漫画:程序员的工作
2013年美国开发者薪资调查报告
2013年美国开发者薪资调查报告
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
总结2014中国互联网十大段子
总结2014中国互联网十大段子
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
我跳槽是因为他们的显示器更大
我跳槽是因为他们的显示器更大
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
程序员都该阅读的书
程序员都该阅读的书
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
程序员和编码员之间的区别
程序员和编码员之间的区别
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
Java程序员必看电影
Java程序员必看电影
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
那些争议最大的编程观点
那些争议最大的编程观点
2013年中国软件开发者薪资调查报告
2013年中国软件开发者薪资调查报告
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
那些性感的让人尖叫的程序员
那些性感的让人尖叫的程序员
我是如何打败拖延症的
我是如何打败拖延症的
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有