Alpine compiles Docker ngawangun pikeun Python 50 kali laun, jeung gambar anu 2 kali heavier

Alpine compiles Docker ngawangun pikeun Python 50 kali laun, jeung gambar anu 2 kali heavier

Alpine Linux sering disarankeun salaku gambar dasar pikeun Docker. Anjeun disarioskeun yén ngagunakeun Alpine bakal ngajantenkeun wangunan anjeun langkung alit sareng prosés ngawangun anjeun langkung gancang.

Tapi upami anjeun nganggo Alpine Linux pikeun aplikasi Python, maka éta:

  • Ngajadikeun wangunan anjeun leuwih laun
  • Ngajadikeun gambar anjeun leuwih badag
  • Ngabuang waktos anjeun
  • Sarta dina tungtungna eta bisa ngabalukarkeun kasalahan dina runtime


Hayu urang tingali naha Alpine disarankeun, tapi naha anjeun masih teu kedah nganggo Python.

Naha jalma nyarankeun Alpine?

Anggap urang peryogi gcc salaku bagian tina gambar urang sareng urang hoyong ngabandingkeun Alpine Linux vs Ubuntu 18.04 dina hal ngawangun kacepetan sareng ukuran gambar ahir.

Mimiti, hayu urang unduh dua gambar sareng bandingkeun ukuranana:

$ docker pull --quiet ubuntu:18.04
docker.io/library/ubuntu:18.04
$ docker pull --quiet alpine
docker.io/library/alpine:latest
$ docker image ls ubuntu:18.04
REPOSITORY          TAG        IMAGE ID         SIZE
ubuntu              18.04      ccc6e87d482b     64.2MB
$ docker image ls alpine
REPOSITORY          TAG        IMAGE ID         SIZE
alpine              latest     e7d92cdc71fe     5.59MB

Sakumaha anjeun tiasa tingali, gambar dasar pikeun Alpine langkung alit. Hayu ayeuna urang cobian masang gcc sareng mimitian ku Ubuntu:

FROM ubuntu:18.04
RUN apt-get update && 
    apt-get install --no-install-recommends -y gcc && 
    apt-get clean && rm -rf /var/lib/apt/lists/*

Nulis Dockerfile anu sampurna saluareun ruang lingkup tulisan ieu.

Hayu urang ngukur laju assembly:

$ time docker build -t ubuntu-gcc -f Dockerfile.ubuntu --quiet .
sha256:b6a3ee33acb83148cd273b0098f4c7eed01a82f47eeb8f5bec775c26d4fe4aae

real    0m29.251s
user    0m0.032s
sys     0m0.026s
$ docker image ls ubuntu-gcc
REPOSITORY   TAG      IMAGE ID      CREATED         SIZE
ubuntu-gcc   latest   b6a3ee33acb8  9 seconds ago   150MB

Urang ngulang sami pikeun Alpine (Dockerfile):

FROM alpine
RUN apk add --update gcc

Urang ngumpul, kasampak di waktu jeung ukuran assembly:

$ time docker build -t alpine-gcc -f Dockerfile.alpine --quiet .
sha256:efd626923c1478ccde67db28911ef90799710e5b8125cf4ebb2b2ca200ae1ac3

real    0m15.461s
user    0m0.026s
sys     0m0.024s
$ docker image ls alpine-gcc
REPOSITORY   TAG      IMAGE ID       CREATED         SIZE
alpine-gcc   latest   efd626923c14   7 seconds ago   105MB

Sakumaha anu dijanjikeun, gambar dumasar Alpine dikumpulkeun langkung gancang sareng langkung alit: 15 detik tibatan 30 sareng ukuran gambarna 105MB versus 150MB. Ieu geulis alus!

Tapi lamun urang pindah ka ngawangun aplikasi Python, lajeng sagalana teu jadi rosy.

gambar Python

Aplikasi Python sering nganggo pandas sareng matplotlib. Ku alatan éta, hiji pilihan nyaéta nyandak gambar dumasar-Debian resmi nganggo Dockerfile ieu:

FROM python:3.8-slim
RUN pip install --no-cache-dir matplotlib pandas

Hayu urang kumpulkeun:

$ docker build -f Dockerfile.slim -t python-matpan.
Sending build context to Docker daemon  3.072kB
Step 1/2 : FROM python:3.8-slim
 ---> 036ea1506a85
Step 2/2 : RUN pip install --no-cache-dir matplotlib pandas
 ---> Running in 13739b2a0917
Collecting matplotlib
  Downloading matplotlib-3.1.2-cp38-cp38-manylinux1_x86_64.whl (13.1 MB)
Collecting pandas
  Downloading pandas-0.25.3-cp38-cp38-manylinux1_x86_64.whl (10.4 MB)
...
Successfully built b98b5dc06690
Successfully tagged python-matpan:latest

real    0m30.297s
user    0m0.043s
sys     0m0.020s

Kami kéngingkeun gambar ukuranana 363MB.
Naha urang bakal langkung saé sareng Alpine? Hayu urang coba:

FROM python:3.8-alpine
RUN pip install --no-cache-dir matplotlib pandas

$ docker build -t python-matpan-alpine -f Dockerfile.alpine .                                 
Sending build context to Docker daemon  3.072kB                                               
Step 1/2 : FROM python:3.8-alpine                                                             
 ---> a0ee0c90a0db                                                                            
Step 2/2 : RUN pip install --no-cache-dir matplotlib pandas                                                  
 ---> Running in 6740adad3729                                                                 
Collecting matplotlib                                                                         
  Downloading matplotlib-3.1.2.tar.gz (40.9 MB)                                               
    ERROR: Command errored out with exit status 1:                                            
     command: /usr/local/bin/python -c 'import sys, setuptools, tokenize; sys.argv[0] = '"'"'/
tmp/pip-install-a3olrixa/matplotlib/setup.py'"'"'; __file__='"'"'/tmp/pip-install-a3olrixa/matplotlib/setup.py'"'"';f=getattr(tokenize, '"'"'open'"'"', open)(__file__);code=f.read().replace('"'"'rn'"'"', '"'"'n'"'"');f.close();exec(compile(code, __file__, '"'"'exec'"'"'))' egg_info --egg-base /tmp/pip-install-a3olrixa/matplotlib/pip-egg-info                              

...
ERROR: Command errored out with exit status 1: python setup.py egg_info Check the logs for full command output.
The command '/bin/sh -c pip install matplotlib pandas' returned a non-zero code: 1

Aya naon dina?

Alpine teu ngarojong roda

Upami anjeun ningali ngawangun, anu dumasar kana Debian, anjeun bakal ningali yén éta ngaunduh matplotlib-3.1.2-cp38-cp38-manylinux1_x86_64.whl.

Ieu binér pikeun kabayang. Alpine ngundeur sumber `matplotlib-3.1.2.tar.gz` Kusabab éta henteu ngadukung standar roda.

Naha? Seuseueurna distribusi Linux nganggo versi GNU (glibc) tina perpustakaan standar C, anu saleresna diperyogikeun ku unggal program anu ditulis dina C, kalebet Python. Tapi Alpine nganggo `musl`, sareng kumargi binari éta dirancang pikeun `glibc`, aranjeunna sanés pilihan.

Ku alatan éta, lamun make Alpine, anjeun kudu compile sakabeh kode ditulis dina C dina unggal pakét Python.

Oh, enya, anjeun kedah milarian daptar sadaya katergantungan sapertos anu kedah disusun nyalira.
Dina hal ieu urang meunang ieu:

FROM python:3.8-alpine
RUN apk --update add gcc build-base freetype-dev libpng-dev openblas-dev
RUN pip install --no-cache-dir matplotlib pandas

Sareng waktos ngawangun butuh ...

... 25 menit 57 detik! Sareng ukuran gambarna 851MB.

Gambar dumasar-alpine butuh waktu anu langkung lami pikeun ngawangun, ukuranana langkung ageung, sareng anjeun masih kedah milarian sadaya katergantungan. Anjeun tangtu bisa ngurangan ukuran assembly ngagunakeun multi-tahap ngawangun tapi hartina malah leuwih gawé kudu dipigawé.

Éta henteu sadayana!

Alpine tiasa nyababkeun bug anu teu kaduga dina waktos jalanna

  • Dina tiori, musl cocog sareng glibc, tapi dina prakna bédana tiasa nyababkeun seueur masalah. Tur upami aranjeunna, aranjeunna meureun bakal pikaresepeun. Ieu sababaraha masalah anu tiasa lumangsung:
  • Alpine ngabogaan ukuran tumpukan thread leutik sacara standar, nu bisa ngakibatkeun kasalahan dina Python
  • Sababaraha pangguna mendakan éta Aplikasi Python langkung laun sabab cara musl allocates memori (beda jeung glibc).
  • Salah sahiji pangguna kapanggih kasalahan nalika pormat tanggal

Pasti kasalahan ieu parantos dilereskeun, tapi saha anu terang bakal aya sabaraha deui.

Entong nganggo gambar Alpine pikeun Python

Upami anjeun henteu hoyong repot sareng gedong anu ageung sareng panjang, milarian katergantungan sareng kamungkinan kasalahan, entong nganggo Alpine Linux salaku gambar dasar. Milih hiji gambar dasar alus.

sumber: www.habr.com

Tambahkeun komentar