- 论坛徽章:
- 0
|
------
| |
| A |-------------------|
|----| |
------
------ | C |
| | -------
| B |------------------|
|----|
1. A,B 是应用服务器,C是后端INFORMIX数据库
2.C中的Database Products, Table profile,表结构大概是(id,info,expiration_timestamp)
3.如果我们A,B上都运行着一个监督进程,需要选出profile中过期的记录,生成一个报表,然后删除该记录
问题
由于A,B上的进程是同时运行的,如何保证被A选中的记录不被B选中而生成重复的报表记录?
我自己想那几个方案
方案一
最简单的,把A,B上进程运行的时间进行协调,比如A上的00:00-12:00,B 12:01-23:59
但是同一时间,只有一个进程运行担心删的不够快的问题
方案二
为表加上一列flag default为0,表示有没有被选中(id,info,expiration_timestamp,flag)
使用SELECT FOR UPDATE
比如 select first 1 id from profile where expiration_timestamp <= current_time and flag !=1 for update;
update profile set flag=1 where id = <前面选中的>
这样当一个A/B上的进程选中以后,及时更新了flag,那么另一个就选不中了,避免重复。
但是我仔细一想,仍然存在重复的可能,我们假设很不幸A,B同时选到一个flag!=1的记录,A获得锁,B等待,A更新了flag然后释放锁,
但是由于之前B已经选中了这个记录,只是在等待,当A update该记录以后B还是获得了update得可能,
不能绝对地保证不重复选中。只是从概率的角度上有所减少罢了。
不知道我的理解对不对,
这个问题别的类型的数据库也会遇到,但是目前使用的是INFORMIX,希望各路神仙帮忙指出个明道那, |
|