Я клонировал проект из главной ветки из удаленного репозитория remote_repo
. Я создаю новую ветку, и я фиксирую эту ветвь. Другие программисты нажали на remote_repo
, чтобы овладеть веткой. Теперь мне нужно перегрузить мою ветку RB на мастер remote_repo
. Как это сделать? Какие команды нужно вводить в терминал?
Как переустановить локальную ветку с удаленным мастером
Ответ 1
Сначала выберите новый мастер из восходящего репозитория, а затем переустановите свою рабочую ветку на это:
git fetch origin # Updates origin/master
git rebase origin/master # Rebases current branch onto origin/master
Обновить: см. Paul Draper answer для более кратких способов сделать то же самое - последние версии Git обеспечивают более простой способ для выполнения эквивалента указанных выше двух команд.
Ответ 2
git pull --rebase origin master
# where --rebase[=(false|true|merges|preserve|interactive)]
Ответ 3
После внесения изменений в вашу ветку, извлеките master
и извлеките его, чтобы получить последние изменения из репо:
git checkout master
git pull origin master
Затем оформите свою ветку и внесите изменения в master
:
git checkout RB
git rebase master
... или две последние команды в одной строке:
git rebase master RB
При попытке вернуться к origin/RB
вы, вероятно, получите ошибку; если вы единственный, кто работает над RB
, вы можете принудительно нажать:
git push --force origin RB
... или если вы правильно настроили git:
git push -f
Ответ 4
Примечание. Если у вас уже есть широкие знания о перебазировании, используйте быструю перебазировку под одним вкладышем. Решение: Предположим, что вы работаете в своей ветке и являетесь единственным человеком, работающим над ней.
git fetch && git rebase origin/master
Разрешите любые конфликты, протестируйте свой код, передайте и отправьте новые изменения в удаленную ветку.
~: For noobs :~
Следующие шаги могут помочь любому, кто новичок в git rebase
и хочет сделать это без хлопот
Шаг 1: Предполагая, что в данный момент в YourBranch нет изменений и изменений, которые необходимо внести. Мы посещаем YourBranch.
git checkout YourBranch
git pull --rebase
Что случилось? Извлекает все изменения, сделанные другими разработчиками, работающими над вашей веткой, и отменяет ваши изменения поверх нее.
Шаг 2: Разрешите любые конфликты, которые представляют.
Шаг 3:
git checkout master
git pull --rebase
Что случилось? Извлекает все последние изменения с удаленного мастера и восстанавливает локальный мастер на удаленном мастере. Я всегда держу удаленный мастер в чистоте и готовлюсь к выпуску! И предпочитаю работать только на мастере или ветких локально. Я рекомендую делать это до тех пор, пока вы не получите руку на изменения или коммиты git. Примечание. Этот шаг не требуется, если вы не обслуживаете локальный мастер, вместо этого вы можете напрямую выбрать и перебазировать удаленный мастер в локальной ветке. Как я уже упоминал в одном шаге в начале.
Шаг 4: Разрешите любые конфликты, которые представляют.
Шаг 5:
git checkout YourBranch
git rebase master
Что случилось? Ребаз на мастера случается
Шаг 6: Решите любые конфликты, если они есть. Используйте git rebase --continue
чтобы продолжить перебазирование после добавления разрешенных конфликтов. В любое время вы можете использовать git rebase --abort
для git rebase --abort
.
Шаг 7:
git push --force-with-lease
Что случилось? Вносить изменения в ваш удаленный YourBranch. --force-with-lease
будет проверять, есть ли какие-либо другие входящие изменения для YourBranch от других разработчиков во время перебазирования. Это супер полезно, а не силовой толчок. В случае каких-либо входящих изменений, загрузите их, чтобы обновить локальный YourBranch, прежде чем отправлять изменения.
Почему я должен толкать изменения? Переписать сообщение коммита в удаленном YourBranch после правильной перебазировки или если разрешены какие-либо конфликты? Затем вам нужно отправить внесенные вами изменения в локальное хранилище в удаленное хранилище YourBranch.
Yahoooo...! Вы успешно сделали перебазирование.
Вы также можете заняться:
git checkout master
git merge YourBranch
Когда и почему? Объедините вашу ветку с master, если внесены изменения, внесенные вами и другими соавторами. Что делает YourBranch современным с master, когда вы захотите поработать над той же веткой позже.
~: (๑ơ ₃ ơ)♥ rebase :~
Ответ 5
git fetch origin master:master
извлекает последнюю версию master, не проверяя ее.
Так что все, что вам нужно, это:
git fetch origin master:master && git rebase master
rebase 👌
Ответ 6
1. Сначала обновите мастер...
git checkout [master branch]
git pull [master branch]
2. Теперь перебазируем исходную ветку с главной веткой
git checkout [source branch]
git rebase [master branch]
git pull [source branch] (remote/source branch)
git push [source branch]
Если ветвь источника еще не существует на удаленном компьютере, выполните:
git push -u origin [source branch]
"и вуаля..."
Ответ 7
Шаг 1:
git fetch origin
Шаг 2:
git rebase origin/master
Шаг 3: (исправить, если возникнут конфликты)
git add .
Шаг 4:
git push --force