<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>https://lib.custis.ru/index.php?action=history&amp;feed=atom&amp;title=The_Risks_of_Distributed_Version_Control</id>
		<title>The Risks of Distributed Version Control - История изменений</title>
		<link rel="self" type="application/atom+xml" href="https://lib.custis.ru/index.php?action=history&amp;feed=atom&amp;title=The_Risks_of_Distributed_Version_Control"/>
		<link rel="alternate" type="text/html" href="https://lib.custis.ru/index.php?title=The_Risks_of_Distributed_Version_Control&amp;action=history"/>
		<updated>2026-06-13T16:15:43Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.26.4</generator>

	<entry>
		<id>https://lib.custis.ru/index.php?title=The_Risks_of_Distributed_Version_Control&amp;diff=11072&amp;oldid=prev</id>
		<title>BenderBot: 1 версия</title>
		<link rel="alternate" type="text/html" href="https://lib.custis.ru/index.php?title=The_Risks_of_Distributed_Version_Control&amp;diff=11072&amp;oldid=prev"/>
				<updated>2009-06-30T15:43:37Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;table class='diff diff-contentalign-left'&gt;
				&lt;tr style='vertical-align: top;' lang='ru'&gt;
				&lt;td colspan='1' style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan='1' style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 15:43, 30 июня 2009&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan='2' style='text-align: center;' lang='ru'&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>BenderBot</name></author>	</entry>

	<entry>
		<id>https://lib.custis.ru/index.php?title=The_Risks_of_Distributed_Version_Control&amp;diff=11071&amp;oldid=prev</id>
		<title>StasFomin: оформление</title>
		<link rel="alternate" type="text/html" href="https://lib.custis.ru/index.php?title=The_Risks_of_Distributed_Version_Control&amp;diff=11071&amp;oldid=prev"/>
				<updated>2009-06-30T11:06:09Z</updated>
		
		<summary type="html">&lt;p&gt;оформление&lt;/p&gt;
&lt;table class='diff diff-contentalign-left'&gt;
				&lt;col class='diff-marker' /&gt;
				&lt;col class='diff-content' /&gt;
				&lt;col class='diff-marker' /&gt;
				&lt;col class='diff-content' /&gt;
				&lt;tr style='vertical-align: top;' lang='ru'&gt;
				&lt;td colspan='2' style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan='2' style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 11:06, 30 июня 2009&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l30&quot; &gt;Строка 30:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Строка 30:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Это новое поколение систем в корне отличается тем, что доводит идею «изолированных операций» до крайности.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Это новое поколение систем в корне отличается тем, что доводит идею «изолированных операций» до крайности.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;−&lt;/td&gt;&lt;td style=&quot;color:black; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;У каждого пользователя на локальном компьютере хранится полная копия репозитория, т.е. 100% истории проекта.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;+&lt;/td&gt;&lt;td style=&quot;color:black; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;У каждого пользователя на локальном компьютере хранится полная копия репозитория, т.е. &lt;ins class=&quot;diffchange diffchange-inline&quot;&gt;&amp;lt;tt&amp;gt;&lt;/ins&gt;100%&lt;ins class=&quot;diffchange diffchange-inline&quot;&gt;&amp;lt;/tt&amp;gt; &lt;/ins&gt;истории проекта.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Каждый человек фактически сам по себе.&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Каждый человек фактически сам по себе.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Пользователи соединяют свои репозитории между собой как только им угодно&lt;/div&gt;&lt;/td&gt;&lt;td class='diff-marker'&gt;&amp;#160;&lt;/td&gt;&lt;td style=&quot;background-color: #f9f9f9; color: #333333; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #e6e6e6; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Пользователи соединяют свои репозитории между собой как только им угодно&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>StasFomin</name></author>	</entry>

	<entry>
		<id>https://lib.custis.ru/index.php?title=The_Risks_of_Distributed_Version_Control&amp;diff=9891&amp;oldid=prev</id>
		<title>WikiSysop: 1 версия</title>
		<link rel="alternate" type="text/html" href="https://lib.custis.ru/index.php?title=The_Risks_of_Distributed_Version_Control&amp;diff=9891&amp;oldid=prev"/>
				<updated>2008-09-03T16:33:11Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;table class='diff diff-contentalign-left'&gt;
				&lt;tr style='vertical-align: top;' lang='ru'&gt;
				&lt;td colspan='1' style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan='1' style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 16:33, 3 сентября 2008&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan='2' style='text-align: center;' lang='ru'&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>WikiSysop</name></author>	</entry>

	<entry>
		<id>https://lib.custis.ru/index.php?title=The_Risks_of_Distributed_Version_Control&amp;diff=9890&amp;oldid=prev</id>
		<title>StasFomin: {{replicate-from-custiswiki-to-lib}}</title>
		<link rel="alternate" type="text/html" href="https://lib.custis.ru/index.php?title=The_Risks_of_Distributed_Version_Control&amp;diff=9890&amp;oldid=prev"/>
				<updated>2008-09-03T16:29:58Z</updated>
		
		<summary type="html">&lt;p&gt;{{replicate-from-custiswiki-to-lib}}&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;lt;blockquote&amp;gt;&lt;br /&gt;
Перевод статьи [http://blog.red-bean.com/sussman/?p=20 {{PAGENAME}}] выполнен сообществом компании [http://www.custis.ru «Заказные ИнформСистемы»].&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Да, забавно, как времена меняются. &lt;br /&gt;
Когда мы начинали разрабатывать [[Subversion]] пять лет назад, &lt;br /&gt;
[[CVS]] был огромным злобным монстром, которого мы хотели «низвергнуть».&lt;br /&gt;
&lt;br /&gt;
Сегодня, хотя [[Subversion]] есть ещё куда развиваться, он уже достиг критической массы в мире свободного ПО.&lt;br /&gt;
Список рассылки «users@» насчитывает тысячи подписчиков и стал самоподдерживаемым.&lt;br /&gt;
Каждая достаточно крупная свободная операционная система поставляется с относительно новой версией &amp;lt;tt&amp;gt;Subversion&amp;lt;/tt&amp;gt;.&lt;br /&gt;
В книжных магазинах есть небедный выбор книг о &amp;lt;tt&amp;gt;Subversion&amp;lt;/tt&amp;gt;.&lt;br /&gt;
Десятки крупных проектов, таких как &lt;br /&gt;
[[RuPedia:KDE|KDE]], [[RuPedia:Apache|Apache]] и [[RuPedia:GNU Compiler Collection|GCC]] перешли на него.&lt;br /&gt;
Вы уже не удивляетесь, когда вы встречаете проект с открытым исходным кодом, использующий &amp;lt;tt&amp;gt;Subversion&amp;lt;/tt&amp;gt;,&lt;br /&gt;
ведь &amp;lt;tt&amp;gt;SVN&amp;lt;/tt&amp;gt; стала стандартным выбором «по умолчанию» для большинства новых проектов.&lt;br /&gt;
&lt;br /&gt;
А сейчас, приколитесь, появилось целое новое поколение систем контроля версий на горизонте: &lt;br /&gt;
* [[EnPedia:GNU_arch|arch]], &lt;br /&gt;
* [[EnPedia:codeville|codeville]], &lt;br /&gt;
* [[EnPedia:Monotone (software)|monotone]], &lt;br /&gt;
* [[EnPedia:Bazaar (software)|bazaar-ng]], &lt;br /&gt;
* [[EnPedia:SVK|svk]],&lt;br /&gt;
* [[RuPedia:git|git]], &lt;br /&gt;
* [[RuPedia:mercurial|mercurial]].&lt;br /&gt;
&lt;br /&gt;
И эти новички — распределённые системы контроля версий (''DVCS'', ''Distributed Version Control Systems'') — хотят «подсидеть стариков».&lt;br /&gt;
Да, вы не ослышались: &amp;lt;tt&amp;gt;Subversion&amp;lt;/tt&amp;gt; сейчас «Старик».&lt;br /&gt;
Интересно, когда это произошло? :-)&lt;br /&gt;
&lt;br /&gt;
Это новое поколение систем в корне отличается тем, что доводит идею «изолированных операций» до крайности.&lt;br /&gt;
У каждого пользователя на локальном компьютере хранится полная копия репозитория, т.е. 100% истории проекта.&lt;br /&gt;
Каждый человек фактически сам по себе.&lt;br /&gt;
Пользователи соединяют свои репозитории между собой как только им угодно&lt;br /&gt;
и меняются изменениями как коллекциями марок, &lt;br /&gt;
а система автоматически отслеживает, какие «чужие» изменения у вас отражены, а какие — нет.&lt;br /&gt;
&lt;br /&gt;
Что-то свежее и самоутверждающее в этом конечно есть, &lt;br /&gt;
ведь это явно расширяет традиционную централизованную модель [[CVS]] и [[Subversion]].&lt;br /&gt;
Конечно, в каком-нибудь проекте может быть решено, что один выделенный репозитарий является главным,&lt;br /&gt;
а все остальные участники, должны отправлять и получать изменения через него, как и в централизованной модели.&lt;br /&gt;
Но проекты могут быть организованы в более интересные формы:&lt;br /&gt;
древовидную иерархию репозиториев, кольцо репозиториев&lt;br /&gt;
или даже просто произвольно связанный граф, что безусловно, весьма гибко.&lt;br /&gt;
&lt;br /&gt;
Однако сторонники этих систем немного фанатичны в «превосходстве» DVCS над нынешними&lt;br /&gt;
централизованными системами.&lt;br /&gt;
Снова и снова я слышу подобные панегирики:&lt;br /&gt;
«Круто! Если я хочу реализовать новую функциональность, мне вообще не нужно иметь доступ на фиксацию изменений, ведь у меня есть моя личная копия репозитория, и я могу независимо творить и фиксировать новый функционал в своем личном репозитарии, так часто, как мне нужно, пока окончательно не завершу доработку. &lt;br /&gt;
Вот тогда то я все остальным и представлю.»&lt;br /&gt;
&lt;br /&gt;
Звучит как «счастье всем даром, и никто не уйдет обиженным», но мне это видится в более мрачных тонах.&lt;br /&gt;
Смотрите, что хочет сделать этот счастливчик — уползти в пещеру,&lt;br /&gt;
неделями в одиночку корпеть над сложной функциональностью, &lt;br /&gt;
а затем воткнуть «вылизанное» решение в «основной ствол» проекта.&lt;br /&gt;
&lt;br /&gt;
И именно это поведение весьма вредно для open-source сообществ, где все должны:&lt;br /&gt;
* работать совместно;&lt;br /&gt;
* согласовывать общие цели;&lt;br /&gt;
* обсуждать архитектуру и непрерывно просматривать работу друг друга.&lt;br /&gt;
&lt;br /&gt;
В нашем Subversion-сообществе такое поведение мы именуем «сбрасывание бомбы», и считаем&lt;br /&gt;
антиобщественным и даже аморальным.&lt;br /&gt;
Ведь обычно, получаемая таким образом новая функциональность настолько велика и сложна, &lt;br /&gt;
что её почти невозможно рецензировать.&lt;br /&gt;
&lt;br /&gt;
А если её сложно рецензировать, то её сложно внедрить в основной ствол проекта,&lt;br /&gt;
сложно поддерживать как качество кода, &lt;br /&gt;
так и саму эту функциональность для всех, кроме, возможно, самого автора.&lt;br /&gt;
И в таких случаях мы, за редким исключением, ругаем автора за «затворничество».&lt;br /&gt;
&lt;br /&gt;
По-хорошему, надо сначала обратиться к сообществу, с предложением-проектом, &lt;br /&gt;
и после некоторого обсуждения мы &lt;br /&gt;
* либо просим разработчика творить последовательно, серией небольших доработок; &lt;br /&gt;
* либо выделяем отдельную «ветку» в репозитории.&lt;br /&gt;
&lt;br /&gt;
И действительно, на самом деле им не нужен доступ на применение к основному коду, &lt;br /&gt;
а все, что им нужно — отдельная ветвь.&lt;br /&gt;
При этом, сколь угодно много других участников могут просматривать самые мельчайшие изменения, &lt;br /&gt;
причем, в порядке их поступления, обсуждать, давать советы и другие отзывы &lt;br /&gt;
и тем самым поддерживать рабочий цикл разработчиков.&lt;br /&gt;
&lt;br /&gt;
Т.е. основная цель — не быть застигнутым врасплох большим изменением в коде.&lt;br /&gt;
Это помогает сообществу концентрироваться на общих целях, при этом держит его в курсе достижений каждого.&lt;br /&gt;
И хотя многие говорят: «Классно, что я могу разветвить целый проект без ведома остальных!»,&lt;br /&gt;
на это я постоянно твержу: «Ну ёлки-палки, ну почему вы не работаете вместе с остальными?&lt;br /&gt;
Почему вы не просите о доступе для фиксации изменений?».&lt;br /&gt;
Это типичная проблема, которую нужно решать не техническими, а социальными методами:&lt;br /&gt;
проектам следует активно поощрять стороннюю работу небольших команд и без промедления давать возможность заводить частные ветки.&lt;br /&gt;
&lt;br /&gt;
Я, вероятно, говорю как Мистер «Противник-распределенных-систем-контроля-версий», но на самом деле это не так.&lt;br /&gt;
Определенно, они удобны и вполне хороши.&lt;br /&gt;
Просто я думаю, что их нужно применять с большой осторожностью потому,&lt;br /&gt;
что предоставляемые ими удобства также способствуют проявлениям&lt;br /&gt;
социально-обособленного поведения, которое вредно для сообществ open-source разработчиков.&lt;br /&gt;
&lt;br /&gt;
[[Category:Статьи о Subversion]]&lt;br /&gt;
&lt;br /&gt;
== Ссылки ==&lt;br /&gt;
&lt;br /&gt;
Больше информации по этому вопросу вы найдете в [http://web.mit.edu/~ghudson/thoughts/bitkeeper.whynot эссе] Грега Хадсона (Greg Hudson) — оно и заставило меня первоначально обратить внимание на эту проблему.&lt;br /&gt;
&lt;br /&gt;
Также по этой теме есть отличная книга Карла Фогеля (Karl Fogel) [http://www.producingoss.com/ «Producing Open Source Software»].&lt;br /&gt;
&lt;br /&gt;
Всё это — вопросы правильного развития и управления сообществ разработчиков открытого ПО.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{{replicate-from-custiswiki-to-lib}}&lt;/div&gt;</summary>
		<author><name>StasFomin</name></author>	</entry>

	</feed>