Image

Git на продвинутом уровне: rebase, cherry-pick, subtree

Git на продвинутом уровне: rebase, cherry-pick, subtree

Git на продвинутом уровне: rebase, cherry-pick, subtree

Освойте продвинутые возможности Git: от rebase и cherry-pick до subtree и интерактивных методов работы с историей. Управляйте ветками и коммитами как профессионал.

Rebase: перезапись истории коммитов

Команда git rebase — мощный инструмент для изменения истории коммитов и последовательности изменений. Она особенно полезна при необходимости поддерживать чистую и линейную историю разработки.

Например, вы работаете в ветке feature, а ветка main уже обновилась. Чтобы подтянуть изменения без создания лишних merge-коммитов, используйте:

git checkout feature git rebase main

Ветка feature теперь будет содержать ваши коммиты, «переписанные» поверх последнего состояния main.

Также вы можете воспользоваться интерактивным режимом:

git rebase -i HEAD~4

Это позволяет редактировать, объединять (squash), удалять или переупорядочивать коммиты. Такой подход удобен перед пушем в общий репозиторий — история станет аккуратной и понятной.

Cherry-pick: выборочный перенос коммитов

Если вам нужно перенести конкретный коммит из одной ветки в другую, но не всё содержимое, команда git cherry-pick пригодится.

Допустим, вы хотите перенести исправление из ветки bugfix в ветку develop:

git checkout develop git cherry-pick a1b2c3d

Ветка develop теперь включает коммит с указанным хэшем, даже если он из другой ветки.

Cherry-pick полезен для изолированных изменений или при выборе отдельных исправлений для разных версий продукта.

Subtree: подключение других репозиториев

git subtree позволяет встраивать один репозиторий в другой как подпроект. В отличие от submodule, subtree не требует отдельного управления зависимостями и работает как часть основного репозитория.

Например, подключим внешний проект:

git subtree add —prefix=vendor/lib https://github.com/username/library.git main —squash

Эта команда скачает внешний репозиторий и разместит его в папке vendor/lib вашего проекта.

Чтобы обновить внешний проект позже:

git subtree pull —prefix=vendor/lib https://github.com/username/library.git main —squash

Subtree особенно хорош для проектов, где внешний код должен быть частью общего коммита и истории.

Stash: временное сохранение изменений

git stash позволяет сохранить текущие изменения, не коммитя их, и вернуться к чистому рабочему каталогу. Это удобно, если вы не закончили работу, но нужно срочно переключиться на другую ветку.

git stash git checkout main

Вернуться к сохранённым изменениям можно с помощью:

git stash pop

Список всех сохранённых stash’ей:

git stash list

Bisect: поиск проблемного коммита

git bisect — отличная команда для поиска первого коммита, вызвавшего баг. Git использует бинарный поиск по истории коммитов.

Пример:

git bisect start git bisect bad # текущий коммит содержит баг git bisect good a1b2c3d # коммит, в котором всё работало

Git начнёт переходить между промежуточными коммитами, пока вы не укажете, в каком из них баг впервые появился.

Clean: удаление ненужных файлов

Если в каталоге проекта остались временные или сгенерированные файлы, которые не отслеживаются Git, их можно удалить командой:

git clean -fd

Флаг -f означает «force», а -d — удаление директорий. Будьте осторожны: эта команда необратима.

Shortlog и log: анализ истории коммитов

git shortlog позволяет быстро увидеть список авторов и количество их коммитов:

git shortlog -sn

А команда git log с параметрами — мощный способ визуального анализа истории:

git log —oneline —graph —decorate —all

Это покажет дерево коммитов в компактной форме.

Tag: метки и версии

git tag используется для маркировки важных коммитов, например — релизов:

git tag v1.0.0 git push origin v1.0.0

Можно создавать аннотированные теги с дополнительной информацией:

git tag -a v1.1.0 -m «Релиз версии 1.1.0»
Источник

✅ Найденные теги: Git, новости
Каталог бесплатных опенсорс-решений, которые можно развернуть локально и забыть о подписках

галерея

Фото сгенерированных лиц: исследование показывает, что люди не могут отличить настоящие лица от сгенерированных
Нейросети построили капитализм за трое суток: 100 агентов Claude заперли…
Скетч: цифровой осьминог и виртуальный мир внутри компьютера с человечком.
Сцена с жестами пальцами, где один жест символизирует "VPN", а другой "KHP".
‼️Paramount купила Warner Bros. Discovery — сумма сделки составила безумные…
Скриншот репозитория GitHub "Claude Scientific Skills" AI для научных исследований.
Структура эффективного запроса Claude с элементами задачи, контекста и референса.
Эскиз и готовая веб-страница платформы для AI-дизайна в современном темном режиме.
ideipro logotyp
Image Not Found
Код на экране компьютера, программирование, интерфейс разработчика.

Хайп или будущее: какие технологии реально проживут 10 лет

Хайп или будущее: какие технологии реально проживут 10 лет Какие технологии переживут хайп и останутся с нами на десятилетие? Разбираем AI, Web3, low-code, облака и другие тренды без эмоций — только холодный анализ рынка. Технологический рынок живёт…

Мар 2, 2026
Компьютер с изображением робота и иконками приложений на экране, символизирует технологии.

Как комбинировать несколько ИИ‑сервисов в один конвейер: от идеи до публикации за один вечер

ИИ сейчас умеет многое, но магии «одной кнопки, которая сделает идеальную статью и сама её опубликует» всё ещё нет. Зато можно собрать…

Фев 23, 2026
Женщина работает за ноутбуком, цифровая коммуникация, графики и письма, концепция удаленной работы.

AI‑агенты для рядового пользователя: 5 сценариев, которые реально экономят время

Слово «AI‑агент» в 2026 году звучит уже не как фантастика, а как нормальный рабочий инструмент, который тихо делает за нас рутину. Компании…

Фев 22, 2026
Компьютер с контрольным списком, замки, деньги, часы на светло-голубом фоне.

Как выбирать ИИ‑сервисы: чек‑лист критериев (цена, лимиты, качество, приватность)

В 2026 году выбрать ИИ‑сервис стало сложнее, чем когда‑либо: вокруг сотни «топ‑10 нейросетей», каждая обещает революцию, а в итоге можно…

Фев 20, 2026

Впишите свой почтовый адрес и мы будем присылать вам на почту самые свежие новости в числе самых первых