Chinaunix首页 | 论坛 | 博客
  • 博客访问: 15177692
  • 博文数量: 7460
  • 博客积分: 10434
  • 博客等级: 上将
  • 技术积分: 78178
  • 用 户 组: 普通用户
  • 注册时间: 2008-03-02 22:54
文章分类

全部博文(7460)

文章存档

2011年(1)

2009年(669)

2008年(6790)

分类: C/C++

2008-05-27 19:59:17

利用文件锁机制实现服务器程序的自启动
通过本文你可以体会一下举一反三的含义,以及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(...);//运行主程序
 
      ...
就是这样,就这么简单 

阅读(210) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~