.env를 crontab에서 인식하지 못하는 문제 수정

This commit is contained in:
2025-12-19 10:02:54 +09:00
parent 338c0c0d1c
commit d2fbfa46c1
15 changed files with 318 additions and 152 deletions

48
build/app/Dockerfile Normal file
View File

@ -0,0 +1,48 @@
FROM ubuntu:22.04
ENV DEBIAN_FRONTEND=noninteractive \
LANG=ko_KR.UTF-8 \
LANGUAGE=ko_KR:ko \
LC_ALL=ko_KR.UTF-8
RUN apt-get update && \
apt-get install -y --no-install-recommends \
locales tzdata bash python3 python3-pip cron curl unzip wget gnupg ca-certificates \
xvfb x11-utils libglib2.0-0 libnss3 libgconf-2-4 libfontconfig1 \
libxss1 libxshmfence1 libasound2 libxtst6 libappindicator3-1 \
fonts-nanum libu2f-udev && \
locale-gen ko_KR.UTF-8 && \
ln -sf /usr/share/zoneinfo/Asia/Seoul /etc/localtime && \
dpkg-reconfigure --frontend noninteractive tzdata && \
ln -sf /usr/bin/python3 /usr/bin/python && \
curl -fsSL https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb -o chrome.deb && \
apt-get install -y ./chrome.deb && rm chrome.deb && \
apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
# Python 패키지 설치
RUN pip install --no-cache-dir --upgrade pip && \
pip install --no-cache-dir \
selenium>=4.10 \
pymysql \
ftputil \
pillow \
pyvirtualdisplay \
requests \
python-dotenv
WORKDIR /app
RUN fc-cache -f -v
COPY app/ /app/
# 로그 디렉토리 생성
RUN mkdir -p /logs && chmod 777 /logs
# Crontab 설정: 매일 09:00에 절대 경로로 Python 실행
# cron은 컨테이너의 환경 변수를 상속받으므로 env_file로 주입된 변수들을 사용 가능
RUN echo "0 9 * * * /usr/bin/python /app/gnu_autoupload.py >> /logs/cron.log 2>&1" | crontab - && \
chmod 666 /logs
# Cron을 포그라운드에서 실행 (docker logs에 출력되도록)
CMD ["/usr/sbin/cron", "-f"]

28
build/app/run.sh Normal file
View File

@ -0,0 +1,28 @@
#!/bin/bash
# 이 스크립트는 수동 실행 시 사용됩니다.
# Crontab은 python을 직접 실행하므로 이 스크립트를 거치지 않습니다.
log() {
echo "[$(date '+%Y-%m-%d %H:%M:%S')] $*"
}
log "========================================"
log "날씨 정보 자동 게시글 생성 시작"
log "========================================"
cd /app
if [ -f "gnu_autoupload.py" ]; then
/usr/bin/python gnu_autoupload.py 2>&1
EXIT_CODE=$?
if [ $EXIT_CODE -eq 0 ]; then
log "✅ 실행 완료 (종료 코드: $EXIT_CODE)"
else
log "❌ 실행 실패 (종료 코드: $EXIT_CODE)"
fi
else
log "❌ 오류: gnu_autoupload.py 파일을 찾을 수 없습니다"
exit 1
fi
log "========================================"