Git —розподілена система керування версіямифайлів та спільної роботи. Проєкт створивЛінус Торвальдс для керування розробкоюядра Linux, а сьогодні підтримуєтьсяДжуніо Хамано (англ.Junio C. Hamano). Git є однією з найефективніших, надійних і високопродуктивнихсистем керування версіями, що надає гнучкі засоби нелінійної розробки, що базуються на відгалуженні та злиттігілок. Для забезпечення цілісності історії та стійкості до змін заднім числом використовуються криптографічні методи, також можлива прив'язкацифрових підписів розробників до тегів і комітів.
Програма є вільною і випущена під ліцензієюGNU GPL версії 2.
Система спроєктована як набір програм, спеціально розроблених з врахуванням їхнього використання ускриптах. Це дозволяє зручно створювати спеціалізовані системи керування версіями на базі Git або користувацькі інтерфейси. Наприклад,Cogito[en] є саме таким прикладом фронтенду до репозиторіїв Git. А StGit використовує Git для управління колекцієюлаток.
Система має ряд користувацьких інтерфейсів: наприклад, gitk та git-gui розповсюджуються з самим Git.
Віддалений доступ дорепозиторіїв Git забезпечується git-демоном,SSH абоHTTPсервером.TCP-сервіс git-daemon входить у дистрибутив Git і є разом з SSH найпоширенішим і надійним методом доступу. Метод доступу HTTP, хоч має низку обмежень, дуже популярний в контрольованих мережах, тому що дозволяє використання наявних конфігурацій мережевих фільтрів.
Git, на відміну відSubversion і подібних до неї систем, не зберігає інформацію як список змін (патчів) для файлів. Замість цього Git зберігає дані набором зліпків. Кожного разу при фіксації поточної версії проєкту Git зберігає зліпок того, як виглядають всі файли проєкту. Але якщо файл не змінювався, то дається посилання на раніше збережений файл (див. рис. 1). Git схожий на своєріднуфайлову систему з інструментами, які працюють поверх неї. Для кожного відстежуваного файлу Git зберігає розмір, час створення та останньої зміни. Ці дані зберігаються у файлі index, який знаходиться у теці .git. Вся база даних Git зберігається в теці з назвою .git В Git файли можуть знаходитися в одному із 3-х станів: зафіксованому (файл вже збережено в локальній базі даних), зміненому (файл було змінено, але зміни не зафіксовано) і підготовленому (файли було змінено і відмічено для фіксації).
Більшість дій можна виконувати на локальній файловій системі без використання інтернет підключення. Вся історія змін зберігається локально і при необхідності вивантажується у віддалений репозиторій. На відміну відSubversion, де без підключення до інтернету можна лише редагувати файли, але зберегти зміни в вашу базу даних неможливо (оскільки вона відключена від репозиторію). Будь-який коміт спочатку робиться локально, а потім вивантажується у віддалений репозиторій.
У своїй базі Git зберігає все по хешам файлів, які хешуються функцієюSHA-1. Перед кожним збереженням файлів Git обчислюєSHA-1хеш файлу й отриманий хеш стає індексом файлу в Git. Використовуючихеш Git легко відстежує зміни в файлах.
Галуження — це розмежування від основної лінії розробки. Git дозволяє створити декілька гілок і перемикатися між ними. Це корисно, оскільки дозволяє працювати декільком розробникам над своїм функціоналом не заважаючи іншим і не псуючи основну гілку. За замовчуванням, Git створює гілку з назвою master.Гілка в Git просто являє собою вказівник на одну із фіксацій. При кожній новій фіксації гілка в Git рухається автоматично (тобто перемикається на фіксацію). Гілка є простим файлом, який містить 40 символів контрольної сумиSHA-1 фіксації. Створення нової гілки дуже швидке, оскільки це однаково запису в файл 41 байта (40 символів + символ нового рядка).
Git підтримує два способи для інтеграції змін згілки в гілку: merge (зливання) та rebase (перебазування). Основна різниця полягає в тому, що rebase запам'ятовує фіксації у вигляді патчів, перемотує гілку і застосовує патчі у вигляді фіксацій на відміну від merge, який зливає дві гілки в одну.
Gitk(gitk) проста, але перевірена і швидка програма. Написана наTcl/Tk, розповсюджується з самим Git.
QGit[Архівовано 18 листопада 2007 уWayback Machine.] (Sourceforge[Архівовано 26 лютого 2008 уWayback Machine.]) інтерфейс написаний з використаннямQt, багато в чому схожий з gitk, але дещо відрізняється набором можливостей (Marco Costalba). В наш час[коли?] переписується на Qt4, що спростить його портування на Microsoft Windows.
$cd<path_project>#Шлях до проєкту (наприклад: $ cd с:/www/git). Переходимо в наявну теку, в якій буде розміщено проєкт$gitinit#Ініціалізація репозиторію. Створює в каталозі Project каталог .git і в ньому всі необхідні файли репозиторію$gitadd.#Додаємо всі файли, які наявні в каталозі Project, під версійний контроль$gitcommit-m"Коментар"#Фіксуємо зміни
Клонувати проєкт з віддаленого сервера в локальний каталог
gitweb[недоступне посилання з лютого 2019] — написаний наPerl (англ.Kay Sievers). Більшість наведених нижче великих публічних git-репозиторіїв його й застосовує.
wit — написаний на Ruby/eRuby (англ.Christian Meder)
Subversion — імпорт і експорт (частково), в стандартному постачанні
.tar.gz, .tar.bz2 (серії версійних файлів) — імпорт і експорт, в стандартному постачанні
Perforce — імпорт і експорт (частково), в стандартному постачанні та в архівах Git Mailing List
Mercurial — імпорт і експорт, в стандартному постачанні та за допомогою зовнішньої програми (Tailor)
Крім того, завдяки своїй структурі даних та форматам даних обміну Git дозволяє порівняно просто й ефективно реалізувати обмін даними практично зі всіма наявними системами керування версіями.
↑Архівована копія. Архіворигіналу за 4 вересня 2019. Процитовано 6 січня 2008.{{cite web}}: Обслуговування CS1: Сторінки з текстом «archived copy» як значення параметру title (посилання)
Everyday Git[Архівовано 4 березня 2016 уWayback Machine.] («Git на кожен день») — набір з приблизно 20 команд (насправді їх буде близько 5—6), які стануть у пригоді в повсякденному використанні системи.
Роки, якщо є, показують дату першого стабільного релізу. Системи з іменами виділенимикурсивом більше не підтримуються, або заплановано завершення підтримки.