Работа с git для начинающих

Наверное не все знают, что такое git и с чем его едят.
git — это распределенная система контроля версий. Основные ее преимущества, лично для меня, распределенность и использование бинарных дифов, что упрощает работу с системой нескольких пользователей одновременно, и упрощает хранение бинарных файлов, ресурсов.

git используется во многих крупных проектах: Linux kernel, KDE и многих  других.

Изначально git написал Linus Torvalds.

Создание нового репозитория

Создание нового репозитория — это наверное первая из задач, с которой сталкивается любой разработчик. К данной проблеме есть несколько подходов.

Во-первых, можно использовать только локальный репозиторий, но смысла особого я в этом не вижу.

Во-вторых, можно создать открытый репозиторий, с которым смогут работать другие люди. Рассмотрим этот вариант. Предположим, что у вас есть некий сервер example.com и ваша рабочая машинка.

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

Далее вам надо создать репозиторий. Предположим что вы будете хранить все git-репозитории в /var/git:

Теперь у вас есть пустой git-репозиторий. Это, собственно говоря, все команды, которые требуется выполнить на сервере.

Теперь идем на вашу рабочую машину и пишем:

Этими командами мы создали новый репозиторий, связали его с основной веткой example.git, закомитили туда файл changelog и отослали это на сервер. В результате выполнения этих команд, вы должны увидеть чтото примерно такое:

Получение и оправка репозитория

Разумеется, после создания репозитория разумно узнать «а как же получить эти данные на свой компьютер?».

Для данной операции используется команда clone. Она создает полную копию удаленного репозитория у вас. Под полной копией понимается именно полная копия, со всеми ветками, удаленными файлами и т.д.

Разумеется, /var/git может меняться, в зависимости от того, где располагаются файлы данного репозитория на удаленной машине.

Обновление данных

С таким локальным репозиторием можно работать долгое время, однако, когда-то у вас все же возникнет необходимость передать сделанные вами изменения в удаленный репозиторий, чтобы результатами вашего труда могли воспользоваться другие участники разработки, и получить из удаленного репозитория новую версию. Для этого служат команды pull и  push.

Данная команда получает обновленную версию из удаленного репозитория, при этом она проверяет на наличие различных проблем при объединении репозиториев и сообщает об этом.

Данная команда целиком передает все сделанные вами изменения, уже закомиченные в локальный репозиторий, в удаленный репозиторий. Для передачи тегов необходимо использовать аргумент —tags

Базовые операции

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

Добавление списка файлов в комит:

Добавление всех недобавленных файлов в комит:

Удаление файла из комита:

Удаление файла из комита и с жесткого диска:

Комит в локальный репозиторий (надо отметить, что в таком случае закомитятся только файлы, которые были обработаны с помощью git add/rm):

Комит всех изменений в локальный репозиторий:

Отмена всех изменений, сделанных в дереве, до состояния, которое было при последнем комите в локальный репозиторий( очень опасная команда, подумайте прежде чем пользоваться ею):

Создание дифа относительно последнего комита:

Использование веток

Рано или поздно в любом проекте возникает ситуация, когда требуется заморозить изменения, но продолжать работать, а на замороженные изменения накладывать только баг-фиксы. Для этой цели служат ветви (branch)

В гите можно создать ветку от любого места. Для создания ветки от основного дерева надо выполнить следующую команду:

В результате этой команды вы увидите примерно такое сообщение:

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

Если в этой команде заменить origin/master на origin/remote_branch_name то вы создадите ветку от другой ветки.

Чтобы ваша ветка была видна всем, ее требуется пропихнуть в удаленный репозиторий. Делается это так:

Разумеется, надо также уметь и получать ветки в свое распоряжение:

В результате вы получите искомую ветку после следующего сообщения:

Работа с тегами

Как правило, кроме веток разработчики используют теги — чтобы запомнить состояние кода в какой-то момент. Тег — это своеобразный слепок, точно идентифицирующий состояние кода. Гит умеет работать с подписанными GPG тегами и с неподписанными. Здесь я рассмотрю только неподписанные теги.

Для создания такого тега необходимо выполнить команду:

Чтобы убрать тег необходимо  выполнить:

Для того, чтобы тег стал виден всем, необходимо отправить его в удаленный репозиторий:

Чтобы получить версию с конкретного тега необходимо создать от него локальную ветку и расчекаутить эту ветку:

Разумеется, в будущем эту ветку можно будет сделать глобальной и выслать в удаленной репозиторий.

Настройка git

Для ускорения некоторых операций и увеличения удобства работы можно провести пару настроек:

Настройка цветного вывода:

Настройка имени пользователя и почтового адреса (между прочим, это хороший тон):

Ускоряем дифы и отменяем ограничение на количество потоков упаковки при push:

Вместо заключения

Git —  очень мощная и удобная система контроля версий. Для нее существует несколько GUI утилит, которые могут облегчить работу, несколько веб интерфейсов для мониторинга текущего состояния. В последнее время все большее кол-во проектов переходят на использование git, и это показатель того, что git успешно развивается и соответствует последним требованиям в области систем контроля версий.

Большое кол-во  документации по использованию git можно найти в сети, в том числе и на официальном сайте


18 Responses to Работа с git для начинающих

  1. Avatar tair
    tair says:

    спасибо! все доступно

  2. Avatar Hawk
    Hawk says:

    >cd /var/git
    >mkdir example.git
    >git init —bare

    После второй строки нужно еще сделать
    cd example.git

    admin Reply:

    Спасибо, исправил.

  3. Avatar Димас
    Димас says:

    Спасибо Вам)

  4. Avatar Павел
    Павел says:

    +1) Добавил в закладки.

  5. Для первого знакомства то, что нужно. Спасибо!

  6. Спасибо за объяснение, а продолжение будет?

    admin Reply:

    Есть вот такое продолжение: http://blog.nsws.ru/bolee-pravilnaya-rabota-s-git-git-stash-i-git-rebase.html
    А какие вопросы еще нужно осветить, если есть какие-то пожелания для новой статьи по git — с радостью выслушаю, и если обладаю необходимой информацией — напишу 🙂

    Alex Reply:

    СПАСИБО, Admin, как раз вовремя!!
    — Я только начинаю осваивать Git, теперь многое стало понятно.

    Артур Reply:

    Спасибо. Это первая из десятков инструкция, по которой все срослось.
    Создал 2 репозитария — локальный и на сервере. Сделал и пуш и пул…
    Но все история затевалась для совместной работы над сайтом. Сайт лежит на том же сервере что и созданый пустой удаленный репозитарий. Как правильно наладить работу, что б все результаты работы команды программистов попадали ни просто в репозитарий, но и заменяли собой файлы скриптов на сайте?
    Каков правильный и безопасный путь — по шагам?

    admin Reply:

    Вам нужно посмотреть в сторону post-receive hook. (http://git-scm.com/book/en/Customizing-Git-Git-Hooks)

    Как вариант можно сделать на сервере post-receive hook который сделает pull в папку с вашим сайтом.
    Тогда по сути будет так:
    Ктото делает push в git репу на сайте. Там запускается скрипт который переходит в каталог где лежит ваш сайт и делает git pull.

    Артур Reply:

    ТЕОРИЯ ЯСНА
    Уже создавал и удавлял кучу репозитариев. все как то не складываетсяв одну цепочку.
    Вот тут что то похожее http://habrahabr.ru/blogs/Git/127213
    Жаль нет единого пошагового мануала.

    admin Reply:

    Посмотрел статью, указанную вами, там какраз пошаговая инструкция.
    Возможно если у меня будет время я наваяю нечто похожее, какраз подворачивается похожая задачка…

    Артур Reply:

    Сделал все по 2 инструкциям, работать невозможно. При малейшем изменении на сервере одним из программистов, мне приходится делать пул на локальную машину — все 14 гб. с сервера (весь последний слепок видимо).
    Наверное все же что то ни так настроено и где тоэти 2 инструкции не согласуются. Не могли бы Вы помочь разобраться? Если нет возможности сделать мануал — просто поконсультировать в скайпе (kadomsky), а я б потом сделал черновик мануала полного процесса.

    admin Reply:

    Можете попробовать связаться со мной через gtalk ( http://blog.nsws.ru/about ), пока с временем беда. На выходных попробую сделать мануальчик, вроде время должно появиться.

  7. Avatar Виталий
    Виталий says:

    Добавьте описание .gitignore для более полной картины

  8. Avatar Николай
    Николай says:

    Спасибо дружище!!!

    Перерыл кучу доки и сайтов, но нужна была всего лишь одна команда на сервере:
    git init —bare —share

  9. Спасибо за статью, очень доступна и полезна