Сравнение слияния и перебазирования | Atlassian Git Tutorial
Командой git rebase
, словно опасным заклинанием, часто пугают новичков. В действительности она может значительно облегчить жизнь команде разработчиков, если использовать ее правильно. В этой статье проводится сравнение команды git rebase
со схожей командой git merge
и описываются все возможные ситуации, в которых уместно включить перебазирование в стандартный рабочий процесс Git.
Обзор основных моментов
В первую очередь нужно понимать, что команда git rebase
помогает решить ту же проблему, что и команда git merge
. Обе команды предназначены для включения изменений из одной ветки в другую, но делают это по-разному.
Представьте, что вы начали работать над новой функциональной возможностью в отдельной ветке, после чего другой участник команды добавляет новые коммиты в главную ветку main
. Возникает история форков, знакомая каждому, кто использовал Git для совместной работы.
А теперь предположим, что новые коммиты в главной ветке main
затрагивают функцию, над которой вы работаете. Для включения новых коммитов в свою функциональную ветку feature
можно использовать два варианта: слияние или перебазирование.
Способ слияния (merge)
Проще всего слияние ветки main
в функциональную ветку выполняется с помощью следующей команды:
git checkout feature
git merge main
При желании этот код можно записать в одну строку:
git merge feature main
Эта операция создает в ветке feature
новый «коммит слияния», связывающий истории обеих веток. Структура веток будет выглядеть так:
Слияние (merge) — это отличная неразрушающая операция. Существующие ветки никак не изменяются. Эта операция позволяет избегать потенциальных проблем, связанных с выполнением команды rebase (и описанных ниже).
С другой стороны, это означает, что каждый раз, когда вам будет необходимо включить вышестоящие изменения, в функциональную ветку feature
будет попадать внешний коммит слияния. Если работа в главной ветке main
ведется активно, история вашей функциональной ветки быстро засорится. Хотя эту проблему можно устранить, используя продвинутые варианты команды git log
, другим разработчикам будет тяжело разобраться в истории проекта.
Способ перебазирования (rebase)
Вместо слияния можно выполнить перебазирование функциональной ветки feature
на главную ветку main
с помощью следующих команд:
git checkout feature
git rebase main
В результате вся функциональная ветка feature
окажется поверх главной ветки main
, включая в себя все новые коммиты в ветке main
. Если вместо команды merge при коммитах используется rebase, эта команда
Главное преимущество rebase — более чистая история проекта. Во-первых, эта команда устраняет ненужные коммиты слияния, необходимые для git merge
. Во-вторых, как показано на рисунке выше, команда rebase создает идеальную линейную историю проекта — вы сможете отследить функционал
до самого начала проекта без каких-либо форков. Это упрощает навигацию в проекте с помощью таких команд, как git log
, git bisect
и gitk
.
Однако такая безупречная история коммитов требует определенных жертв: жертвовать приходится безопасностью и отслеживаемостью. Если не следовать Золотому правилу Rebase, перезапись истории проекта может обернуться катастрофическими последствиями для совместных рабочих процессов. Кроме того, при выполнении rebase теряется контекст, доступный в коммите со слиянием: вы не сможете увидеть, когда вышестоящие изменения были включены в функционал.
Интерактивное перебазирование
Интерактивная операция rebase позволяет изменять коммиты при их перемещении в новую ветку. Этот вариант предоставляет еще больше возможностей, чем автоматическое выполнение rebase, поскольку дает полный контроль над историей коммитов ветки. Обычно его используют для очистки запутанной истории, перед тем как сливать функциональную ветку в главную ветку main
.
Чтобы запустить интерактивное перебазирование, передайте параметр i
команде git rebase
:
git checkout feature
git rebase -i main
Откроется текстовый редактор. В нем будут перечислены все коммиты, подготовленные к перемещению:
pick 33d5b7a Message for commit #1
pick 9480b3d Message for commit #2
pick 5c67e61 Message for commit #3
Этот список точно отражает, как будет выглядеть ветка после перебазирования. Изменяя команду pick
и (или) порядок коммитов, вы можете придать истории ветки нужный вид. Так, если второй коммит содержит исправление небольшой проблемы в первом, их можно объединить с помощью команды fixup
:
pick 33d5b7a Message for commit #1
fixup 9480b3d Message for commit #2
pick 5c67e61 Message for commit #3
Когда вы сохраните и закроете файл, Git выполнит перебазирование в соответствии с вашими указаниями. История проекта затем примет следующий вид:
Удаление незначительных коммитов помогает быстрее разобраться в истории функциональной ветки. Команда git merge
просто не в состоянии этого сделать.
Золотое правило перебазирования
Разобравшись с возможностями rebase, необходимо в первую очередь понять, когда эту команду не нужно использовать. Золотое правило для команды git rebase
— никогда не использовать ее в публичных ветках.
К примеру, представьте, что произойдет, если вы выполните rebase главной ветки main
на свою функциональную ветку feature
.
Перебазирование перемещает все коммиты ветки main
в конец ветки feature
. Проблема в том, что это происходит только в вашем репозитории, в то время как другие разработчики продолжают работать с исходной веткой main
. Поскольку в результате перебазирования создаются абсолютно новые коммиты, Git будет считать, что история вашей главной ветки main
разошлась с остальными.
Единственный способ синхронизировать две главные ветки
— выполнить их обратное слияние. Это приведет к дополнительному коммиту слияния и двум наборам коммитов, которые содержат одни и те же изменения (исходные изменения и изменения из вашей ветки после rebase). Нужно ли говорить, что ситуация получится крайне запутанная?
Поэтому перед выполнением команды git rebase
следует убедиться, что текущую ветку не просматривает кто-то другой. Если в ней действительно ведется работа, прекратите любые действия и подумайте, как можно внести изменения неразрушающим способом (например, с помощью команды git revert
). В остальных случаях вы можете свободно перезаписывать историю при необходимости.
Принудительная отправка изменений
Git заблокирует попытку поместить перебазированную ветку main
обратно в удаленный репозиторий, поскольку она вступит в конфликт с удаленной веткой main
. Но эту операцию можно выполнить принудительно, добавив флаг --force
:
# Будьте крайне осторожны с этой командой! git push --force
При этом удаленная ветка main
станет соответствовать ветке в вашем репозитории после rebase. В итоге путаться начнут и ваши коллеги. Поэтому будьте внимательны и используйте эту команду только в том случае, если полностью понимаете, чего хотите добиться.
Одна из немногих ситуаций, требующих форсированного помещения кода, — это локальная очистка после помещения частной функциональной ветки в удаленный репозиторий (например, для создания резервной копии). Это равноценно заявлению: «Ой, я ведь не хотел отправлять исходную версию этой функциональной ветки. Лучше возьмите текущую версию». Здесь также важно, чтобы никто после коммитов не начал работу из исходной версии функциональной ветки.
Пошаговый разбор процесса
Перебазирование можно использовать при работе с Git ровно в том объеме, который подходит команде. В этом разделе вы узнаете о преимуществах перебазирования на разных этапах разработки функций продукта.
В любом рабочем процессе с применением команды git rebase
сначала нужно создать отдельную ветку для каждой функции. Полученная структура веток необходима для безопасного перебазирования:
Локальная очистка
Один из самых эффективных сценариев перебазирования в рабочем процессе — это очистка локальных функциональных веток, в которых еще ведется работа. Если периодически проводить интерактивное перебазирование, ни один коммит в вашей ветке не потеряет смысла. Вы сможете быть уверены, что ваш код не распадется на изолированные коммиты. Если это случится, ситуацию всегда можно будет исправить.
При использовании команды git rebase
есть два варианта для нового положения ветки: вышестоящая ветка для функциональной ветки (например, ветка main
) или более ранний коммит в функциональной ветке. Первый вариант описывался в примере в разделе Интерактивное перебазирование. Второй вариант удобен, когда нужно исправить лишь несколько недавних коммитов. Например, следующая команда запускает интерактивную операцию rebase только для трех последних коммитов.
git checkout feature git rebase -i HEAD~3
Указав HEAD~3
в качестве нового положения, вы не перемещаете ветку как таковую, а лишь интерактивно переписываете 3 последующих коммита. Следует отметить, что при этой операции вышестоящие изменения не включаются в функциональную
ветку.
Если с помощью этого способа вы хотите переписать всю функциональную ветку, найти начальное положение функциональной
ветки поможет команда
. Следующая команда возвращает ID коммита начального положения, который затем можно передать в команду git rebase
:
git merge-base feature main
Такое использование интерактивной операции rebase отлично поможет включить git rebase
в рабочий процесс, поскольку затронет только локальные ветки. Другие разработчики увидят только законченную версию с простой и отслеживаемой историей функциональной ветки.
Повторим, что это работает только для частных функциональных веток. Если вы работаете в одной функциональной ветке с другими разработчиками, она является публичной и переписывать ее историю запрещено.
Варианта очистки локальных коммитов с интерактивным использованием rebase с помощью команды git merge
не существует.
Включение восходящих изменений в функциональную ветку
В разделе Обзор основных моментов рассматривалось включение вышестоящих изменений из главной ветки main
в функциональную ветку с помощью команды git merge
или git rebase
. Операцию слияния можно выполнять безопасно, поскольку при этом сохраняется вся история репозитория. При выполнении перебазирования создается линейная структура: функциональная ветка перемещается в конец ветки main
.
В этом случае команда git rebase
используется так же, как и локальная очистка (которую можно осуществить одновременно), но при ее выполнении включаются вышестоящие изменения из главной ветки main
.
Помните, что можно еще выполнять rebase в удаленную ветку, отличную от ветки main
. Например, при совместной работе над функциональной возможностью с другим разработчиком, когда требуется включить его изменения в ваш репозиторий.
Например, если вы вместе с разработчиком Джоном добавляли коммиты в ветку feature
, то после получения удаленной ветки feature
из репозитория Джона ваш репозиторий может выглядеть следующим образом:
С таким ветвлением можно работать так же, как и при включении вышестоящих изменений из ветки main
: либо выполнить слияние в локальную ветку feature
для ветки john/feature
, либо выполнить перебазирование локальной ветки feature
на конец ветки john/feature
.
Обратите внимание: такое перебазирование не нарушает «золотое правило», поскольку перемещаются только коммиты вашей ветки feature
, тогда как предшествующие элементы остаются нетронутыми. В сущности, эта операция позволяет лишь добавить ваши изменения к наработкам Джона. Чаще всего это проще, чем выполнять синхронизацию с удаленной веткой посредством коммита слияния.
По умолчанию команда git pull
выполняет слияние. Однако если передать ей параметр --rebase
, будет выполнено перебазирование для удаленной ветки.
Проверка функции с помощью запроса pull
Если в процессе проверки кода используются пул-реквесты, не используйте команду git rebase
после создания пул-реквеста. Сразу после создания пул-реквеста другие разработчики смогут видеть ваши коммиты, то есть ваша ветка станет публичной. В случае перезаписи ее истории Git и ваши коллеги не смогут отслеживать последующие коммиты в функциональную ветку.
Все изменения, сделанные другими разработчиками, нужно добавлять командой git merge
, а не git rebase
.
Поэтому хорошей идеей является очистка кода с помощью интерактивной операции rebase перед созданием пул-реквеста.
Внедрение утвержденной функции
После одобрения функциональной ветки коллегой вы можете перебазировать ее на конец ветки main
, а затем использовать команду git merge
для включения функциональной ветки в основную базу кода.
Это похоже на включение вышестоящих изменений в функциональную ветку, но поскольку переписывать коммиты в главной ветке main
запрещено, вам придется использовать для включения функциональной ветки команду git merge
. Выполняя перебазирование перед слиянием, вы обеспечиваете ускоренное слияние и идеальную линейную историю. Такой подход также позволяет склеивать любые последующие коммиты, добавленные до закрытия запроса pull.
Если вы еще не привыкли работать с командой git rebase
, всегда можно выполнить rebase во временную ветку. В таком случае, если вы случайно запутаете историю функциональной ветки, всегда можно будет переключиться в исходную ветку и попробовать снова. Например:
git checkout feature
git checkout -b temporary-branch
git rebase -i main
# [Clean up the history]
git checkout main
git merge temporary-branch
Резюме
Теперь у вас достаточно информации, чтобы начать использовать rebase для своих веток. Если вы предпочитаете иметь чистую линейную историю без ненужных коммитов слияния, используйте команду git rebase
вместо git merge
при включении изменений из другой ветки.
Но если вам нужно сохранить полную историю проекта и избежать перезаписи публичных коммитов, воспользуйтесь командой git merge
. Теперь вы можете не только применить слияние, но и оценить преимущества команды git rebase
— оба варианта эффективны в работе.
Видео: слияние почты — Служба поддержки Майкрософт
Слияние почты
Обучение работе с Word 2013
Слияние почты
Слияние почты
Слияние почты
-
Слияние почты
Видео -
Печать писем
Видео -
Печать конвертов
Видео
Далее: Расширенные возможности слияния
Чтобы показать, как работает слияние, начнем с сообщения электронной почты. Вы создаете основной документ, прикладываете список сведений о получателях и добавляете поля слияния. Затем Word автоматически заполняет поля сведениями о получателях и генерирует отдельные документы.
Вставка полей слияния
Например, чтобы добавить стандартное приветствие в сообщение электронной почты или письмо, используйте поле слияния Строка приветствия.
-
Щелкните в том месте, куда требуется поместить приветствие.
-
Нажмите кнопку Строка приветствия.
-
Выберите желаемый стиль названия и задайте другие параметры.
-
Чтобы убедиться, что поле отформатировано правильно, выделите все поле, включая знаки в конце.
-
На вкладке ГЛАВНАЯ проверьте шрифт и его размер.
-
Нажмите кнопку Интервал, чтобы убедиться, что ко всему документу применен единообразный междустрочный интервал.
После добавления полей слияния введите информацию, которая должна повторяться в каждом сообщении, отправляемом во время слияния.
Добавление отдельных полей
Если необходимо добавить настраиваемое приветствие или другую информацию из списка рассылки, можно добавлять поля по одному.
-
Щелкните в том месте документа, где нужно добавить поле слияния.
-
Щелкните стрелку рядом с кнопкой Вставить поле слияния, а затем выберите название поля.
-
Если название поля не отображается в списке, нажмите кнопку Вставить поле слияния.
-
Чтобы просмотреть список полей в источнике данных, выберите пункт Поля базы данных.
-
Щелкните поле, которое необходимо добавить.
-
Выберите вкладку Вставка.
Хотите узнать больше?
Слияние с использованием таблицы Excel
Вставка полей слияния
Создание и печать почтовых наклеек для списка адресов в Excel
Слияние почты с помощью Word
Домашняя страница — ОБЪЕДИНИТЬ
ПРОГРАММНОЕ ОБЕСПЕЧЕНИЕ
ПРИНЯТИЕ
ОБЛАЧНЫЕ И УПРАВЛЯЕМЫЕ РЕШЕНИЯ
УЧИТЬ БОЛЬШЕ
АУТСОРС
УПРАВЛЕНИЕ
УЧИТЬ БОЛЬШЕ
ПЕРЕНОС ДАННЫХ
УЧИТЬ БОЛЬШЕ
ГОСУДАРСТВЕННЫЕ УСЛУГИ
УЧИТЬ БОЛЬШЕ
ПРОГРАММНОЕ ОБЕСПЕЧЕНИЕ
ПРИНЯТИЕ
ОБЛАЧНЫЕ И УПРАВЛЯЕМЫЕ РЕШЕНИЯ
УЧИТЬ БОЛЬШЕ
АУТСОРС
УПРАВЛЕНИЕ
УЧИТЬ БОЛЬШЕ
ПЕРЕНОС ДАННЫХ
УЧИТЬ БОЛЬШЕ
ГОСУДАРСТВЕННЫЕ УСЛУГИ
УЧИТЬ БОЛЬШЕ
Даже если вы не знаете, чем мы можем помочь, свяжитесь с нами.
Существует более короткий список того, что мы НЕ предлагаем, поэтому свяжитесь с нами сегодня!
Отправьте нам электронное письмо
[email protected]
Позвоните нам
(954) 332-2497
ПОДПИСЫВАЙТЕСЬ НА НАС НА LINKEDIN
ПОДПИСЫВАЙТЕСЬ НА НАС В INSTAGRAM
ПОСТАВЬТЕ НАМ ЛАЙК НА ФЕЙСБУКЕ
бизнес-решений — ОБЪЕДИНЕНИЕ ИТ
КОНСУЛЬТАЦИОННЫЕ УСЛУГИ ПО ТЕХНОЛОГИЯМ
ERP
Позвольте нашим решениям ERP объединить вашу компанию. Не заканчивайте с разными решениями и одной и той же головной болью. Наши индивидуальные решения Microsoft обеспечат безупречную работу программного обеспечения для бухгалтерского учета, финансов и управления персоналом, обеспечивая непревзойденную совместную работу и рост компании.
Узнайте больше о наших решениях ERP Запросить консультацию по ERPCRM
Бизнес — ничто без клиентов.
Если ваша цель — улучшить деловые отношения, мы можем предоставить вам персонализированную CRM-систему с возможностью помочь в управлении контрактами и продажами, производительности агентов и на всем жизненном цикле клиента. Узнайте больше о наших возможностях CRM Запросить консультацию по crmАвтоматизация бизнес-процессов
Компания Merge IT обладает десятилетним опытом предоставления экономически эффективных способов улучшения бухгалтерских и финансовых процессов в вашей организации. Если ваша организация быстро растет, это позволит вам масштабировать ресурсы по мере необходимости и снизит нагрузку на наем, обучение и содержание персонала.
Запросить консультацию по финансовому и бухгалтерскому аутсорсингуИнфраструктура
В наш цифровой век важно, чтобы ваши системы могли не только выживать, но и процветать. Без надлежащей инфраструктуры ваша компания не сможет идти в ногу с вашим ростом.
Давайте оценим и оптимизируем то, что вы уже используете, или создадим совершенно новый план для управления операциями с таким количеством ИИ, какое вам нужно.Пришло время автоматизировать ваши рабочие процессы и сделать возможной интеграцию и распространение данных.
Запросить консультацию по инфраструктуре
Разработка и интеграция приложений
Когда вы интегрируете новую техническую систему в свой бизнес, вы хотите ОБЪЕДИНИТЬ пробелы между вашими процессами и системой. Когда мы внедряем, у нас есть возможность настраивать приложения кода, необходимые вашей организации, чтобы быть максимально эффективными. Мы можем обновить ваши системы И убедиться, что у вас есть приложения в этой системе, которые делают то, что вам нужно, даже автоматически.
Запросите индивидуальную консультацию по разработке приложенийРешения для электронной коммерции
В интернет-магазине так много всего.
Ваша система работает оптимально или настолько интегрирована, насколько это возможно? Нужна ли вам помощь с вашей инфраструктурой, бухгалтерским учетом, приемкой на склад и т. д., мы предлагаем решения, которые произведут революцию в ваших внутренних процессах без больших затрат. Узнайте больше о наших решениях для электронной коммерции Запросить консультацию по решению для электронной коммерцииМы сотрудничаем с вами и вашими системами
Мы НЕ внедряем системы и не оставляем вас в затруднительном положении. Мы оцениваем, планируем и выполняем ВМЕСТЕ с вами, чтобы максимально оптимизировать ваш бизнес.
Осязаемые результаты
Вы увидите измеримый рост бизнеса с увеличением рентабельности инвестиций и снижением рисков. Наши системные реализации и решения позволяют вам сосредоточиться на своих целях с помощью эффективных систем, чтобы оставаться впереди конкурентов и поддерживать максимальную производительность ваших сотрудников.
Мы понимаем ПЕРВЫМ
60% внедрений терпят неудачу из-за пробелов, оставшихся между вашими текущими процессами и вашей новой системой. Мы лучшие в том, что мы делаем, потому что мы ОБЪЕДИНЯЕМ наш опыт и решения С вашими текущими процессами, чтобы вы могли достичь своих бизнес-целей, как никогда раньше. В отличие от конкурентов, мы с вами на каждом этапе внедрения, а наши знания инновационных решений упрощают даже самые сложные системы.