利用文件锁机制实现服务器程序的自启动

王朝other·作者佚名  2006-12-19
窄屏简体版  字體: |||超大  

利用文件锁机制实现服务器程序的自启动

通过本文你可以体会一下举一反三的含义,以及unix程序设计的简洁性理念。

不知你有没有读过《Unix高级编程》一书,每一章节都是基本知识,感觉不到任何高级之意。正如《C++Primer》一样,书名和内容好像很不相称。

其实正如中国的一句俗语:运用之妙存乎一心。

读的程序多了,编的代码也不少了,剩下的也就是慢慢品味其中的乐趣了。

下面就举一个文件锁(file lock)的用法,向来不喜欢大段的函数参数格式说明,如果你想详细了解文件锁,请查阅相关文档。

服务器程序当然不会无缘无故就死掉,除了受到人为攻击的原因,多是程序bug所致,经过长时间(如果允许)测试修正,纠正了大量的bug,服务器程序已经很稳定了。服务器程序还会崩溃吗?没有人敢说不会,实际就是这样。那好,程序发布的最后阶段就因该是实现服务程序的崩溃自启动。

原理很简单:服务器程序开始运行时先锁定一个文件,程序正常情况不释放该锁,当程序因故崩溃时Unix系统将自动释放该锁。由此我们可以设计另一个单独的监听程序,它在主程序锁定锁文件后去锁定同样的文件,那么根据文件锁的性质,此锁定要求将被系统阻塞,当主程序崩溃释放文件锁时,监听程序将获得文件锁,继续执行,在此加入重新启动主程序的命令即可。

主程序的开始处

...

int fd;

fd=open(lockfilename,O_WRONLY|O_CREAT,0600);

flock(fd,LOCK_EX);//互斥锁

...

监听程序的部分内容

...

int fd=-1;

fd=open(lockfilename,O_WRONLY|O_RDONLY);

flock(fd,LOCK_EX);//互斥锁

sleep(2);

flock(fd,LOCK_UN);

system(...);//运行主程序

...

就是这样,就这么简单

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航