Gentoo Forums
Gentoo Forums
Gentoo Forums
Quick Search: in
Is it possible to max out modern hardware with portage?
View unanswered posts
View posts from last 24 hours

Goto page Previous  1, 2  
Reply to topic    Gentoo Forums Forum Index Portage & Programming
View previous topic :: View next topic  
Author Message
logrusx
Advocate
Advocate


Joined: 22 Feb 2018
Posts: 2390

PostPosted: Fri Jul 19, 2024 7:31 pm    Post subject: Reply with quote

eccerr0r wrote:
Lol I was inspecting
Code:
# qlop -mvt virtual/*

and I notice
Code:
2023-02-25T21:23:15 >>> virtual/editor-0-r4: 19'19"

I don't think it really took 20 minutes, but it was probably waiting on a lock for 19 minutes...


Quite possible. Or if this was a laptop, you might have suspended it.

Best Regards,
Georgi
Back to top
View user's profile Send private message
therik
n00b
n00b


Joined: 14 Jul 2024
Posts: 7

PostPosted: Sat Jul 20, 2024 5:18 pm    Post subject: Reply with quote

wanne32 wrote:
If you set your load average to 31 and your parallel processes per CPU also to 31 it is more or less clear that it rarely starts a second process. This will hamper your CPU-utilisation but maybe not so much your compile time since more cache hits will compensate for the idle time.

But also compiling it on only 32G tmpfs sounds scarce for bigger things like firefox/kde/chromium. What are you compiling? Can it be that you are satisfying your internet connection since you are compiling a lot of big things without much compiletime?

Also llvm/clang are these packages that usually also stop my CPU running on max. The compilation process doesn't seems very parallel and a lot of other packages depend on it. So you can not go on with compiling other packages.


I was recompiling everything, it was #emerge --emptytree @world and I was looking at the load numbers and memory usage from free and top, SSD read/write speeds and network statistics in KDE system monitor, I dunno where the KDE data is fundamentally pulled from. df -h was reporting that the tmpfs in /var/tmp/portage was rarely above 2.5 gigs, despite having 32 gigs available, which also seems a bit suspicious. You can see on the outputs I copied in the first post what the typical values were. Compiling LLVM, gcc and few others packages did hit the load limit from makeopts, but portage is also set to 30-ish jobs and it was never even remotely close. Obviously, when make spawns 32 processes for a big package, it's expected that portage won't do anything until that's done, but vast majority of the time, there isn't anything big compiling in the background.

That's kind of the gist of what I'm trying to say, that the compilation can easily max out the hardware limits on big packages, but when emerging 1000 small packages, it's nowhere near that.

Basically, considering that most packages are small, the compilation itself is not even remotely the bottleneck.

If you indulge me, just to really nail this point down, if I use 6.6.30 as a crude benchmark, it looks like this:
Code:
Gentoo /usr/src/linux # make distclean --silent
Gentoo /usr/src/linux # cp /tmp/.config .config
Gentoo /usr/src/linux # time make --silent -j31

real    2m42.899s
user    50m37.359s
sys     8m27.441s


A minute in I see
Code:
top - 17:35:27 up  6:28,  1 user,  load average: 29.19, 9.97, 3.93
Tasks: 579 total,  34 running, 545 sleeping,   0 stopped,   0 zombie
%Cpu(s): 81.8 us, 18.0 sy,  0.0 ni,  0.2 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
MiB Mem :  64223.8 total,  53052.7 free,   7078.1 used,   5054.8 buff/cache     
MiB Swap:  16312.0 total,  16312.0 free,      0.0 used.  57145.8 avail Mem
in a parallel terminal.

It baloons up in in memory, does its thing and it's done before the kettle boils the tea. But if I need to do 1000 small packages, I'll have to let it run over night, which is frankly a little bit silly.

Just as logrusx's post shows:
logrusx wrote:
It took me ~8 hours to emerge ~1600 packages using the binary packages host.

This is not a compiliation thing. This is portage twiddling its thumbs.
Back to top
View user's profile Send private message
wanne32
n00b
n00b


Joined: 11 Nov 2023
Posts: 69

PostPosted: Sat Jul 20, 2024 11:22 pm    Post subject: Reply with quote

Quote:
df -h was reporting that the tmpfs in /var/tmp/portage was rarely above 2.5 gigs, despite having 32 gigs available, which also seems a bit suspicious.
Indeed. Sounds to me like some things are not compiled in /var/tmp/portage. But be aware that only chrome, firefox and khtml are realy big packages and finished packages are removed. So as long as you are not compiling these low usage is normal.
Quote:
but portage is also set to 30-ish jobs and it was never even remotely close. Obviously, when make spawns 32 processes for a big package, it's expected that portage won't do anything until that's done, but vast majority of the time, there isn't anything big compiling in the background.
This is very similar for me I set load-average to 64 for that reason.
Quote:
That's kind of the gist of what I'm trying to say, that the compilation can easily max out the hardware limits on big packages, but when emerging 1000 small packages, it's nowhere near that.
That is kind of normal. You like to have a transaction based system for installing to minimize the risk of ending in an inconsistent state witch will result in a lot of waiting processes. yum/dnf is even worse in that regard. But usually compiling the bigger packages will outwight that by far. In an optimal scenario you would try to always have an big package compiling while there is one downloading and one installing. urpmi was able to do something like that by piping downloads directly to cpio. Similarly you could do btrfs snapshots and run your stuff on eatmydata and roll back if the update fails. But portage has no such intelligent scheduling and usually starts with downloading a lot of small packages at the same time to later compile bigger packages in parallel. Since the whole emerge time is usually dominated by compile times I doubt that anyone is willing to invest time in optimizing that.
Because like I said: You should be much faster than 8h on an modern day nvme/DDR5/tmpfs computer.
Her on my PC:
Code:
#time emerge virtual/ssh
Calculating dependencies... done!
Dependency resolution took 0.82 s (backtrack: 0/20).

>>> Emerging binary (1 of 1) virtual/ssh-0-r2::gentoo
>>> Installing (1 of 1) virtual/ssh-0-r2::gentoo
>>> Completed (1 of 1) virtual/ssh-0-r2::gentoo
>>> Jobs: 1 of 1 complete                           Load avg: 1.23, 1.17, 1.10

 * GNU info directory index is up-to-date.

real    0m5.437s
user    0m3.700s
sys     0m1.044s
# time emerge help
Dependency resolution took 0.56 s (backtrack: 0/20).


emerge: there are no ebuilds to satisfy "help".

emerge: searching for similar names...
emerge: Maybe you meant any of these: dev-qt/qthelp, gnome-extra/yelp, media-sound/helm, app-emacs/helm, app-admin/helm?

real    0m1.709s
user    0m1.131s
sys     0m0.142s

So virtual/ssh without starting emerge takes 3.7s on a modern day mid-range PC virtual/editor takes 3.3s. For my 1029 packages that would amount to a full hour. This is still a lot. But be aware that there also where real things happening. It used in average more than a core. So if you have a few compiled packages the will easily saturate your CPU for that time.
Back to top
View user's profile Send private message
therik
n00b
n00b


Joined: 14 Jul 2024
Posts: 7

PostPosted: Tue Jul 23, 2024 1:19 pm    Post subject: Reply with quote

wanne32 wrote:
Since the whole emerge time is usually dominated by compile times I doubt that anyone is willing to invest time in optimizing that.


If the report in this thread is correct, and emerging 1600 packages from binary took 8 hours, it would seem that emerge time is not dominated by compile times at all.

wanne32 wrote:
You should be much faster than 8h on an modern day nvme/DDR5/tmpfs computer


Code:
# time emerge --ask=n -1 virtual/ssh
Calculating dependencies... done!
Dependency resolution took 1.29 s (backtrack: 0/20).

>>> Verifying ebuild manifests
>>> Emerging (1 of 1) virtual/ssh-0-r2::gentoo
>>> Installing (1 of 1) virtual/ssh-0-r2::gentoo
>>> Completed (1 of 1) virtual/ssh-0-r2::gentoo
>>> Jobs: 1 of 1 complete                           Load avg: 0.65, 0.61, 0.40

 * GNU info directory index is up-to-date.

 * IMPORTANT: 3 config files in '/etc' need updating.
 * See the CONFIGURATION FILES and CONFIGURATION FILES UPDATE TOOLS
 * sections of the emerge man page to learn how to update config files.

real    0m8.012s
user    0m5.269s
sys     0m2.094s

Code:
# time emerge --ask=n -1 virtual/editor
Calculating dependencies... done!
Dependency resolution took 1.38 s (backtrack: 0/20).

>>> Verifying ebuild manifests
>>> Emerging (1 of 1) virtual/editor-0-r7::gentoo
>>> Installing (1 of 1) virtual/editor-0-r7::gentoo
>>> Completed (1 of 1) virtual/editor-0-r7::gentoo
>>> Jobs: 1 of 1 complete                           Load avg: 0.79, 0.64, 0.41

 * GNU info directory index is up-to-date.

 * IMPORTANT: 3 config files in '/etc' need updating.
 * See the CONFIGURATION FILES and CONFIGURATION FILES UPDATE TOOLS
 * sections of the emerge man page to learn how to update config files.

real    0m8.118s
user    0m5.276s
sys     0m2.220s

Code:
# time emerge help

These are the packages that would be merged, in order:

Calculating dependencies... done!
Dependency resolution took 0.80 s (backtrack: 0/20).


emerge: there are no ebuilds to satisfy "help".

emerge: searching for similar names...
emerge: Maybe you meant any of these: dev-qt/qthelp, gnome-extra/yelp, app-admin/helm, app-emacs/helm, media-sound/helm?

real    0m1.419s
user    0m1.189s
sys     0m0.133s


Why are my numbers so different?
Back to top
View user's profile Send private message
logrusx
Advocate
Advocate


Joined: 22 Feb 2018
Posts: 2390

PostPosted: Tue Jul 23, 2024 3:28 pm    Post subject: Reply with quote

therik wrote:

If the report in this thread is correct, and emerging 1600 packages from binary took 8 hours, it would seem that emerge time is not dominated by compile times at all.


Those were binary packages!

Precisely it took 6:25, I checked and it's a few posts above. I think one big package and a few smaller compiled for about an hour or so. I can check that too but I don't think it's important.

EDIT: noticeably longer compile times were for two packages, one 15 and one 20 minutes, I haven't counted the vast majority of packages which took below or around a minute. I don'r temember statistics and I sure don't want to count how many were not binary packages.

p.s.
therik wrote:


Why are my numbers so different?


Because you have a different tree of installed packages and dependency resolution takes different time.

p.s.2 I'm out.

Best Regards,
Georgi
Back to top
View user's profile Send private message
Genone
Retired Dev
Retired Dev


Joined: 14 Mar 2003
Posts: 9605
Location: beyond the rim

PostPosted: Tue Jul 23, 2024 4:52 pm    Post subject: Reply with quote

therik wrote:
Why are my numbers so different?

Obviously because your system hardware and configuration is different.
Back to top
View user's profile Send private message
Display posts from previous:   
Reply to topic    Gentoo Forums Forum Index Portage & Programming All times are GMT
Goto page Previous  1, 2
Page 2 of 2

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum