-
Notifications
You must be signed in to change notification settings - Fork 6
/
PipDockerfile
73 lines (62 loc) · 1.81 KB
/
PipDockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
FROM python:3.11-slim-buster
RUN apt-get update \
# Install aws-lambda-cpp build dependencies
&& apt-get install -y \
g++ \
make \
cmake \
unzip \
# cleanup package lists, they are not used anymore in this image
&& rm -rf /var/lib/apt/lists/* \
&& apt-cache search linux-headers-generic
ARG FUNCTION_DIR="/function"
# Copy function code
RUN mkdir -p ${FUNCTION_DIR}
# Update pip
RUN pip install --upgrade --ignore-installed pip wheel six setuptools \
&& pip install --upgrade --no-cache-dir --ignore-installed \
awslambdaric \
boto3 \
redis \
httplib2 \
requests \
numpy \
scipy \
pandas \
pika \
kafka-python \
cloudpickle \
ps-mem \
tblib \
psutil
# Set working directory to function root directory
WORKDIR ${FUNCTION_DIR}
# Add Lithops
COPY lithops_lambda.zip ${FUNCTION_DIR}
RUN unzip lithops_lambda.zip \
&& rm lithops_lambda.zip \
&& mkdir handler \
&& touch handler/__init__.py \
&& mv entry_point.py handler/
# Put your dependencies here, using RUN pip install... or RUN apt install...
RUN pip install --upgrade --no-cache-dir --ignore-installed \
arraylake \
pystac-client \
odc-stac \
odc-geo \
psycopg2-binary \
rasterio \
dask_image \
numexpr \
scikit-image \
distributed \
cartopy \
s3fs
RUN pip install --upgrade --no-cache-dir --ignore-installed --no-deps deprecat datacube odc-algo
# need to run this to create the proper dask config file
RUN python -c "import dask"
# check that imports actually work
RUN python -c "from odc.algo import erase_bad, mask_cleanup"
ENV ZARR_V3_EXPERIMENTAL_API=1
ENTRYPOINT [ "/usr/local/bin/python", "-m", "awslambdaric" ]
CMD [ "handler.entry_point.lambda_handler" ]