zoukankan      html  css  js  c++  java
  • How to synchronize between processes

    # lock across process
    e.g. Server handles request from different clients, there clients are essentially different processes, they could potentially write to the same piece
    of data(e.g. same records in table), so we need to make sure these access well synchronized.

    Since normal locking mechnism applies only to inter process(inter-threads), for normal lock from JDK won't work here.

    In this case, we need to use some medium from outside, which could be database records or some file on our hard disk.

    ## Using database records to be mutual exclusive

    CREATE OR REPLACE PROCEDURE BBDEV_DBO.Prcubblock(txtType IN CHAR, success OUT INT) IS
    intRecCount INT;
    BEGIN
    DELETE FROM UBBMSTLOCK WHERE dtlastmodified <= SYSDATE - 1/48;
    SELECT COUNT(*) INTO intRecCount FROM UBBMSTLOCK;
    IF (intRecCount = 0) THEN
    INSERT INTO UBBMSTLOCK VALUES (' ', 0, SYSDATE);
    END IF;
    IF (txtType = 'U') THEN
    UPDATE UBBMSTLOCK l
    SET l.txtlocktype = 'U', l.dtlastmodified = SYSDATE
    WHERE l.txtlocktype = ' ' OR l.txtlocktype = 'U';
    success := SQL%Rowcount;
    ELSIF txtType = 'S' THEN
    UPDATE UBBMSTLOCK l
    SET l.txtlocktype = 'S', l.dtlastmodified = SYSDATE
    WHERE l.txtlocktype = ' ' OR l.txtlocktype = 'S';
    success := SQL%Rowcount;
    IF (success > 0) THEN
    UPDATE UBBMSTLOCK l
    SET l.Intlockcount = l.Intlockcount + 1, l.dtlastmodified = SYSDATE
    WHERE l.txtlocktype = 'S';
    END IF;
    ELSE
    success := 0;
    END IF;
    COMMIT;
    EXCEPTION
    WHEN OTHERS THEN
    ROLLBACK;
    success := 0;
    END;
    /

  • 相关阅读:
    图像轮廓提取
    图像分割学习
    数据的平面拟合 Plane Fitting
    目标跟踪_MeanShift
    灰度图像伪彩色
    OpenCv SGBM算法源码解读
    图像处理之滤波器
    Ubuntu下Jenkins(docker)配置Docker远程启动
    使用dockerfile文件创建镜像时docker build没有反应
    创建jdk8基础镜像
  • 原文地址:https://www.cnblogs.com/glf2046/p/4885403.html
Copyright © 2011-2022 走看看