SVN с самого начала::Журнал СА 9.2015
www.samag.ru
Журнал «БИТ. Бизнес&Информационные технологии»      
Поиск   
              
 www.samag.ru    Web  0 товаров , сумма 0 руб.
E-mail
Пароль  
 Запомнить меня
Регистрация | Забыли пароль?
Журнал "Системный администратор"
Журнал «БИТ»
Подписка
Архив номеров
Где купить
Наука и технологии
Авторам
Рекламодателям
Контакты
   

  Опросы
1001 и 1 книга  
19.03.2018г.
Просмотров: 7047
Комментарии: 0
Машинное обучение с использованием библиотеки Н2О

 Читать далее...

12.03.2018г.
Просмотров: 7474
Комментарии: 0
Особенности киберпреступлений в России: инструменты нападения и защита информации

 Читать далее...

12.03.2018г.
Просмотров: 4869
Комментарии: 0
Глубокое обучение с точки зрения практика

 Читать далее...

12.03.2018г.
Просмотров: 3200
Комментарии: 0
Изучаем pandas

 Читать далее...

12.03.2018г.
Просмотров: 3998
Комментарии: 0
Программирование на языке Rust (Цветное издание)

 Читать далее...

19.12.2017г.
Просмотров: 3998
Комментарии: 0
Глубокое обучение

 Читать далее...

19.12.2017г.
Просмотров: 6496
Комментарии: 0
Анализ социальных медиа на Python

 Читать далее...

19.12.2017г.
Просмотров: 3349
Комментарии: 0
Основы блокчейна

 Читать далее...

19.12.2017г.
Просмотров: 3624
Комментарии: 0
Java 9. Полный обзор нововведений

 Читать далее...

16.02.2017г.
Просмотров: 7487
Комментарии: 0
Опоздавших не бывает, или книга о стеке

 Читать далее...

17.05.2016г.
Просмотров: 10855
Комментарии: 0
Теория вычислений для программистов

 Читать далее...

30.03.2015г.
Просмотров: 12560
Комментарии: 0
От математики к обобщенному программированию

 Читать далее...

18.02.2014г.
Просмотров: 14284
Комментарии: 0
Рецензия на книгу «Читаем Тьюринга»

 Читать далее...

13.02.2014г.
Просмотров: 9297
Комментарии: 0
Читайте, размышляйте, действуйте

 Читать далее...

12.02.2014г.
Просмотров: 7253
Комментарии: 0
Рисуем наши мысли

 Читать далее...

10.02.2014г.
Просмотров: 5547
Комментарии: 3
Страна в цифрах

 Читать далее...

18.12.2013г.
Просмотров: 4777
Комментарии: 0
Большие данные меняют нашу жизнь

 Читать далее...

18.12.2013г.
Просмотров: 3599
Комментарии: 0
Компьютерные технологии – корень зла для точки роста

 Читать далее...

04.12.2013г.
Просмотров: 3303
Комментарии: 0
Паутина в облаках

 Читать далее...

03.12.2013г.
Просмотров: 3532
Комментарии: 1
Рецензия на книгу «MongoDB в действии»

 Читать далее...

02.12.2013г.
Просмотров: 3192
Комментарии: 0
Не думай о минутах свысока

 Читать далее...

Друзья сайта  

 SVN с самого начала

Архив номеров / 2015 / Выпуск №9 (154) / SVN с самого начала

Рубрика: Разработка /  Инструменты

Рашид Ачилов РАШИД АЧИЛОВ, главный специалист по защите информации в компании, занимающейся автоматизацией горнодобывающей промышленности, shelton@sheltonsoft.ru

SVN с самого начала

О том, что такое SVN и как ее использовать, для тех, кто ее никогда не видел, с разъяснением терминологии и множеством примеров

Общее описание системы

Система контроля версий – это ПО, позволяющее создавать версии элементов и работать с этими версиями, как с самостоятельными элементами. В англоязычных источниках используется термин version control systems, сокращенно VCS. Как правило, в качестве элементов выступают либо файлы, либо каталоги.

Прежде чем работать с элементами и их версиями, надо эти элементы создать, т.е. дать указание системе контроля версий взять объекты и поместить их под свой контроль. Вместе с самим элементом всегда создается и его первая версия. Для чего это нужно?

Представим, что программист разрабатывает проект, состоящий из одного небольшого файла. После выпуска первой версии проекта перед ним встает выбор: необходимо решать проблемы, о которых сообщают пользователи первой версии, и в то же время разрабатывать что-то новое для второй. Даже если надо просто устранять возникающие проблемы, то велика вероятность, что после какого-либо изменения проект перестает работать, и надо определить, что было изменено, чтобы было проще локализовать проблему. Также желательно вести какой-то журнал внесенных изменений и исправлений, чтобы не делать несколько раз одну и ту же работу.

В простейшем случае вышеприведенную проблему можно решить хранением нескольких копий файлов – например, один для исправления ошибок в первой версии проекта и второй для новых изменений. Так как изменения обычно не очень большие по сравнению с размером файла, можно хранить только измененные строки, используя утилиту diff, и позже объединять их с помощью утилиты patch. Но что если проект состоит из нескольких тысяч файлов и над ним работает сотня человек? Если в этом случае использовать метод с хранением отдельных копий файлов (или даже только изменений), то проект застопорится очень быстро.

Системы контроля версий как раз и служат для решения следующих проблем:

  • хранение версий файлов, причем обычно хранятся только изменения между предыдущей и текущей версиями, и таким образом хранилище не растет слишком быстро;
  • возможность получить любые предыдущие версии хранимых файлов;
  • просмотр изменений, внесенных между заданными в запросе версиями;
  • сохранение и просмотр комментариев и авторов к внесенным изменениям.

Кроме того, если проект достаточно крупный, то перед администратором проекта, как правило, стоят следующие задачи:

  • предоставление доступа только к отдельным частям проекта;
  • выпуск релизов продукта, управление версиями.

Системы контроля должны предоставлять структуры для хранения версий. Самым распространенным представлением подобной структуры является дерево версий. Это такая организация версий элемента, при которой на основе любой версии элемента может быть создано несколько наборов последовательностей его версий. При этом отдельный набор версий, происходящий из произвольной версии, называется веткой. И поскольку ветка содержит версии, то каждая из версий может быть источником для создания других веток. Короче, дерево.

Часто бывает, что над одним проектом одновременно работают несколько человек. Если два человека изменяют один и тот же файл, то один из них может случайно отменить изменения, сделанные другим. Системы управления версиями отслеживают такие конфликты и предлагают средства их решения. Большинство систем может автоматически объединить (слить) изменения, сделанные разными разработчиками. Однако такое автоматическое объединение изменений обычно возможно только для текстовых файлов и при условии, что изменялись разные (непересекающиеся) части этого файла. Такое ограничение связано с тем, что большинство систем управления версиями ориентировано на поддержку процесса разработки ПО, а исходные коды программ хранятся в текстовых файлах. Если автоматическое объединение выполнить не удалось, система может предложить решить проблему вручную.
Часто выполнить слияние невозможно ни в автоматическом, ни в ручном режиме, например, если формат файла неизвестен или слишком сложен. Некоторые системы управления версиями дают возможность заблокировать файл в хранилище. Блокировка не позволяет другим пользователям получить рабочую копию или препятствует изменению рабочей копии файла (например, средствами файловой системы) и обеспечивает, таким образом, исключительный доступ только тому пользователю, который работает с документом.

Статью целиком читайте в журнале «Системный администратор», №9 за 2015 г. на страницах 61-71.

PDF-версию данного номера можно приобрести в нашем магазине.


  1. Документация по SVN версии 1.8 – http://svnbook.red-bean.com/en/1.8/index.html.

Комментарии отсутствуют

Добавить комментарий

Комментарии могут оставлять только зарегистрированные пользователи

               Copyright © Системный администратор

Яндекс.Метрика
Tel.: (499) 277-12-45
E-mail: sa@samag.ru