以下のベースイメージと、APP側のイメージ作成すると、app側をbuildする際に以下のエラーがでます。
エラー内容について、管理者権限をどのようにOKにするのかよくわかりませんでした。
ベースイメージの以下の部分が曖昧ですが。。。調べても修正方法わかりませんでした。
python -m venv venv
error
1Exception: 2Traceback (most recent call last): 3 File "/home/www/venv/lib/python3.6/site-packages/pip/basecommand.py", line 215, in main 4 status = self.run(options, args) 5 File "/home/www/venv/lib/python3.6/site-packages/pip/commands/install.py", line 360, in run 6 prefix=options.prefix_path, 7 File "/home/www/venv/lib/python3.6/site-packages/pip/req/req_set.py", line 784, in install 8 **kwargs 9 File "/home/www/venv/lib/python3.6/site-packages/pip/req/req_install.py", line 851, in install 10 self.move_wheel_files(self.source_dir, root=root, prefix=prefix) 11 File "/home/www/venv/lib/python3.6/site-packages/pip/req/req_install.py", line 1064, in move_wheel_files 12 isolated=self.isolated, 13 File "/home/www/venv/lib/python3.6/site-packages/pip/wheel.py", line 345, in move_wheel_files 14 clobber(source, lib_dir, True) 15 File "/home/www/venv/lib/python3.6/site-packages/pip/wheel.py", line 316, in clobber 16 ensure_dir(destdir) 17 File "/home/www/venv/lib/python3.6/site-packages/pip/utils/__init__.py", line 83, in ensure_dir 18 os.makedirs(path) 19 File "/usr/lib/python3.6/os.py", line 220, in makedirs 20 mkdir(name, mode) 21PermissionError: [Errno 13] Permission denied: '/home/www/venv/lib/python3.6/site-packages/pytz-2018.5.dist-info' 22The command '/bin/sh -c set -x && ../venv/bin/pip install -r ${requirements}' returned a non-zero code: 2
ベースイメージ
dockerfile
1FROM ubuntu:18.04 AS djample-base 2 3RUN useradd www --create-home --shell /bin/bash 4WORKDIR /home/www 5 6RUN set -x; \ 7 apt-get update -y &&\ 8 apt-get install -y cron &&\ 9 apt-get install python3.6 -y &&\ 10 apt-get install python3-pip -y &&\ 11 apt-get install python3.6-venv -y &&\ 12 apt-get install -y postgresql-client &&\ 13 apt-get install -y libpcre3 libpcre3-dev &&\ 14 ln -f /usr/bin/python3.6 /usr/bin/python &&\ 15 python -m venv venv 16 17ENTRYPOINT bin/bash
APPイメージ
dockerfileapp
1FROM djample-base:latest 2ARG requirements="requirements/requirements.txt" 3ARG preprocess="echo start processing" 4ARG project="djample" 5 6USER www 7RUN mkdir ${project} 8 9WORKDIR /home/www/${project} 10ADD apps/ apps/ 11ADD templates/ templates/ 12ADD static/ static/ 13ADD requirements/ requirements/ 14 15RUN set -x &&\ 16 ../venv/bin/pip install -r ${requirements} 17 18CMD ${preprocess} && ../venv/bin/uwsgi --ini apps/uwsgi.ini
docker最新版をインストール、公式イメージを利用してみるとかしてみてはいかがでしょうか。
一応公式サイトを見て最新版を入れたのですが、うまくいかず。
https://hub.docker.com/_/python
python入りのイメージです
まずエラーが出ているのは
The command '/bin/sh -c set -x && ../venv/bin/pip install -r ${requirements}' returned a non-zero code: 2
です。これはAPPイメージと書かれているDockerfileの
RUN set -x &&\
../venv/bin/pip install -r ${requirements}
に当たるのですが、
requirements/requirements.txt
の内容がこの質問にはありません。この中にあるパッケージの何か(が必要としているpytz)が問題であるようですが。。。
エラーが発生している原因はベースイメージ側にUSER指定がなく、venv仮想環境をrootで作成しているのに、その環境をAPPイメージ側でwwwユーザーで更新しようとしているからだと思います。
現象を再現するために、書かれていない情報を推測させる質問だと、回答やコメントが付きにくいと思います。手順があるなら、明快に書きましょう。Dockerfile自体も書きかけ感が強く、直すべき箇所が結構あるので、回答者はあなたが手順自体を間違えている可能性まで考えてしまいます。
回答1件
あなたの回答
tips
プレビュー