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;
    /

  • 相关阅读:
    GridView中使用DataFromatString
    添加文件Node
    GridView技巧1:加入序号
    Android UI控件Spinner控件的学习
    Android UI开发之RadioButton
    二叉树
    visual studio toolbox 修复
    github笔记
    nhibernate manytoone 没有匹配项时的异常
    DataMember 特性
  • 原文地址:https://www.cnblogs.com/glf2046/p/4885403.html
Copyright © 2011-2022 走看看