728x90

PostgreSQL 6

[PostgreSQL] repmgr을 이용한 DB 이중화 구성하기_2, auto failover

지난 repmgr을 이용한 이중화 구성 포스팅에서 primary에서 테이블을 생성하고 데이터를 기록하면 standby에서도 해당 테이블을 조회할 수 있는 것을 확인하였다. 하지만 이렇게까지만 설정한다면 pglogical과 별반 다를 것이 없다. 이번에는 repmgr이 제공하는 auto failover 기능에 대해 알아보기로 하였다. 1. repmgr.conf 설정하기 auto failover를 사용하기 위해서는 repmgr.conf를 수정한 뒤 repmgrd를 시작하면 된다. vi /etc/repmgr/14/repmgr.conf failover='automatic' promote_command='repmgr standby promote' follow_command='repmgr standby follow..

DB 2022.10.02

[PostgreSQL] repmgr을 이용한 DB 이중화 구성하기_1

지난번 pglogical을 이용한 DB 이중화에 대해 알아보았었는데, pglogical 자체에는 primary-secondary 구조에서 auto failover나 secondary 서버에서 read only로 설정해 주는 기능이 없었다. 그러던 중 PostgreSQL 자체 replication 기능을 이용하면서 auto failover 처리를 해줄 수 있는 repmgr을 알게 되었다. 이번 포스팅은 Rocky Linux 8 환경에 PostgreSQL 14를 repmgr을 이용하여 이중화를 구성하는 방법에 대해 포스팅하려고 한다. 설치에 앞서 primary-secondary를 repmgr에서는 primary-standby로 표현하고 있기 때문에 primary-standby로 표현하기로 한다. 1. rep..

DB 2022.10.01

[PostgreSQL] pglogical을 이용한 DB 이중화 구성하기_2, 양방향 이중화를 구성해 보자

지난 포스팅에서 pglogical을 이용한 DB 이중화 구성을 테스트했을 때, 마지막에 구독을 하고 있는 노드에서 INSERT, UPDATE, DELETE 등의 DML 명령어를 사용했을 때 read-only 모드가 아니기 때문에 값이 DB에 반영되는 것을 확인할 수 있었다. read-only 모드로 사용하는 방법이던지, 뭔가 다른 방법이 있을 것 같지만 이런 것들을 찾아보기 이전에 양방향 이중화. bi-directional replication 글을 읽었기 때문에 이 방법 먼저 알아보기로 하였다. https://aws.amazon.com/ko/blogs/database/postgresql-bi-directional-replication-using-pglogical/ PostgreSQL bi-directi..

DB 2022.09.21

[PostgreSQL] pglogical을 이용한 DB 이중화 구성하기

PostgreSQL의 공식 문서 27번 항목은 Chapter 27. High Availability, Load Balancing, and Replication. 고가용성, 로드 밸런싱, 복제를 설명하고 있다. 이제 막 이중화에 대해 알아가기 시작하는 단계라 자세히는 모르지만 이중화를 구성함으로써 failover를 기대할 수 있고, 부하를 분산시킬 수도 있다고 한다. 이 중 오늘 알아볼 것은 공식 문서 27.1 항목에서 논리적 복제(Logical Replication)를 이용한 모듈인 pglogical에 대해 알아보려고 한다. pgsql에서 논리적 복제는 Write-Ahead 로깅(WAL)에서 논리적 데이터 수정 스트림을 구성하여 테이블 별로 데이터 변경 사항을 복제할 수 있다고 되어있다. pglogica..

DB 2022.09.20

[Rocky 8] Rocky Linux 8에 PostgreSQL 14 설치하기

# rpm 저장소 설치: sudo dnf install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-8-x86_64/pgdg-redhat-repo-latest.noarch.rpm # Disable the built-in PostgreSQL module: # 기본 제공 PostgreSQL 모듈 비활성화 sudo dnf -qy module disable postgresql # PostgreSQL 설치: sudo dnf install -y postgresql14-server # PostgreSQL 초기화 및 부팅 시 자동 시작 설정: sudo /usr/pgsql-14/bin/postgresql-14-setup initdb sudo systemct..

Linux 2022.09.19

[PostgreSQL] PostgreSQL 12 설치 후 Job for postgresql-12.service failed because the control process exited with error code. 에러 해결하기

회사에서 DB 백업 관련 테스트가 필요해 centOS 7을 설치 후 rpm을 사용하여 PostgreSQL 12를 설치하였다. 하지만 psql 명령어를 실행하니 연결할 수 없다고 한다. DB가 꺼진 것 같아 systemctl start postgresql-12.service를 입력하니 Job for postgresql-12.service failed because the control process exited with error code. See "systemctl status postgresql-12.service" and "journalctl -xe" for details. 오류코드와 함께 제어 프로세스가 종료되었다고 뜬다. systemctl status postgresql-12.service와 jo..

DB 2022.09.08
728x90