Saturday, November 4, 2023

Crontab의 시간 설정

 ubuntu:~$ crontab -l

# Edit this file to introduce tasks to be run by cron.

# Each task to run has to be defined through a single line

# indicating with different fields when the task will be run

# and what command to run for the task

# To define the time you can provide concrete values for

# minute (m), hour (h), day of month (dom), month (mon),

# and day of week (dow) or use '*' in these fields (for 'any').

# Notice that tasks will be started based on the cron's system

# daemon's notion of time and timezones.

# Output of the crontab jobs (including errors) is sent through

# email to the user the crontab file belongs to (unless redirected).

# For example, you can run a backup of all your user accounts

# at 5 a.m every week with:

# 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/

# For more information see the manual pages of crontab(5) and cron(8)

#  4시와 오후 

# m h  dom mon dow   command

40 04,16 * * * sudo /sbin/reboot


ubuntu:~$ 


Crontab의 시간 설정

배치Batch처럼 특정 시간에 정기적으로 ShellScript나 프로그램을 실행 시키기 위한 Crontab 시간 설정을 정리해 둔다.

Desc

  • 기본적으로 아래와 같이 공백(space)으로 5개 값을 구분하여 설정한다.
  1 11 3 * * <SHELL_PATH>
  분 시 일 월 요일 쉘스크립트경로
  • 1번째
    • 분(minute)을 의미, 몇 분에 실행 할 것인지 설정한다.
    • ex) 1 11 3 * * <SHELL_PATH>
      • XX일 XX시 '01분'에 실행
      • *을 설정할 경우, 매분(1분 마다) 실행을 의미
  • 2번째
    • 시간(hour)을 의미, 몇 시에 실행 할 것인지 설정한다.
    • ex) 1 11 3 * * <SHELL_PATH>
      • XX일 '11시' 01분에 실행
      • *을 설정할 경우, 매시간(1시간 마다) 실행을 의미
  • 3번째
    • 일(day of month)을 의미, 몇 일에 실행 할 것인지 설정한다.
    • ex) 1 11 3 * * <SHELL_PATH>
      • '3일' 11시 01분에 실행
      • *을 설정할 경우, 매일 실행을 의미
  • 4번째
    • 월(month)을 의미, 몇 월에 실행 할 것인지 설정한다.
    • ex) 1 11 3 5 * <SHELL_PATH>
      • '5월' 3일 11시 01분에 실행
      • *을 설정할 경우, 매월 실행을 의미
  • 5번째
    • 요일(day of week)을 의미, 무슨 요일에 실행 할 것인지 설정한다.
    • 0 ~ 6 사이의 값을 설정 (0: 일요일, 6: 토요일)
    • ex) 1 11 3 * 3 <SHELL_PATH>
      • 매달 3일 11시 01분 수요일에 실행
      • *을 설정할 경우, 매일 실행을 의미

Examples

ExpressionsDesc
* * * * *매일 1분마다 실행
5 * * * *매일 매시간 05분에 실행 (1시간 간격으로 실행)
*/5 * * * *매일 5분마다 실행
*/10 * * * *매일 10분마다 실행
0,10,20,30,40,50 * * * *매일 10분마다 실행
0 18 * * *매일 18시 00분에 실행
45 22 * * *매일 22시 45분에 실행
28 03 * * *매일 03시 28분에 실행
* 1 * * *매일 01시 00분 ~ 01시 59분 사이에 1분 간격으로 실행
0 */1 * * *매일 1시간 간격으로 실행 (매시간 00분)
0 */12 * * *매일 12시간마다 실행
0 6,12 * * *매일 06시, 12시에 실행
10 2-5 * * *매일 02시 ~ 05시 사이 매시간 10분에 실행
(02시 10분, 03시 10분, 04시 10분, 05시 10분)
5 8-20/3 * * *매일 08시 ~ 20시 사이 3시간 간격으로 05분에 실행
(08시 05분, 11시 05분, 14시 05분, 17시 05분, 20시 05분)
42 4 10 * *매달 10일 04시 42분에 실행
30 5 1,15 * *매달 1일과 15일 05시 30분에 실행
0-10 17 1 * *매달 1일 17시 00분 ~ 17시 10분까지 1분 단위로 실행
0 17 * * 1매주 월요일 17시 00분에 실행
0,10 17 * * 0,2,3매주 일, 화, 수요일 17시 00분과 17시 10분에 실행
0 0 1,15 * 1매달 1일과 15일 그리고 월요일 24시 00분에 실행
0 6,12 * * 0,3수, 일요일마다 06시, 12시에 실행
0 21 * * 1-6월 ~ 토 21시 00분에 실행

참고- 리눅스 crontab 시간 설정 방법 예제 샘플

Friday, November 3, 2023

postgreSQL의 pg_hba.conf 파일 설정

 pg_hba.conf 파일은 PostgreSQL에서 클라이언트 인증 설정을 저장하는 파일입니다. 이 파일의 각 줄은 특정 유형의 연결 요청에 대해 어떤 인증 방법을 사용할지 지정합니다.

당신이 제공한 pg_hba.conf의 내용을 한글로 설명하면 다음과 같습니다:

  1. Database administrative login by Unix domain socket

    • 유닉스 도메인 소켓을 통한 데이터베이스 관리자 로그인
    sql
    local all postgres peer
    • local은 유닉스 도메인 소켓 연결을 의미합니다.
    • all은 모든 데이터베이스를 의미합니다.
    • postgrespostgres 사용자를 의미합니다.
    • peer 인증은 운영체제 사용자와 PostgreSQL 사용자의 이름이 동일하다고 가정하고 인증합니다.
  2. "local" is for Unix domain socket connections only

    sql
    local all all peer
    • 모든 데이터베이스, 모든 사용자에 대한 유닉스 도메인 소켓 연결은 peer 인증 방식을 사용합니다.
  3. IPv4 local connections:

    css
    host all all 0.0.0.0/0 md5 host all all 127.0.0.1/32 trust
    • 첫 번째 줄은 모든 IPv4 주소에서의 연결에 대해 md5 인증 방식을 사용합니다.
    • 두 번째 줄은 로컬호스트(127.0.0.1)에서의 연결에 대해 인증 없이 접근을 허용합니다(trust).
  4. IPv6 local connections:

    css
    host all all ::1/128 scram-sha-256
    • IPv6 로컬호스트(::1)에서의 연결에 대해 scram-sha-256 인증 방식을 사용합니다.
  5. Allow replication connections from localhost, by a user with the replication privilege.

    sql
    local replication all peer host replication all 127.0.0.1/32 scram-sha-256 host replication all ::1/128 scram-sha-256
    • 복제 권한을 가진 사용자가 로컬호스트에서 복제 연결을 수행할 때의 인증 설정입니다.
  6. Other Connections:

    css
    host all all 172.26.0.0/16 trust
    • 172.26.0.0/16 IP 범위에서의 모든 연결에 대해 인증 없이 접근을 허용합니다(trust).

이 설정은 데이터베이스의 보안 수준과 연결 허용 범위를 결정하는 중요한 역할