* [devel] Сборочница - правильные настройки.
@ 2018-05-29 20:03 Igor Vlasenko
2018-05-29 20:29 ` Dmitry V. Levin
0 siblings, 1 reply; 5+ messages in thread
From: Igor Vlasenko @ 2018-05-29 20:03 UTC (permalink / raw)
To: devel
Уважаемые коллеги,
чтобы продвинуться с обновлением java
нужна срочная помощь со сборчницей.
Начал обновление gradle. Залил бутстрап,
а полноценный gradle отправить в Сизиф не могу.
На локальной машине gradle собирается. Но там 4 ядра.
На сборчнице же, как предполагаю,
16 или 32 виртуальных ядра и дефолтный
$ ulimit -u
512
Чем это плохо? Непуганные апстримы практикуют индийский код вида
for Runtime.getRuntime().availableProcessors():
create a thread, а иногда, возможно, и fork().
При этом сама JVM thread - прожорлива, запускает JIT threads
по числу availableProcessors().
При вложении индийского кода друг в друга мы с легкостью получаем
C*N^2 threads. Для N=2 или N=4 это чепуха,
но для N=32 это уже немало. На нашей сборчнице
это упирается в ее ulimit -u=512
и сборка падает с unable to create new native thread (Хотя памяти в
системе хватает).
Конкретно с gradle N^2 threads, рождаются не только из-за
самого gradle, (хотя и внутри его есть много подобного кода,
но есть хотя бы ограничивающие опции)
а еще внутри используемых им библиотек (ivy,...?).
Апстрим это рассматривает как неправильную конфигурацию -
если у вас такая крутая машина с N ядер и N Gb памяти -
просто поднимите лимит до соответствующих 4096/8192.
Я так понимаю, со сборочницей мы уже наступали на эти грабли,
на что намекает текущий хак с NPROC=1, чтобы сборочнице
не плохело от make -j32.
Чем плох наш NPROC=1 костыль, что он не универсальный - заточен под make.
Я бы советовал cpuset(7) -- нарезать ноду на K пользователей,
и дать каждому пользователю N/K ядер. Приложения, и в частности, JVM,
будут тогда думать, что запущены на N/K ядерной машине и проблема исчезнет.
и ulimit -u поднять, конечно, XXI век на дворе, все-таки.
Заодно в перспективе это поможет уплотнить сборочные ноды,
чтобы на одной ноде можно было бы параллельно пускать больше сборок.
А прямо сейчас прошу хотя бы только ulimit -u поднять,
чтобы gradle мог собраться и на нашей сборочнице.
--
I V
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [devel] Сборочница - правильные настройки.
2018-05-29 20:03 [devel] Сборочница - правильные настройки Igor Vlasenko
@ 2018-05-29 20:29 ` Dmitry V. Levin
2018-05-29 20:58 ` Igor Vlasenko
0 siblings, 1 reply; 5+ messages in thread
From: Dmitry V. Levin @ 2018-05-29 20:29 UTC (permalink / raw)
To: ALT Devel discussion list
[-- Attachment #1: Type: text/plain, Size: 2637 bytes --]
On Tue, May 29, 2018 at 11:03:25PM +0300, Igor Vlasenko wrote:
> Уважаемые коллеги,
>
> чтобы продвинуться с обновлением java
> нужна срочная помощь со сборчницей.
>
> Начал обновление gradle. Залил бутстрап,
> а полноценный gradle отправить в Сизиф не могу.
> На локальной машине gradle собирается. Но там 4 ядра.
>
> На сборчнице же, как предполагаю,
> 16 или 32 виртуальных ядра и дефолтный
> $ ulimit -u
> 512
>
> Чем это плохо? Непуганные апстримы практикуют индийский код вида
> for Runtime.getRuntime().availableProcessors():
> create a thread, а иногда, возможно, и fork().
> При этом сама JVM thread - прожорлива, запускает JIT threads
> по числу availableProcessors().
> При вложении индийского кода друг в друга мы с легкостью получаем
> C*N^2 threads. Для N=2 или N=4 это чепуха,
> но для N=32 это уже немало. На нашей сборчнице
> это упирается в ее ulimit -u=512
> и сборка падает с unable to create new native thread (Хотя памяти в
> системе хватает).
>
> Конкретно с gradle N^2 threads, рождаются не только из-за
> самого gradle, (хотя и внутри его есть много подобного кода,
> но есть хотя бы ограничивающие опции)
> а еще внутри используемых им библиотек (ivy,...?).
> Апстрим это рассматривает как неправильную конфигурацию -
> если у вас такая крутая машина с N ядер и N Gb памяти -
> просто поднимите лимит до соответствующих 4096/8192.
>
> Я так понимаю, со сборочницей мы уже наступали на эти грабли,
> на что намекает текущий хак с NPROC=1, чтобы сборочнице
> не плохело от make -j32.
Первоначально nprocs=1 был выставлен для лучшей воспроизводимости сборки.
> Чем плох наш NPROC=1 костыль, что он не универсальный - заточен под make.
>
> Я бы советовал cpuset(7) -- нарезать ноду на K пользователей,
> и дать каждому пользователю N/K ядер. Приложения, и в частности, JVM,
> будут тогда думать, что запущены на N/K ядерной машине и проблема исчезнет.
Уже. Я экспериментирую с раздачей по одной numa node на пользователя,
nproc(1) там показывает 8, %__nprocs с недавних пор по умолчанию
содержит то, что выводит nproc(1).
Но некоторые это игнорируют, разными способами (_SC_NPROCESSORS_ONLN,
/proc/stat, /proc/cpuinfo, ...) берут число видимых cpu units,
и получается фигня.
Мы попробовали ограничить видимую часть /proc/stat и /proc/cpuinfo
cpuset'ом, но эксперименты показывают, что, например, maven от этого
сходит с ума:
https://lists.altlinux.org/pipermail/sisyphus-cybertalk/2018-May/103621.html
> и ulimit -u поднять, конечно, XXI век на дворе, все-таки.
Кто-нибудь знает, сколько им надо тредов на N cpu units?
--
ldv
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 801 bytes --]
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [devel] Сборочница - правильные настройки.
2018-05-29 20:29 ` Dmitry V. Levin
@ 2018-05-29 20:58 ` Igor Vlasenko
2018-05-29 21:22 ` Dmitry V. Levin
0 siblings, 1 reply; 5+ messages in thread
From: Igor Vlasenko @ 2018-05-29 20:58 UTC (permalink / raw)
To: ALT Linux Team development discussions
On Tue, May 29, 2018 at 11:29:47PM +0300, Dmitry V. Levin wrote:
> > и ulimit -u поднять, конечно, XXI век на дворе, все-таки.
>
> Кто-нибудь знает, сколько им надо тредов на N cpu units?
есть два кролика для тестирования.
#207136 FAILED #1 sisyphus srpm=gradle-4.3.1-alt1_5jpp8.src.rpm
#207006 FAILED #3 sisyphus srpm=gradle-4.3.1-alt1_5jpp8.src.rpm
207006 - ванильный, собирается на 4-х ядрах.
а в #207136 - пытался везде где можно
вкрутить ручки на минимум - не помогло.
--
I V
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [devel] Сборочница - правильные настройки.
2018-05-29 20:58 ` Igor Vlasenko
@ 2018-05-29 21:22 ` Dmitry V. Levin
2018-05-30 5:13 ` Igor Vlasenko
0 siblings, 1 reply; 5+ messages in thread
From: Dmitry V. Levin @ 2018-05-29 21:22 UTC (permalink / raw)
To: ALT Devel discussion list
[-- Attachment #1: Type: text/plain, Size: 658 bytes --]
On Tue, May 29, 2018 at 11:58:53PM +0300, Igor Vlasenko wrote:
> On Tue, May 29, 2018 at 11:29:47PM +0300, Dmitry V. Levin wrote:
> > > и ulimit -u поднять, конечно, XXI век на дворе, все-таки.
> >
> > Кто-нибудь знает, сколько им надо тредов на N cpu units?
>
> есть два кролика для тестирования.
> #207136 FAILED #1 sisyphus srpm=gradle-4.3.1-alt1_5jpp8.src.rpm
> #207006 FAILED #3 sisyphus srpm=gradle-4.3.1-alt1_5jpp8.src.rpm
>
> 207006 - ванильный, собирается на 4-х ядрах.
Для nproc(1) == 8:
512 было недостаточно, а 1024 хватило.
Т.е. N * 2^6 мало, а N * 2^7 достаточно.
Тем временем ванильный кролик уже в Сизифе.
--
ldv
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 801 bytes --]
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [devel] Сборочница - правильные настройки.
2018-05-29 21:22 ` Dmitry V. Levin
@ 2018-05-30 5:13 ` Igor Vlasenko
0 siblings, 0 replies; 5+ messages in thread
From: Igor Vlasenko @ 2018-05-30 5:13 UTC (permalink / raw)
To: ALT Linux Team development discussions
On Wed, May 30, 2018 at 12:22:51AM +0300, Dmitry V. Levin wrote:
> 512 было недостаточно, а 1024 хватило.
> Т.е. N * 2^6 мало, а N * 2^7 достаточно.
>
> Тем временем ванильный кролик уже в Сизифе.
Большое спасибо!
--
I V
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2018-05-30 5:13 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2018-05-29 20:03 [devel] Сборочница - правильные настройки Igor Vlasenko
2018-05-29 20:29 ` Dmitry V. Levin
2018-05-29 20:58 ` Igor Vlasenko
2018-05-29 21:22 ` Dmitry V. Levin
2018-05-30 5:13 ` Igor Vlasenko
ALT Linux Team development discussions
This inbox may be cloned and mirrored by anyone:
git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \
devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
public-inbox-index devel
Example config snippet for mirrors.
Newsgroup available over NNTP:
nntp://lore.altlinux.org/org.altlinux.lists.devel
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git