前提・実現したいこと
Docker,Docker-composeでpythonを使ったWebスクレイピング環境を作り、それをcronで自動実行させたいと思っています。
https://qiita.com/sikkim/items/447b72e6ec45849058cd
この記事の方法に、cronなどをインストールする記述を加えてそれを実現させようとしています。ソースコードは以下のようになっています。
該当のソースコード
ディレクトリの構成は以下のようになっています。
selenium/
├ python-selenium/
│ └ Dockerfile
│ └ root
├ script/
│ └ sample.py
└ docker-compose.yml
Dockerfile
1FROM python:3 2 3RUN set -x && \ 4 apt-get update && \ 5 apt-get install -y vim cron tzdata && \ 6 pip install selenium 7 8USER root 9 10COPY root /var/spool/cron/crontabs/ 11 12RUN ln -sf /usr/share/zoneinfo/Asia/Tokyo /etc/localtime
docker-compose.yml
selenium-hub: image: selenium/hub container_name: 'selenium-hub' ports: - 4444:4444 chrome: image: selenium/node-chrome-debug container_name: 'chrome' links: - selenium-hub:hub ports: - 5900:5900 volumes: - /dev/shm:/dev/shm python: build: './python-selenium' container_name: 'python' links: - selenium-hub:hub command: 'tail -f /dev/null' working_dir: '/root/script/' restart: always tty: true volumes: - ./script/:/root/script/ - './python-selenium/root:/var/spool/cron/crontabs/root' environment: - 'TZ=Asia/Tokyo' - 'EDITOR=vim'
root
1PATH=/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin 2 3# min hour day month weekday command 4*/1 * * * * python /root/script/sample.py >> /root/script/cron.log 2>&1
発生している問題・エラーメッセージ
$ docker-compose up -d --build $ docker-compose exec python bash # コンテナ内に入る $ chmod 600 /var/spool/cron/crontabs/root $ service cron restart
これらを実行したのですが、pythonの実行がされません。
試したこと
コンテナ内で以下の操作をしました。
# パスが間違っているのではないかと考えました。 $ echo $PATH /usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin # cronの起動ができていないのではと考えました。 $ service cron status [ ok ] cron is running. # 改行コードが間違っているのではないかと考えました。 $ od -c /var/spool/cron/crontabs/root 0000000 P A T H = / u s r / l o c a l / 0000020 b i n : / u s r / l o c a l / s 0000040 b i n : / u s r / l o c a l / b 0000060 i n : / u s r / s b i n : / u s 0000100 r / b i n : / s b i n : / b i n 0000120 \n \n # m i n h o u r 0000140 d a y m o n t h 0000160 w e e k d a y c o m m a n 0000200 d \n * / 1 * 0000220 * * 0000240 * p y t h o n 0000260 / r o o t / s c r i p t / s a 0000300 m p l e . p y > > / r o o t 0000320 / s c r i p t / c r o n . l o g 0000340 2 > & 1 \n 0000346 # cronは実行されているが、pythonが実行できていないのではないかと思い、コマンドを直接実行しました $ python /root/script/sample.py >> /root/script/cron.log 2>&1 # scriptにcron.logが作られ、問題なく動作しました。
補足情報(FW/ツールのバージョンなど)
MacOS
Docker version 20.10.2
docker-compose version 1.27.4
初めてのteratailの利用で、わかりにくいなどありましたら申し訳ありません。ご回答よろしくお願いします。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。