centos7 postgresql13 pgAdmin4 설치 + 외부 접속, 로그 파일 생성
1. Postgres 설치
1.1 설치 파일 다운로드 및 업로드
https://www.postgresql.org/ftp/source/
data:image/s3,"s3://crabby-images/e2e73/e2e73eb4529e710e87e379302c6cd6cb6f48e7e8" alt=""
data:image/s3,"s3://crabby-images/d536b/d536b2f99a5f8a2d583769761bc4914f610e98d1" alt=""
data:image/s3,"s3://crabby-images/e4474/e447486337fdcb7614afda584f86a0f52ed213ad" alt=""
1.2 압축 해제
postgresql 설치는 postgres 계정을 별도로 생성하여 만듬.
[postgres@localhost ~]$ tar -xvf postgresql-13.3.tar.gz
data:image/s3,"s3://crabby-images/0ded3/0ded32be7c43c5f18f8955840611fd933e9b0ca6" alt=""
1.3 관련 패키지 다운로드
yum -y install gcc gcc-c++ boost boost-devel pkgconfig uuidd libtool autoconf make coreutils uuid-dev uuid-devel libuuid-devel e2fsprogs-devel readline readline-devel zlib zlib-devel openssl openssl-devel gettext
data:image/s3,"s3://crabby-images/f104f/f104f55e1170c68027b498408ebf86330af85091" alt=""
1.4 Postgres configure 설정 및 설치진행
[postgres@localhost postgresql-13.3]$ ./configure --prefix=/home/postgres/postgres/postgresql-13.3/pgsql
--prefix는 설치 디렉토리 지정
[postgres@localhost postgresql-13.3]$ make
[postgres@localhost postgresql-13.3]$ make install
1.5 DB 설치
[postgres@localhost bin]$ ./initdb -D /home/postgres/postgres/postgresql-13.3/pgsql/data
[postgres@localhost bin]$ pwd
/home/postgres/postgres/postgresql-13.3/pgsql/bin
1.6 POSTGRES 환경 설정
[postgres@localhost ~]$ vi ~/.bash_profile
PATH=$PATH:$HOME/bin:$POSTGRES_HOME/bin
POSTGRES_HOME=/home/postgres/postgres/postgresql-13.3/pgsql
PGLIB=$POSTGRES_HOME/lib
PGDATA=$POSTGRES_HOME/data
data:image/s3,"s3://crabby-images/f339e/f339ea3823638a712304cbf570b4c7eb4b1cd452" alt=""
[postgres@localhost pgsql]$ source ~/.bash_profile --~/.bash_profile 적용
1.7 DB 시작
[postgres@localhost bin]$ ./pg_ctl start -D $PGDATA
data:image/s3,"s3://crabby-images/1ec46/1ec4605b0326f2f0be9deca404a7b3933e1411ad" alt=""
data:image/s3,"s3://crabby-images/11553/11553d56b320e219def813c74a4dc0464d939429" alt=""
1.7.1 Database / user / schema생성
# database 생성
postgres=# create database fido;
CREATE DATABASE
# user 생성
postgres=# create user fido;
CREATE ROLE
# 비밀번호 설정
postgres=# alter user fido with password 'fido';
ALTER ROLE
data:image/s3,"s3://crabby-images/11087/110875507c9d96d2351b235af7bcd25c2886711e" alt=""
data:image/s3,"s3://crabby-images/b181a/b181aa9d5c5652ed672fc0dc7b739c8193337cbe" alt=""
# schema 생성 및 소유자 변경
[postgres@localhost ~]$ psql -d fido –psql 접속
psql (13.3)
Type "help" for help.
fido=# create schema fido; --schema 생성
CREATE SCHEMA
fido=# alter schema fido owner to fido; --스키마 소유자 변경
ALTER SCHEMA
fido=# \dn –해당 db내의 schema 확인
List of schemas
Name | Owner
--------+----------
fido | fido
public | postgres
(2 rows)
data:image/s3,"s3://crabby-images/de689/de689b16d526cbd62446ff00bf8f477ea03c1c1f" alt=""
2. POSTGRESQL 외부 접속 설정
2.1 외부 접속 허용
2.1.1 Postgresql.conf 수정
[postgres@localhost data]$ vi postgresql.conf
주석 해제 후 ‘localhost’ -> ‘*’ 로 변경
쉽게 찾는 방법: shift + ? listen 검색
data:image/s3,"s3://crabby-images/b9d49/b9d49967f12e2791e80246b002beea4dcf380546" alt=""
listen_addresses = '*'
data:image/s3,"s3://crabby-images/6058b/6058bedf0b18becbec4a9af2aa1f551ea205d98e" alt=""
data:image/s3,"s3://crabby-images/de060/de0605681ac18f465739f0ef4579b832bd293ca4" alt=""
2.1.2. pg_hba.conf
127.0.0.1/32 -> 0.0.0.0/0 으로 변경해 모두 접속 허용
[변경전]
data:image/s3,"s3://crabby-images/20f45/20f4593d18db5f1211eda77844f078e8f34e96a0" alt=""
[변경후]
data:image/s3,"s3://crabby-images/eb5cc/eb5ccefd5930dd232124dd5942bccf54495eb294" alt=""
2.2 재시작
[postgres@localhost pgsql]$ pg_ctl restart -D $PGDATA
혹은
[postgres@localhost pgsql]$ service postgresql restart
Redirecting to /bin/systemctl restart postgresql.service
==== AUTHENTICATING FOR org.freedesktop.systemd1.manage-units ===
Authentication is required to manage system services or units.
Authenticating as: root
Password:
==== AUTHENTICATION COMPLETE ===
Failed to restart postgresql.service: Unit not found.
data:image/s3,"s3://crabby-images/fe667/fe66705a20f2e1cea84ef28debd295b40369dfc1" alt=""
2.3 방화벽 해제(5432)
data:image/s3,"s3://crabby-images/1bd0a/1bd0acea52d373e263a31a305f70ba475e5d5515" alt=""
data:image/s3,"s3://crabby-images/6dedc/6dedcd9b272600935b707d8720f5c450303d5992" alt=""
[root@localhost ~]# firewall-cmd --permanent --zone=public --add-service=postgresql
success
[root@localhost ~]# firewall-cmd --reload
Success
data:image/s3,"s3://crabby-images/00780/00780906d98139e00bd28a88f1132cb929f6bb7f" alt=""
3. POSTGRESQL LOG FILE 생성
3.1 POSTGRES LOG FILE 생성
3.1.1 Postgresql.conf 파일 찾기
먼저 postgres 설정 File에서 log관련 설정들을 수정해줘야 하므로 Postgrdsql.conf 파일 위치를 찾습니다.
show config_file;
data:image/s3,"s3://crabby-images/6cbe7/6cbe7e006e102810ec85f6bb4acfe8881586aaef" alt=""
3.1.2 Data_directory 위치 찾기
log 폴더가 data_direcotry 밑으로 들어가기 때문에 data_directory 위치도 찾아줍니다.
show data_directory;
data:image/s3,"s3://crabby-images/3a4ac/3a4ac017e42713686731c895112135dbb8400250" alt=""
3.2 Postgresql.conf 파일 수정
1번에서 찾았던 postgres conf 파일을 열어 아래와 같이 log 관련 설정들을 수정해줍니다.
[postgres@localhost postgresql-13.3]$ vi /home/postgres/postgres/postgresql-13.3/pgsql/data/postgresql.conf
아래 4가지 설정 주석 해제
log_destination = 'csvlog'
logging_collector = on
log_directory = 'pg_log'
log_filename = 'postgresql-%Y-%m-%d_%H%M%S.log'
data:image/s3,"s3://crabby-images/cb620/cb6202fdd8976d6257709f6298a46c928fbeef0e" alt=""
3.3 Postgresql 재시작
위에서 설정한 사항들이 적용될 수 있도록 postgresql을 재시작 해줍니다.
[postgres@localhost bin]$ ./pg_ctl restart -D $PGDATA
data:image/s3,"s3://crabby-images/6bceb/6bceb324e4ce7ee567ef6aa83ace756b8d608770" alt=""
위의 방법으로 postgres 재시작이 안되면 아래와 같은 방법으로 재시작
[postgres@localhost bin]$ service postgresql restart
3.4 LOG 파일 생성 확인
마지막으로 LOG 파일이 잘 생성되었는지 확인합니다.
위에 postgres conf 파일에서 설정한 4가지 기억하시죠? 그거에 맞춰 설정한 위치에 log 파일이 생깁니다.
즉 LOG 위치 & FILE명 형식 : data_direcotry/log_directory/log_filename
data:image/s3,"s3://crabby-images/f5fcd/f5fcd13bb0eb0f0518aed92be5c0bbbdf7836621" alt=""
4. PgAdmin4 다운
4.1 PGADMIN4 다운
data:image/s3,"s3://crabby-images/4acf1/4acf11bdcfe4ca7fb9064cbde002546db202048b" alt=""
data:image/s3,"s3://crabby-images/eb45c/eb45c5182afd9c64794c2166e4c4ef959a0832b4" alt=""
data:image/s3,"s3://crabby-images/078f3/078f31281bfd37509fba1004eb5142b7bb036467" alt=""
data:image/s3,"s3://crabby-images/5cc01/5cc0195022510a15fc1afaa05e3664e10d1829cf" alt=""
data:image/s3,"s3://crabby-images/db507/db507561ddb4d927c23c96e5556fe0ee9337d8a9" alt=""
data:image/s3,"s3://crabby-images/e479e/e479e59e34c05258d6ec913be9a0856ef14d07d2" alt=""
5. pgAdmin4 실행
5.1 pgAdmin4 실행
위치 : pgAdmin4.exe는 설치한 pgAdmin 4\v4\runtime에 위치되어있음.
data:image/s3,"s3://crabby-images/5d125/5d12581c68060f0aa4902d9df889db4158836522" alt=""
5.2 접속 테스트 및 접속 완료
data:image/s3,"s3://crabby-images/11ff7/11ff7b028e9127ab1f18fdb3173c0fe1a28bdfca" alt=""
data:image/s3,"s3://crabby-images/998ef/998ef459ca388d9636a8b358ed23662f949f4459" alt=""
5.3 쿼리 작성
data:image/s3,"s3://crabby-images/0a567/0a567a0866981fb5e8e7e53642ea3a54fbebf34c" alt=""