Mercurial > p > roundup > code
annotate scripts/Docker/Dockerfile @ 7117:9f3ca362a415
pip update outdated packages
Specifically to handle issue with setuptools package as distributed
with python:3-alpine.
https://github.com/roundup-tracker/roundup/security/code-scanning/111
But it does a generic update of packages. I expect the packages I
explicitly install will already be up to date. This could be an issue
if I need to pinning/freeze specific versions in requirements.txt.
| author | John Rouillard <rouilj@ieee.org> |
|---|---|
| date | Wed, 28 Dec 2022 20:07:30 -0500 |
| parents | 031cdb92fa1d |
| children | 59908110ccc9 |
| rev | line source |
|---|---|
|
6520
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
1 # build in root dir using: |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
2 # |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
3 # docker build -t roundup-app --rm -f scripts/Dockerfile . |
|
6520
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
4 # |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
5 # run using: |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
6 # |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
7 # docker run --rm -v /.../issue.tracker:/usr/src/app/tracker \ |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
8 # -p 9017:8080 roundup-app:latest |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
9 |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
10 |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
11 # Global vars for all build stages |
|
6520
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
12 |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
13 # application directory |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
14 ARG appdir=/usr/src/app |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
15 |
|
6530
6bf22b7b23fe
Add local_pip source and add healthcheck.
John Rouillard <rouilj@ieee.org>
parents:
6527
diff
changeset
|
16 # support roundup install from 'local' directory, |
|
6bf22b7b23fe
Add local_pip source and add healthcheck.
John Rouillard <rouilj@ieee.org>
parents:
6527
diff
changeset
|
17 # 'local_pip' local directory using pip to install or |
|
6bf22b7b23fe
Add local_pip source and add healthcheck.
John Rouillard <rouilj@ieee.org>
parents:
6527
diff
changeset
|
18 # latest release from 'pypi' |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
19 ARG source=local |
|
6520
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
20 |
|
7042
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
21 # Python version as a.b Used for installation directory and |
|
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
22 # COPY from install dir in second stage. |
|
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
23 ARG pythonversion=3.11 |
|
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
24 |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
25 FROM python:3-alpine as build |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
26 |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
27 # Inherit global values https://github.com/moby/moby/issues/37345 |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
28 ARG appdir |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
29 |
|
6520
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
30 WORKDIR $appdir |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
31 |
|
6994
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
32 # Update to get security and other improvements; |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
33 RUN apk --update-cache upgrade |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
34 |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
35 # Add packages needed to compile mysql, pgsql and other python modules. |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
36 # Can't use apk to add them as that installs a 3.9 python version. |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
37 # g++ installs cc1plus needed by pip install |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
38 RUN apk add \ |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
39 g++ \ |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
40 gcc \ |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
41 gpgme-dev \ |
|
6575
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
42 libxapian \ |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
43 linux-headers \ |
|
6575
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
44 make \ |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
45 musl-dev \ |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
46 mysql-dev \ |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
47 postgresql-dev \ |
|
6575
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
48 swig \ |
|
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
49 xapian-core-dev |
|
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
50 |
|
7042
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
51 ARG pythonversion |
|
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
52 # verify that pythonversion matches the one in the image. |
|
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
53 RUN image_python_version=$(python -c 'import sys; print("%s.%s"%sys.version_info[0:2])'); \ |
|
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
54 if [ "${pythonversion}" != "${image_python_version}" ]; then \ |
|
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
55 printf "\n\n*****\npythonversion does not match.\n" ; \ |
|
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
56 printf "Add:\n --build-arg=\"pythonversion=${image_python_version}\"\nto docker build\n******\n\n"; \ |
|
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
57 exit 1; \ |
|
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
58 fi |
|
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
59 |
|
6575
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
60 # build xapian bindings: |
|
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
61 # file with sphinx build dependencies to remove after build |
|
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
62 # they are over 70MB of space. |
|
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
63 COPY scripts/Docker/sphinxdeps.txt . |
|
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
64 |
|
6994
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
65 # suppress warning when running pip as root |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
66 ENV PIP_ROOT_USER_ACTION=ignore |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
67 |
|
6575
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
68 RUN set -xv && CWD=$PWD && \ |
|
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
69 VER=$(apk list -I 'xapian-core-dev' | \ |
|
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
70 sed 's/^xapian-core-dev-\([0-9.]*\)-.*/\1/') && \ |
|
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
71 cd /tmp && \ |
|
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
72 wget https://oligarchy.co.uk/xapian/$VER/xapian-bindings-$VER.tar.xz && \ |
|
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
73 tar -Jxvf xapian-bindings-$VER.tar.xz && \ |
|
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
74 cd xapian-bindings-$VER/ && \ |
|
6686
2eadad009010
Remove sphinx 1.8.5 limit. Use current pipy version.
John Rouillard <rouilj@ieee.org>
parents:
6575
diff
changeset
|
75 pip --no-cache-dir install sphinx && \ |
|
7040
60ea33643a01
Anchore Container Scan docker bulld is failing.
John Rouillard <rouilj@ieee.org>
parents:
6994
diff
changeset
|
76 sed -i -e '/PYTHON3_SO=/s/distutils\.//g' \ |
|
60ea33643a01
Anchore Container Scan docker bulld is failing.
John Rouillard <rouilj@ieee.org>
parents:
6994
diff
changeset
|
77 -e '/PYTHON3_SO=/s/"SO"/"EXT_SUFFIX"/g' configure && \ |
|
6575
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
78 ./configure --prefix=/usr/local --with-python3 --disable-documentation && \ |
|
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
79 make && make install && \ |
|
6797
a24ec63759f6
Docker fix healthcheck; allow modules; cleanup; set uid
John Rouillard <rouilj@ieee.org>
parents:
6686
diff
changeset
|
80 pip uninstall --no-cache-dir -y sphinx && \ |
|
6575
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
81 pip uninstall --no-cache-dir -y -r $CWD/sphinxdeps.txt |
|
6520
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
82 |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
83 # add requirements for pip here, e.g. Whoosh, gpg, zstd or other |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
84 # modules not installed in the base library. |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
85 # ignore warnings from pip to use virtualenv |
|
6555
34cbd0e633d2
Added FastCGI deployment info, updated Docker docs; docker-compose added
John Rouillard <rouilj@ieee.org>
parents:
6530
diff
changeset
|
86 COPY scripts/Docker/requirements.txt . |
|
6520
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
87 RUN pip install --no-cache-dir -r requirements.txt |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
88 |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
89 # copy the elements of the release directory to the docker image |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
90 COPY setup.py install/ |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
91 COPY doc install/doc/ |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
92 COPY frontends install/frontends/ |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
93 COPY locale install/locale/ |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
94 COPY roundup install/roundup/ |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
95 COPY share install/share/ |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
96 |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
97 # verify source has one of two valid values then |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
98 # install in python3 standard directories from local copy |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
99 # or install in python3 standard directories from pypi using pip |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
100 # import from global/command line |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
101 ARG source |
|
6527
5ad7fb912227
issue2551167 - update wheel support.
John Rouillard <rouilj@ieee.org>
parents:
6523
diff
changeset
|
102 RUN set -xv && if [ "$source" = "local" ] || \ |
|
5ad7fb912227
issue2551167 - update wheel support.
John Rouillard <rouilj@ieee.org>
parents:
6523
diff
changeset
|
103 [ "$source" = "pypi" ] || \ |
|
5ad7fb912227
issue2551167 - update wheel support.
John Rouillard <rouilj@ieee.org>
parents:
6523
diff
changeset
|
104 [ "$source" = "local_pip" ]; then :; \ |
|
6520
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
105 else echo "invalid value for source: $source"; \ |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
106 echo "must be local or pypi"; exit 1; fi; \ |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
107 if [ "$source" = "local" ]; then cd install && ./setup.py install; fi; \ |
|
6527
5ad7fb912227
issue2551167 - update wheel support.
John Rouillard <rouilj@ieee.org>
parents:
6523
diff
changeset
|
108 if [ "$source" = "local_pip" ]; then cd install && pip install \ |
|
5ad7fb912227
issue2551167 - update wheel support.
John Rouillard <rouilj@ieee.org>
parents:
6523
diff
changeset
|
109 --use-feature=in-tree-build . ; fi; \ |
|
6523
49d26e77d173
issue2551163 Docker/containerization support - pypi fix
John Rouillard <rouilj@ieee.org>
parents:
6522
diff
changeset
|
110 if [ "$source" = "pypi" ]; then pip install roundup; \ |
|
7042
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
111 cp -ril /usr/local/lib/python${pythonversion}/site-packages/usr/local/share/* \ |
|
6523
49d26e77d173
issue2551163 Docker/containerization support - pypi fix
John Rouillard <rouilj@ieee.org>
parents:
6522
diff
changeset
|
112 /usr/local/share; fi |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
113 |
|
6994
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
114 # Allow user to add more modules during build |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
115 ARG pip_mod |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
116 RUN if [ -n "$pip_mod" ]; then pip install --no-cache-dir ${pip_mod}; fi |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
117 |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
118 # build a new smaller docker image for execution. Build image above |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
119 # is 1G in size. |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
120 FROM python:3-alpine |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
121 |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
122 # import from global |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
123 ARG appdir |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
124 |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
125 WORKDIR $appdir |
|
6520
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
126 |
|
6994
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
127 # suppress warning when running pip as root |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
128 ENV PIP_ROOT_USER_ACTION=ignore |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
129 |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
130 # upgrade to get any security updates; bundle with |
|
7117
9f3ca362a415
pip update outdated packages
John Rouillard <rouilj@ieee.org>
parents:
7042
diff
changeset
|
131 # rest of apk actions to reduce layers/wasted space |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
132 # add libraries needed to run gpg/mysql/pgsql/brotli |
|
6994
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
133 # clean out any caches to save space |
|
7117
9f3ca362a415
pip update outdated packages
John Rouillard <rouilj@ieee.org>
parents:
7042
diff
changeset
|
134 # upgrade pip packages to get security and other updates |
|
9f3ca362a415
pip update outdated packages
John Rouillard <rouilj@ieee.org>
parents:
7042
diff
changeset
|
135 # bundle with apk updates |
|
6994
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
136 RUN apk --update-cache upgrade; \ |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
137 apk add \ |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
138 brotli-libs \ |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
139 gpgme \ |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
140 mariadb-connector-c \ |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
141 libpq \ |
|
6575
c3c636feace3
Ass support for xapian indexer.
John Rouillard <rouilj@ieee.org>
parents:
6566
diff
changeset
|
142 libstdc++ \ |
|
6994
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
143 libxapian \ |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
144 zstd-libs; \ |
|
7117
9f3ca362a415
pip update outdated packages
John Rouillard <rouilj@ieee.org>
parents:
7042
diff
changeset
|
145 rm -f /var/cache/apk/*; \ |
|
9f3ca362a415
pip update outdated packages
John Rouillard <rouilj@ieee.org>
parents:
7042
diff
changeset
|
146 upgrades=$(python3 -m pip --no-cache --disable-pip-version-check \ |
|
9f3ca362a415
pip update outdated packages
John Rouillard <rouilj@ieee.org>
parents:
7042
diff
changeset
|
147 list --outdated | awk 'NR > 2 {print $1}'); \ |
|
9f3ca362a415
pip update outdated packages
John Rouillard <rouilj@ieee.org>
parents:
7042
diff
changeset
|
148 if [ -n "$upgrades" ]; then \ |
|
9f3ca362a415
pip update outdated packages
John Rouillard <rouilj@ieee.org>
parents:
7042
diff
changeset
|
149 echo Pip updating $upgrades; \ |
|
9f3ca362a415
pip update outdated packages
John Rouillard <rouilj@ieee.org>
parents:
7042
diff
changeset
|
150 python -m pip --no-cache --disable-pip-version-check \ |
|
9f3ca362a415
pip update outdated packages
John Rouillard <rouilj@ieee.org>
parents:
7042
diff
changeset
|
151 install -U $upgrades; \ |
|
9f3ca362a415
pip update outdated packages
John Rouillard <rouilj@ieee.org>
parents:
7042
diff
changeset
|
152 else \ |
|
9f3ca362a415
pip update outdated packages
John Rouillard <rouilj@ieee.org>
parents:
7042
diff
changeset
|
153 echo Nothing to pip update; \ |
|
9f3ca362a415
pip update outdated packages
John Rouillard <rouilj@ieee.org>
parents:
7042
diff
changeset
|
154 fi |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
155 |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
156 ARG source |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
157 LABEL "org.roundup-tracker.vendor"="Roundup Issue Tracker Team" \ |
|
6994
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
158 "org.roundup-tracker.description"="Roundup Issue Tracker multi-backend" \ |
|
4336e655b2be
Update packages in docker image; supress pip warning; improve cache
John Rouillard <rouilj@ieee.org>
parents:
6797
diff
changeset
|
159 "version"="2.2.0 $source" \ |
|
6566
8f1fddb71422
Add maintainer address (via label) to rounduo-devel list.
John Rouillard <rouilj@ieee.org>
parents:
6555
diff
changeset
|
160 "org.opencontainers.image.authors"="roundup-devel@lists.sourceforge.net" |
|
8f1fddb71422
Add maintainer address (via label) to rounduo-devel list.
John Rouillard <rouilj@ieee.org>
parents:
6555
diff
changeset
|
161 |
|
7042
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
162 ARG pythonversion |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
163 # pull over built assets |
|
7042
031cdb92fa1d
Replace hardcoded python version with ARG variable
John Rouillard <rouilj@ieee.org>
parents:
7041
diff
changeset
|
164 COPY --from=build /usr/local/lib/python${pythonversion}/site-packages /usr/local/lib/python${pythonversion}/site-packages/ |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
165 COPY --from=build /usr/local/bin/roundup* /usr/local/bin/ |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
166 COPY --from=build /usr/local/share /usr/local/share/ |
|
6555
34cbd0e633d2
Added FastCGI deployment info, updated Docker docs; docker-compose added
John Rouillard <rouilj@ieee.org>
parents:
6530
diff
changeset
|
167 COPY scripts/Docker/roundup_start . |
|
6797
a24ec63759f6
Docker fix healthcheck; allow modules; cleanup; set uid
John Rouillard <rouilj@ieee.org>
parents:
6686
diff
changeset
|
168 COPY scripts/Docker/roundup_healthcheck . |
|
a24ec63759f6
Docker fix healthcheck; allow modules; cleanup; set uid
John Rouillard <rouilj@ieee.org>
parents:
6686
diff
changeset
|
169 |
|
a24ec63759f6
Docker fix healthcheck; allow modules; cleanup; set uid
John Rouillard <rouilj@ieee.org>
parents:
6686
diff
changeset
|
170 # make roundup scripts execuable and mount a trackerdir on tracker location |
|
a24ec63759f6
Docker fix healthcheck; allow modules; cleanup; set uid
John Rouillard <rouilj@ieee.org>
parents:
6686
diff
changeset
|
171 RUN chmod +x roundup_start roundup_healthcheck; mkdir tracker |
|
a24ec63759f6
Docker fix healthcheck; allow modules; cleanup; set uid
John Rouillard <rouilj@ieee.org>
parents:
6686
diff
changeset
|
172 VOLUME $appdir/tracker |
|
6520
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
173 |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
174 # map port 8080 to your local port |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
175 EXPOSE 8080/tcp |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
176 |
|
6530
6bf22b7b23fe
Add local_pip source and add healthcheck.
John Rouillard <rouilj@ieee.org>
parents:
6527
diff
changeset
|
177 HEALTHCHECK --start-period=1m \ |
|
6797
a24ec63759f6
Docker fix healthcheck; allow modules; cleanup; set uid
John Rouillard <rouilj@ieee.org>
parents:
6686
diff
changeset
|
178 CMD ./roundup_healthcheck |
|
6530
6bf22b7b23fe
Add local_pip source and add healthcheck.
John Rouillard <rouilj@ieee.org>
parents:
6527
diff
changeset
|
179 |
|
6686
2eadad009010
Remove sphinx 1.8.5 limit. Use current pipy version.
John Rouillard <rouilj@ieee.org>
parents:
6575
diff
changeset
|
180 # do not run roundup as root. This creates roundup user and group. |
|
6797
a24ec63759f6
Docker fix healthcheck; allow modules; cleanup; set uid
John Rouillard <rouilj@ieee.org>
parents:
6686
diff
changeset
|
181 ARG roundup_uid |
|
a24ec63759f6
Docker fix healthcheck; allow modules; cleanup; set uid
John Rouillard <rouilj@ieee.org>
parents:
6686
diff
changeset
|
182 RUN adduser -D -h ${appdir} -u ${roundup_uid:-1000} roundup |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
183 USER roundup |
|
6520
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
184 |
|
6522
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
185 # run the server, disable output buffering so we can see logs. |
|
e6ae8188f61a
issue2551163 Docker/containerization support
John Rouillard <rouilj@ieee.org>
parents:
6520
diff
changeset
|
186 ENV PYTHONUNBUFFERED=1 |
|
6555
34cbd0e633d2
Added FastCGI deployment info, updated Docker docs; docker-compose added
John Rouillard <rouilj@ieee.org>
parents:
6530
diff
changeset
|
187 #ENTRYPOINT [ "roundup-server", "-n", "0.0.0.0" ] |
|
34cbd0e633d2
Added FastCGI deployment info, updated Docker docs; docker-compose added
John Rouillard <rouilj@ieee.org>
parents:
6530
diff
changeset
|
188 ENTRYPOINT [ "./roundup_start" ] |
|
6520
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
189 |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
190 # allow the invoker to override cmd with multiple trackers |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
191 # in each subdirectory under $appdir/tracker. E.G. |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
192 # docker run .... \ |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
193 # issues=tracker/issues foo=tracker/foo |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
194 # |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
195 # note using "issue=$appdir/tracker" results in error: |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
196 # |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
197 # No valid configuration files found in directory /usr/src/app/$appdir/tracker |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
198 # |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
199 # so $appdir not expanded and $PWD prefixed onto the (relative path) |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
200 # $appdir/tracker. Hence use relative path for spec. |
|
26babdf85067
issue2551163 - add starter docker
John Rouillard <rouilj@ieee.org>
parents:
diff
changeset
|
201 CMD [ "issues=tracker" ] |
