Система керування версіямиСистема керування версіями (СКВ; source code management(SCM)[джерело?], revision control[джерело?], source control[джерело?], version control system[джерело?]) — програмний інструмент для керування версіями одиниці інформації: початкового коду програми, скрипту, вебсторінки, вебсайту, 3D-моделі, текстового документу тощо. Система керування версіями — інструмент, який дозволяє одночасно, не заважаючи один одному, проводити роботу над груповими проєктами. Системи керування версіями зазвичай використовуються при розробці програмного забезпечення для відстеження, документування та контролю над поступовими змінами в електронних документах: у сирцевому коді застосунків, кресленнях, електронних моделях та інших документах, над змінами яких одночасно працюють декілька людей. Кожна версія позначається унікальною цифрою чи літерою, зміни документу занотовуються. Зазвичай також зберігаються дані про автора зробленої зміни та її час. Інструменти для контролю версій входять до складу багатьох інтегрованих середовищ розробки. Існують два основні типи систем керування версіями: з централізованим сховищем та розподіленим. Система збереження історії редагувань статей, що застосовується у Вікіпедії є прикладом системи керування версіями. Загальні відомостіСистема контролю дозволяє зберігати попередні версії файлів та завантажувати їх за потребою. Вона зберігає повну інформацію про версію кожного з файлів, а також повну структуру проєкту на всіх стадіях розробки. Місце зберігання даних файлів називають репозиторієм. В середині кожного з репозиторіїв можуть бути створені паралельні лінії розробки — гілки. Гілки зазвичай використовують для зберігання експериментальних, незавершених(alpha, beta) та повністю робочих версій проєкту(final). Більшість систем контролю версії дозволяють кожному з об'єктів присвоювати теги, за допомогою яких можна формувати нові гілки та репозиторії. Використання системи контролю версії є необхідним для роботи над великими проєктами, над якими одночасно працює велика кількість розробників. Системи контролю версії надають ряд додаткових можливостей:
Невеликий словник основних термінів-сленгів
Світовий досвідНа сьогодні у світі існує багато організацій, які використовують системи контролю версій у своїй повсякденній роботі. Практично кожна фірма, що виробляє програмне забезпечення використовує їх. Але крім комерційних організацій системи контролю версій використовуються в університетах у всьому світі. Так, наприклад, можна виділити статтю двох професорів університету в Торонто: Грегорі В. Вілсона і Карен Рейд[1]. У своєму новому проєкті вони намагаються створити середовище для студентів, в якому вони хочуть використати системи контролю версій, issue trackers, web-логи. Деякі університети прагнуть використовувати і створювати такі середовища, в яких усі студенти технічних спеціальностей змогли б мати систему контролю версій, web-логи та інше. У США департамент освіти також займається цим питанням. Впровадження подібних систем відбувається на державному рівні. Види систем контролю версіїЦентралізовані системи контролю версійЦентралізована система контролю версії (клієнт-серверна) — система, дані в якій зберігаються в єдиному «серверному» сховищі. Весь обмін файлами відбувається з використанням центрального сервера. Є можливість створення та роботи з локальними репозиторіями (робочими копіями). Переваги:
Недоліки:
До таких систем відносять Subversion, Concurrent Versions System, Team Foundation Server. Розподілені системи контролю версіїРозподілена система контролю версії (англ. Distributed Version Control System, DVCS) — система, яка використовує замість моделі клієнт-сервер, розподілену модель зберігання файлів. Така система не потребує сервера, адже всі файли знаходяться на кожному з комп'ютерів. Переваги:
Недоліки:
До розподілених систем відносять: Git, Mercurial, Bazaar, Monotone, Codeville, BitKeeper. Виникнення конфліктів та їх вирішенняКонфлікти можуть виникнути при операції злиття, розгалужені від різних джерел. При зміненні одного і того ж рядка різними користувачами виникає конфлікт. Тобто якщо один користувач внесе зміни в документ та виконає злиття — то конфлікту не буде. Але якщо після цього інший користувач змінить документ в тих же рядках, що і перший — то виникне конфлікт. В такому випадку конфлікт повинен вирішувати другий користувач (власне, через якого і виник конфлікт), або система (як правило, вирішення конфліктів покладається на користувачів). Вирішення конфліктів Ручний режим:
Автоматичний режим:
Зауваження. Але далеко не в кожній системі існує пріоритет користувачів. Поширені системи керування версіями
Див. такожПримітки
Джерела
|