ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [devel] make ninja-build fast again
@ 2025-05-14 17:54 Ivan A. Melnikov
  0 siblings, 0 replies; only message in thread
From: Ivan A. Melnikov @ 2025-05-14 17:54 UTC (permalink / raw)
  To: ALT Linux Team development discussions

Приветствую.

Я тут обнаружил, что ninja-build в Сизифе стал как-то хтонически
небыстр. Чтобы оценить масштаб трагедии, я собрал из подручных
материалов небольшой бенчмарк[1], запустив который на tmpfs
получил потрясающие результаты:

make  -- 0:01.00elapsed 
samu  -- 0:00.90elapsed
ninja -- 0:45.00elapsed

Реально, в 45 раз мелненнее make и в 50 раз медленнее samurai?
Её нужно спасать!

В логах обнаружилось, что при сборке ninja потерялся %optflags,
и она собиралась вообще без оптимизаций. Вернув %optflags,
я добился ускорения чуть больше чем в 2 раза, до ~19 секунд.

Однако возвращение %optflags позволило убрать параметр `--debug`,
всё равно получая работоспособный debuginfo (да, я проверял)
у сборочного скрипта, что, благодаря -DNDEBUG, вернуло
производительность ninja в норму.

В таком виде пакет ушёл в Сизиф (задача 384155 DONE,
надеюсь никому ничего не сломал).

Предлагаю мейнтейнеру как-то проверять производительность
при последующих обновлениях. Также можно перейти на сборку
cmake'ом, как это сделали, например, в debian, чтобы всяческие
best practices следовали за собой сами.

[1] https://git.altlinux.org/people/iv/public/?p=build-tool-benchmarks.git

-- 
  wbr,
    iv m.


^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2025-05-14 17:54 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-05-14 17:54 [devel] make ninja-build fast again Ivan A. Melnikov

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