From: TJ <tj@sheer.tj>
To: Edouard Klein <edou@rdklein.fr>
Cc: help-guix@gnu.org
Subject: Re: Docker image sizes
Date: Mon, 19 Jul 2021 00:10:39 -0700 [thread overview]
Message-ID: <87o8ayvkwg.fsf@sheer.tj> (raw)
In-Reply-To: <87eebxf2u8.fsf@rdklein.fr>
Thanks for the tip. I'm going to try to compile a minimal erlang.
Edouard Klein <edou@rdklein.fr> writes:
> Hi !
>
> You can use guix graph to see what depends on what, and find out why a
> specific dependency is needed:
>
> https://guix.gnu.org/manual/en/html_node/Invoking-guix-graph.html
>
> I just invoked:
> guix graph elixir > /tmp/toto.dot
>
> and by manually inspecting the dot file I can see that e.g. webkit is needed
> by wxWidgets, whether you need those or not is up to you.
>
> You can generate the visual graph with
> dot -T pdf < /tmp/toto.dot > /tmp/toto.pdf
>
> I'm looking at it right now, and I see that elixir depends on erlang and
> git, and that git is pulling perl with it.
>
> I doubt that's needed, so maybe you can create a new package
> "lean-elixir", and forego the dependency on git somehow ? If you cut a
> branch early in the DAG you may get huge returns on investment,
> size-wise.
>
>
> This may not be the best approach, maybe some wizards here will have
> better ideas.
>
> Cheers,
>
> Edouard.
> TJ writes:
>
>> Hi,
>>
>> I was trying to package a project in docker and to start I did a fairly
>> straightforward command:
>>
>> $ guix pack --format=docker elixir
>>
>> It generated an image quite a bit larger than I expected.
>>
>> -r--r--r-- 2 root root 461M Dec 31 1969 gfnqg760z22vr8kbvyzdzhs1hc5766c9-elixir-docker-pack.tar.gz
>>
>> After uncompressing, this is taking 1.5GB and is including quite a few
>> unnecessary packages for a minimal image - see below for the top 30.
>>
>> $ du -s * |sort -g -r | head -n 30
>> 155804 g3idjpqsp2p2d163qfzskxj4k58nrx7f-llvm-11.0.0
>> 145164 m59c9hj9d4n65maimbpmx2xq56d2mvqs-mesa-20.2.4
>> 111708 q233v022vziq8ry18y8q959k110vclvf-webkitgtk-2.32.1
>> 110840 cgqj7xswlpvhzxwri3mcqfs1fhbgnka8-erlang-23.2.1
>> 103940 qk5v5vzwfl066zch67nxlv4x7aspf0fx-samba-4.13.4
>> 93972 cw8brvxkzp4kmdqldsv1wkvi2cv4kq4x-python-3.8.2
>> 64620 8zvc5mvk0xm3ygrxsgpyy5ilxb5rzjry-perl-5.30.2
>> 56300 18hp7flyb3yid3yp49i6qcdq0sbi5l1n-guile-3.0.2
>> 52748 nscar35x261xky08qih2ddxq1b105qwd-gtk+-3.24.24
>> 41092 fa6wj5bxkj5ll1d7292a70knmyl7a0cr-glibc-2.31
>> 39544 2wqjj3mkqdvsvksndr2hpjpi7qqwi7kr-icu4c-66.1
>> 35848 fi1mdh30b5q6zvplvayn68lb575xcd1k-ghostscript-with-cups-9.52
>> 34768 01b4w3m6mp55y531kyi1g8shh722kwqm-gcc-7.5.0-lib
>> 34188 wjmydimw608k61qxmsifkam11jwgpric-wxwidgets-3.0.5.1
>> 24224 jv6v8p8jbjf6hpscgp3dgdfylrdhldi1-gdk-pixbuf+svg-2.40.0
>> 18488 n8awazyldv9hbzb7pjcw76hiifmvrpvd-coreutils-8.32
>> 18464 57xj5gcy1jbl9ai2lnrqnpr0dald9i65-coreutils-8.32
>> 16596 jsqxxnaj5p8a22mrsvl679gi7jl26z4j-glib-2.62.6
>> 16400 aza259fsrb841zwb4rjzfzs2nrsf28f1-eudev-3.2.9
>> 16060 9z185s19zp2p9yq8gdayxgibaphxfcps-cups-2.3.3
>> 15604 4l2il4wcxjb443xwc2arwixpq28pbfvl-cups-minimal-2.3.3
>> 14140 02z5vgdhgxw4gcjvhx51mvy1ax4lzxmp-fftwf-3.3.8
>> 13912 zzkly5rbfvahwqgcs7crz0ilpi7x5g5p-ncurses-6.2
>> 13096 lv92cmzqjpb8mxygpqdvh0mkkkfi9vmz-libxcb-1.14
>> 10876 n3pjsbpd51x6vqikfglmrdbijflammf6-gst-plugins-base-1.18.2
>> 10588 sayvymkqjl328rsivzlp9r46337rvdmz-pulseaudio-14.0
>> 10084 7y3lvk3xf4im8n44337mc6y0ccysvfia-font-dejavu-2.37
>> 9888 hr1p9l1waam8lk2csdwbzaipf14h9n33-gstreamer-1.18.2
>> 9576 a45p39mgqvfd8kjwibyr0q42k1mw7gmf-util-linux-2.35.1-lib
>> 8812 z3vbqvpgcz7lag9qci074hjry4j3120i-shared-mime-info-1.15
>>
>> I wouldn't expect to need llvm, mesa, webkit, samba, python, perl, gtk, cups, pulseaudio, etc, etc. in a production image.
>>
>> What would be the recommended way to minimize the derivation?
>>
>> Thanks,
>>
>> TJ
next prev parent reply other threads:[~2021-07-19 7:11 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-07-17 5:06 Docker image sizes TJ
2021-07-17 14:10 ` Edouard Klein
2021-07-19 7:10 ` TJ [this message]
2021-07-17 15:53 ` Akib Azmain Turja
2021-08-17 13:19 ` zimoun
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://guix.gnu.org/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87o8ayvkwg.fsf@sheer.tj \
--to=tj@sheer.tj \
--cc=edou@rdklein.fr \
--cc=help-guix@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).