Re: scalability of cvs

From
Victor Sudakov (2:5020/400)
To
Ilya Kulagin
Date
2006-11-21T11:08:16Z
Area
RU.UNIX.BSD
From: Victor Sudakov <vas@mpeks.tomsk.su>

Ilya Kulagin wrote:

>  VS>>  у меня gserver, а не pserver. Так вот, при $CVSROOT указывающем на
>  VS>>  локальный каталог, checkout занимает 1.5 мин, а по TCP через gserver
>  VS>>  на localhost - 20 мин.

>  EG> Ну, значит это протокол gserver такой тормоз (или его кто-то еще
>  EG> тормозит). Что делать, не знаю - слово gserver вижу впервые.

> Проэкспериментировал: залил в cvs 15000 файлов. 
> 1. Через pserver с пустым рабочим каталогом сделал checkout. Ровно час. 
> 2. Поменял три файла, на заполненном рабочем каталоге, через pserver сделал
> checkout. 40 секунд.

Да, согласуется с моими наблюдениями.

А можешь ещё провести хронометраж при работе через локальный путь, не
через сеть?

> 3. Через pserver сделал export в новый каталог. Полторы минуты.

> Таким образом, если просто нужны сами файлы - то export поможет.
> Если нужен именно рабочий каталог, то в первый раз придётся
> подождать. 

Нужен именно рабочий каталог. Ждать несколько десятков секунд на
каждый update и commit уже надоело.

> С другой стороны, на хотя бы беглое чтение хотя бы краткого описания
> к 15000 файлов всяко уйдёт больше времени. Вот как раз будет чем
> заняться.

> Ну и, на самом деле, держать весь проект в одном каталоге - это не очень
> здравая идея. По крайней мере, мне ещё ни разу таких проектов не попадалось,
> которые не были бы, на самом деле, разбиты на обозримые подпроекты.

Это не проект, а DNS зона. Которая сильно выросла.

Можно было бы перегруппировать все эти мелкие файлы, например, по
подкаталогам [a-z], но всем известно, какой pain in the ass
перемещение файлов в CVS. Да и всё равно иногда нужно сказать update
на всё.

-- 
Victor Sudakov,  VAS4-RIPE, VAS47-RIPN
2:5005/49@fidonet http://vas.tomsk.ru/
--- ifmail v.2.15dev5.3
 * Origin: AO "Svyaztransneft", SibPTUS (2:5020/400)
SEEN-BY: 50/12 400/814 450/159 1024 461/43 132 640 469/999 4616/3 4625/8
SEEN-BY: 4641/444 5000/76 5000 5006/1 5007/1 5010/70 5011/13 5012/46 5015/28
SEEN-BY: 5019/31 5020/18 175 194 400 545 982 1057 1909 1922 2238 2395 2871
SEEN-BY: 5020/4441 5021/29 5025/3 5026/14 45 5027/12 5030/1080 1957 5034/10 13
SEEN-BY: 5035/3 38 5036/1 5045/7 5049/1 5051/15 5054/1 4 8 9 11 28 35 36 37 45
SEEN-BY: 5054/63 66 67 70 75 84 85 5059/9 5060/88 5061/15 5062/10 5063/3
SEEN-BY: 5064/7 5066/18 5075/5 5076/1 5077/70 5080/1003 5084/9 5085/13 5095/20
SEEN-BY: 5096/18 6001/10
PATH: 5020/400 545 5054/1 37