From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Date: Tue, 8 Sep 2020 22:05:30 +0300 From: "Dmitry V. Levin" To: ALT Devel discussion list Message-ID: <20200908190530.GA32490@altlinux.org> References: <20200908001233.GA18009@dad.imath.kiev.ua> <20200908150137.GA29502@altlinux.org> MIME-Version: 1.0 Content-Type: text/plain; charset=koi8-r Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: Subject: Re: [devel] hasher unchecked_initroot_cache X-BeenThere: devel@lists.altlinux.org X-Mailman-Version: 2.1.12 Precedence: list Reply-To: ALT Linux Team development discussions List-Id: ALT Linux Team development discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 08 Sep 2020 19:05:31 -0000 Archived-At: List-Archive: List-Post: On Tue, Sep 08, 2020 at 06:09:11PM +0300, Anton Farygin wrote: > On 08.09.2020 18:01, Dmitry V. Levin wrote: > > On Tue, Sep 08, 2020 at 03:12:33AM +0300, Igor Vlasenko wrote: > >> Оптимизируем hasher для работы с фиксированным репозиторием. II. > >> ________________________________________________________________ > >> > >> При запуске hasher, если hasher/cache/ уже есть, > >> то hasher проверяет, не изменился ли репозиторий, и если изменился, > >> то обновляет hasher/cache/, иначе использует hasher/cache/. > >> > >> По условиям задачи у нас фиксированный репозиторий. Это означает, > >> что репозиторий не меняется без нашего ведома -- к примеру, > >> локальное зеркало ежедневного релиза Сизифа. > >> > >> Вторая оптимизация позволяет ускорять любые работы с hasher. > >> > >> Ее суть проста: поскольку мы явно знаем, что репозиторий не менялся, > >> то сообщить об этом hasher'у опцией вроде --same-repository, > >> чтобы он поверил человеку на слово, пропустил тяжелые проверки, > >> и сразу использовал свой hasher/cache/. > > Я думаю, что поддержка $unchecked_initroot_cache, которая была реализована > > весной прошлого года в hasher-1.3.36, предназначена для решения именно > > этой задачи. Эта оптимизация используется в install check на сборочнице. > > > > Пример использования: > > unchecked_initroot_cache="$(sed '/^task[[:space:]]\+/!d;s///;q' /path/to/Sisyphus/files/list/task.info)" > > > а можно для тупых объяснить что это делает и как ? unchecked_initroot_cache - это конфигурационная настройка, похожая на конфигурационную настройку no_cache, только к no_cache есть cli в виде --no-cache, а к unchecked_initroot_cache нет. В пояснении к unchecked_initroot_cache написано следующее: # Whether the initroot cache is unchecked. # Unchecked initroot cache allows more efficient initroot caching, # but its validity is the responsibility of the user. По умолчанию значением unchecked_initroot_cache является пустая строка. Если unchecked_initroot_cache имеет значение, отличное от пустой строки, то hasher сравнивает это значение со значением unchecked_initroot_cache, которое было на момент создания cache, и если эти значения совпадают, то обычная проверка актуальности cache не производится. Настройку вида unchecked_initroot_cache="$(sed '/^task[[:space:]]\+/!d;s///;q' /path/to/Sisyphus/files/list/task.info)" не рекомендуется использовать без --without-stuff по очевидной причине. > Опцией было бы понятнее, конечно. Есть мнение, что контролировать эту настройку с помощью cli не очень удобно, но если будет предложен удачный вариант cli, то я не против. -- ldv