반응형
postgresql의 권고 잠금 시간 초과
Oracle에서 마이그레이션합니다.현재 이 통화를 포팅하려고 합니다.
lkstat := DBMS_LOCK.REQUEST(lkhndl, DBMS_LOCK.X_MODE, lktimeout, true);
이 함수는 잠금을 획득하려고 합니다.lkhndl
다음 이후에 얻지 못하면 1을 반환합니다.timeout
초
postgresql 내가 사용하는
pg_advisory_xact_lock(lkhndl);
하지만, 그것은 영원히 자물쇠를 기다리는 것처럼 보입니다.pg_try_advisory_xact_lock
실패한 경우 즉시 반환됩니다.잠금 획득의 시간 초과 버전을 구현하는 방법이 있습니까?
설정이 있지만 조언 잠금에 적용할 수 있는지와 방법을 잘 모르겠습니다.pg_advisory_xact_lock
시간 초과 후 동작합니다.
에뮬레이션이 제대로 되지 않는 포장지의 프로토타입입니다.DBMS_LOCK.REQUEST
하나의 잠금 유형(트랜잭션 범위 권고 잠금)으로만 제한됩니다.
Oracle과 기능이 완전히 호환되도록 하려면 수백 개의 라인이 필요합니다.하지만 그것은 시작입니다.
CREATE OR REPLACE FUNCTION
advisory_xact_lock_request(p_key bigint, p_timeout numeric)
RETURNS integer
LANGUAGE plpgsql AS $$
/* Imitate DBMS_LOCK.REQUEST for PostgreSQL advisory lock.
Return 0 on Success, 1 on Timeout, 3 on Parameter Error. */
DECLARE
t0 timestamptz := clock_timestamp();
BEGIN
IF p_timeout NOT BETWEEN 0 AND 86400 THEN
RAISE WARNING 'Invalid timeout parameter';
RETURN 3;
END IF;
LOOP
IF pg_try_advisory_xact_lock(key) THEN
RETURN 0;
ELSIF clock_timestamp() > t0 + (p_timeout||' seconds')::interval THEN
RAISE WARNING 'Could not acquire lock in % seconds', p_timeout;
RETURN 1;
ELSE
PERFORM pg_sleep(0.01); /* 10 ms */
END IF;
END LOOP;
END;
$$;
다음 코드를 사용하여 테스트:
SELECT CASE
WHEN advisory_xact_lock_request(1, 2.5) = 0
THEN pg_sleep(120)
END; -- and repeat this in parallel session
/* Usage in Pl/PgSQL */
lkstat := advisory_xact_lock_request(lkhndl, lktimeout);
언급URL : https://stackoverflow.com/questions/38853470/timeout-on-advisory-locks-in-postgresql
반응형
'programing' 카테고리의 다른 글
봄 웹 플럭스에서 반응형 전자 메일을 보내는 방법 (0) | 2023.07.21 |
---|---|
MyBatis 목록 삽입 값 (0) | 2023.07.21 |
es6 스타일 가져오기를 사용하여 MongoDB를 가져오는 방법은 무엇입니까? (0) | 2023.07.16 |
워크시트 기능과 함께 1004 오류를 처리하는 방법.V 룩업? (0) | 2023.07.16 |
문자열을 정의할 수 있습니까?TypeScript에서 비어 있습니까? (0) | 2023.07.16 |