Форум программистов, компьютерный форум, киберфорум
Системы контроля версий
Войти
Регистрация
Восстановить пароль
 
 
Рейтинг 5.00/47: Рейтинг темы: голосов - 47, средняя оценка - 5.00
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
1

Чем отличается git merge От git pull

05.07.2016, 13:13. Просмотров 9490. Ответов 20
Метки нет (Все метки)


в обоих случаях я забираю изменения в свою ветку. в чем различие?
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
05.07.2016, 13:13
Ответы с готовыми решениями:

Разница межу git fetch+merge и pull
Есть удаленный реп. Правильно ли я понимаю, что если я выполню на локальной машине: git fetch git...

Ошибки выполняя git pull
вСЕМ привет! Получил от другого разработчика проект в виде .zip-файла и внеся изменения перевел...

Git merge errors
Совершенно не получается скачать последние изменения, сделанные другим человеком на моем...

Механизм работы git merge
Мне стало интересно как изнутри работает механизм git merge. То есть допустим если я создал две...

20
Эксперт .NET
7522 / 5016 / 1194
Регистрация: 25.05.2015
Сообщений: 15,297
Записей в блоге: 14
05.07.2016, 15:11 2
Pull скачивает с сервера и делает merge.
0
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
05.07.2016, 16:44  [ТС] 3
Rius, а просто ,merge?
0
Эксперт .NET
7522 / 5016 / 1194
Регистрация: 25.05.2015
Сообщений: 15,297
Записей в блоге: 14
05.07.2016, 16:45 4
А merge делает merge.
pull в варианте по умолчанию это почти аналог fetch с последующим merge.

https://git-scm.com/docs/git-merge
https://git-scm.com/docs/git-pull
0
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
05.07.2016, 17:20  [ТС] 5
Rius, но в любом случае я получаю все изменения в свою ветку с другой ветки?
0
Эксперт .NET
7522 / 5016 / 1194
Регистрация: 25.05.2015
Сообщений: 15,297
Записей в блоге: 14
05.07.2016, 17:27 6
Разными путями, с разными последствиями, с разным видом получаемого дерева версий.
Команды не эквивалентны.

Добавлено через 3 минуты
Надо использовать те команды, которые подходят по месту. А не "они же одинаковы". Потому что дерево может быть аккуратным вьюном, а может быть грибницей.
0
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
05.07.2016, 17:31  [ТС] 7
Rius,

не понятно. мерж делает мерж, а пул скачивает и делает мерж
0
Эксперт .NET
7522 / 5016 / 1194
Регистрация: 25.05.2015
Сообщений: 15,297
Записей в блоге: 14
05.07.2016, 17:33 8
Да.
Что именно непонятно? Подробнее.
0
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
06.07.2016, 13:58  [ТС] 9
Rius,

получается pull это улучшенный вариант мержа?
0
Эксперт .NET
7522 / 5016 / 1194
Регистрация: 25.05.2015
Сообщений: 15,297
Записей в блоге: 14
06.07.2016, 14:01 10
Нет. Это лишь команда для подтягивания коммитов из удалённого репозитория в текущую ветку (по умолчанию).
Особенно удобен
Bash
1
git pull --rebase
, позволяющий обойтись без ненужных слияний.
0
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
06.07.2016, 15:06  [ТС] 11
Rius,

допустим кто-то сделал изменения в своей ветке, назовем ее vetka1

у меня есть своя ветка, называется vetka2

этот кто-то сделал коммит в vetka1, мне нужно забрать изменения из vetka1 в vetka2

если я делаю git pull vetka1, то я скачиваю эти изменения себе в vetka2

если я делаю git merge vetka1, то я так же забираю изменения в vetka2
0
Эксперт .NET
7522 / 5016 / 1194
Регистрация: 25.05.2015
Сообщений: 15,297
Записей в блоге: 14
06.07.2016, 15:16 12
Типа того. Только через pull забирать изменения из другой ветки не стоит, можно историю кривой сделать.
0
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
06.07.2016, 16:59  [ТС] 13
Rius, тогда вообще разницы не вижу, скачаю я эти изменения или соединю две ветки результат то тот же
0
Эксперт .NET
7522 / 5016 / 1194
Регистрация: 25.05.2015
Сообщений: 15,297
Записей в блоге: 14
06.07.2016, 20:01 14
Скачать можно обновления текущей ветки, из удалённого репозитория, в текущую же ветку.
Объединить можно только что-то с чем-то (3 ветки сразу, например), но не само с собой.
Не видите разницы? Это не имеет значения. Надо просто пользоваться теми командами, что подходят к конкретному случаю.
0
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
07.07.2016, 10:29  [ТС] 15
Rius, т.е. git pull нельзя сделать из ветки vetka1 Находять при этом в vetka 2?

p.s.как же можно понять какой случай лучше использовать, если я не могу понять разницы в командах?)
0
Эксперт .NET
7522 / 5016 / 1194
Регистрация: 25.05.2015
Сообщений: 15,297
Записей в блоге: 14
07.07.2016, 10:32 16
Лучший ответ Сообщение было отмечено Mashka_mulashka как решение

Решение

Цитата Сообщение от Mashka_mulashka Посмотреть сообщение
т.е. git pull нельзя сделать из ветки vetka1 Находять при этом в vetka 2?
Можно, но обычно лучше не стоит.

Если надо загрузить изменения удалённой текущей ветки в локальную текущую ветку, пользуйтесь git pull --rebase.
Если надо слить одну локальную ветку с другой, то git merge.
1
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
07.07.2016, 10:33  [ТС] 17
Rius, т.е. git merge работает только с локальными ветками?
0
Эксперт .NET
7522 / 5016 / 1194
Регистрация: 25.05.2015
Сообщений: 15,297
Записей в блоге: 14
07.07.2016, 10:35 18
Да.
Чтобы с удалёнными, их надо сначала загрузить, через git fetch например.
0
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
07.07.2016, 10:39  [ТС] 19
Rius, а чем отличается git pull -rebase От git pull?
0
Эксперт .NET
7522 / 5016 / 1194
Регистрация: 25.05.2015
Сообщений: 15,297
Записей в блоге: 14
07.07.2016, 10:52 20
Предположим, у Вас есть удалённая ветка и локальная её копия.
Вы закоммитили в локальную ветку что-то.
Кто-то другой закоммитил и запушил в репозиторий в эту же ветку.
Название: C1.PNG
Просмотров: 73

Размер: 2.6 Кб
Вам надо скачать себе изменения, но там ветки пошли разными путями.
Если сделать git pull, у Вас случится merge, что создаёт один лишний коммит и искривляет историю.
Если git pull --rebase, то скачаются изменения, найдётся общий коммит удалённой и локальной ветки, удалённые изменения применятся к нему, а Ваши - после удалённого. История останется прямой.
Название: C2.PNG
Просмотров: 72

Размер: 2.5 Кб
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
07.07.2016, 10:52

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь или здесь.

Как сделать git pull, не затерев при этом в директории папки и файлы
Привет. Мне необходим сделать git pull origin master в текущую директорию, но у меня в ней лежат...

Команда $git init создает .git не в той папке
Привет. Не нашел на форуме раздела, где мог бы задать вопрос по работе git, пишу поэтому сюда....

Not a git repository or any of the parent directories git
Всем привет. Случилось нечто досадное. Я закончил работу в локальной ветке и перешел в мастер,...

git - gitk и git-gui
На сайте raboj.su написаноЭто имеется в виду, что надо перейти в какую именно папку?


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.