From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.1 (2015-04-28) on sa.local.altlinux.org X-Spam-Level: X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FROM autolearn=ham autolearn_force=no version=3.4.1 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:references:from:message-id:date:user-agent:mime-version :in-reply-to:content-transfer-encoding:content-language; bh=upgKHjyUbPC0eVok1zL984d0VcSK7FYelytOS4nbkQY=; b=TQnk0eXLpx+a94eG1rSt0Vj9KgUNoU+R5Q5lnmpf/zDt0be41e0cAPlPliwnJIo0oZ xZoQl9HC9Oh9FoADLejfyLMFScVX7Mb2nF3QJnusVDJzZVpfXm+4/p6i7sqg7jFSSgJW JfQX2W3n93AtSeiEBgt8wnhnH4NdGpujK5x7VEzgrRJe03DwZ+20N1sMzc1BV1mDsoiZ CAf3PsjfxtzCoqqA+HYcO788PzNpDCP6HOLuDFqHrOhStvAVEz2TwaHtDv8tsrzbnxDQ LmJEhYgENEzXSXlIDSThBr19fko4g0JiO/MOIjPY0U0KNi27Zlot62n6Y7gYBwjYVFBE 4t3g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding :content-language; bh=upgKHjyUbPC0eVok1zL984d0VcSK7FYelytOS4nbkQY=; b=aTxtpMMswOAlqqKxpahNWAZodyNU2Muje3YDdUm2XlpCKV0dhw75UmNK/RVecIB2+t YnmLGQfzpaqC0g+b8FBcVzvnDxxX466F40pXiteoJzyHTfjppYlhktfw+QOg3nQJKLv7 GS58i4FE+POFUMwgL5VAp5EjERerrrZNFWwHxydY0/cE2h9yMX2u+E/db/gxwgoxxpQp xnlfqfjtdse1yoWyPivFMP1xaS0uZrhTEVc6VsH1oPZIhkT7G4tll4tJ/8LH0bG/84V8 xvq+xvvvesZgtYLR1eZ4YoHPDgwPeHX0Fh8ZQnZ1HiYyz89Tz21juuweqUKawT8FW34z FBLA== X-Gm-Message-State: AOAM530Ad21NRR0CRWunSdWq6+qSZzGQJ9EVS1eNH3HabxXdaciXvufG cWJeXZktcPaxe5J6e5UuEXm24y3oafY= X-Google-Smtp-Source: ABdhPJzKV4fAq9TAKMHMZZG/UnDS38mbmv8BG5cpF4AV1HadryOP2IPyuqmBkTTWl2RlCha2y2NDRA== X-Received: by 2002:a05:651c:23a:: with SMTP id z26mr10405415ljn.257.1598576283286; Thu, 27 Aug 2020 17:58:03 -0700 (PDT) To: devel@lists.altlinux.org References: <20200827022952.GA8129@dad.imath.kiev.ua> <5acc7f44-c122-d4ab-c67b-85275232f482@basealt.ru> <20200827145402.2cc954d1cb8412ffc81d9b11@altlinux.org> <5aa3cdd8-b3b0-a227-ed40-885636deab29@basealt.ru> <20200827120918.GA1072@altlinux.org> <20200827122039.GB1072@altlinux.org> From: Leonid Krivoshein Message-ID: <068a17d6-e7d8-c66e-6dc8-c83155ae87e8@gmail.com> Date: Fri, 28 Aug 2020 03:58:01 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: <20200827122039.GB1072@altlinux.org> Content-Type: text/plain; charset=koi8-r; format=flowed Content-Transfer-Encoding: 8bit Content-Language: ru Subject: Re: [devel] =?utf-8?b?0LDRgNGF0LjQstC40YDQvtCy0LDQvdC40LUg0YDQtdC/?= =?utf-8?b?0L7Qt9C40YLQvtGA0LjQtdCy?= 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: Fri, 28 Aug 2020 00:58:06 -0000 Archived-At: List-Archive: List-Post: 27.08.2020 15:20, Dmitry V. Levin пишет: > On Thu, Aug 27, 2020 at 03:14:27PM +0300, Anton Farygin wrote: >> On 27.08.2020 15:09, Dmitry V. Levin wrote: >>> On Thu, Aug 27, 2020 at 02:59:22PM +0300, Anton Farygin wrote: >>>> On 27.08.2020 14:54, Andrey Savchenko wrote: >>>>> On Thu, 27 Aug 2020 10:27:11 +0300 Anton Farygin wrote: >>>>> [...] >>>>>> Т.е. - для экономии места старые пакеты хардлинкаются в новое место и в >>>>>> него уже добавляются изменения из сборочного задания. Очень простая и >>>>>> очень надёжная схема, при которой риск потери данных минимален и всегда >>>>>> можно взять консистентное состояние репозитория за любой момент времени. >>>>>> >>>>>> Живёт это всё сейчас, вроде как, на ext4 (я могу ошибаться). >>>>>> Максимальное количество inodes у ext4 2^32 - 4,294,967,295 >>>>>> >>>>>> Каждый новый таск в репозиторий приводит к тому, что на файловой системе >>>>>> появляется около 160 тысяч (а может быть и больше, я давно не смотрел >>>>>> цифры) новых записей. >>>>>> >>>>>> Т.е. - условно мы можем записать около 26 тысяч сборочных заданий в >>>>>> архив, а после этого из него придётся удалять что-то старое для того, >>>>>> что бы записать что-то новое. >>>>> Это полная чушь, поскольку все жесткие ссылки на файл используют >>>>> один и тот же inode: >>>>> >>>>> https://ext4.wiki.kernel.org/index.php/Ext4_Disk_Layout#Directory_Entries >>>>> >>>>> In an ext4 filesystem, a directory is more or less a flat file that >>>>> maps an arbitrary byte string (usually ASCII) to an inode number on >>>>> the filesystem. There can be many directory entries across the >>>>> filesystem that reference the same inode number--these are known as >>>>> hard links, and that is why hard links cannot reference files on >>>>> other filesystems. As such, directory entries are found by reading >>>>> the data block(s) associated with a directory file for the >>>>> particular directory entry that is desired. >>>>> >>>> Точно. Не хардлинки, а симлинки. Спасибо за замечание. >>> В архиваторе репозиториев используется захардлинкивание симлинков >>> для уменьшения количества используемых inode'ов. >> Ух ты, это же здорово. А где посмотреть исходники ? >> >> в girar я сходу это не увидел. > git grep GA_SYMLINK_DIR. > > В ext4 есть ограничение на количество хардлинков, которе может быть > у симлинка, я постарался это учесть. rm -rf ... всё же очень дорогая операция на изначально не 64-бит ФС. В этом плане jfs рвёт её на части. Может, есть смысл бега для этих фс? -- Best regards, Leonid Krivoshein.