powered by simpleCommunicator - 2.0.19     © 2024 Programmizd 02
Map
Форумы / Управление процессом разработки ИС [игнор отключен] [закрыт для гостей] / GIT и DEV-TEST-PROD
25 сообщений из 62, страница 1 из 3
GIT и DEV-TEST-PROD
    #40010455
Фотография Критик
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Как в GIT осуществляется работа по веткам DEV-TEST-PROD? (работа ведется в VS)

Как мы это делали в TFS:
- Сначала создали DEV-ветку, из нее клонируются TEST, PROD.
- В DEV работают разработчики, по завершению разработки они делают merge своих изменений в DEV->TEST
- Тестировщики работают TEST-ветке и могут как откатить changeset обратно, так и сделать merge в TEST->PROD
- В релизный день содержимое PROD-ветки билдится и накатывается на продуктив

1) В GIT же у меня какой-то локальный репозиторий master + репозиторий master на сервере.
Я могу переименовать локальный репозиторий master в DEV, но в скобках там остается origin/master, что это? см картинка

2) Я могу создать локальную ветку, но мне не понятно, как создать серверную ветку TEST, которая потом будет собираться и выкладываться на тестовый сервер и ветку PROD?

3) Как в GIT решаются конфликты? В TFS (в той схеме, что я использовал ранее) только 1 разработчик мог брать объект на редактирование в DEV-ветке и конфликты возникали, только если он делал большую паузу перед отправкой DEV->TEST, и при этом в TEST-ветке уже лежала чья-то более свежая версия кода. А тут как? Может разрабочик как-то увидеть, что его сосед правит "его" объекты, которые ему нужны для данной задачи? Или это выявится только на этапе синхронизации репозиториев?
...
Рейтинг: 0 / 0
GIT и DEV-TEST-PROD
    #40010456
Фотография Критик
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Вдогонку - чтобы на win-компе выполнять команды git`а что нужно установить?
Какие есть удобные GUI-средства?
...
Рейтинг: 0 / 0
GIT и DEV-TEST-PROD
    #40010471
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Критик,

Посмотрите в сторону git-flow .

Переименование веток нужно запретить.
Продуктовые master-ветки должны быть заблокированы для внесения изменений, только через pull-request.
...
Рейтинг: 0 / 0
GIT и DEV-TEST-PROD
    #40010485
Фотография Критик
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
hVostt,

вот так?
...
Рейтинг: 0 / 0
GIT и DEV-TEST-PROD
    #40010491
istrebitel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Как оно работает По пунктам 1 и 2 описано в Ветвление в Git - Удалённые ветки
  • 1. Ваша локальная ветка "сцеплена" с удалённой, вы переименовали локальную, но она "сцеплена" с всё той же удалённой.
Посмотреть какие ветки только локальные а какие связанные
Код: plaintext
git branch -vv
ProGitОтслеживание веток
  • Получение локальной ветки из удалённой ветки автоматически создаёт то, что называется “веткой слежения” (а ветка, за которой следит локальная называется “upstream branch”). Ветки слежения — это локальные ветки, которые напрямую связаны с удалённой веткой. Если, находясь на ветке слежения, выполнить git pull, то Git уже будет знать с какого сервера получать данные и какую ветку использовать для слияния.
    • 2. ProGitЕсли у вас есть ветка serverfix, над которой вы хотите работать с кем-то ещё, вы можете отправить её точно так же, как вы отправляли вашу первую ветку. Выполните команду git push <remote> <branch>:
    • $ git push origin serverfix
    • Counting objects: 24, done.
    • Delta compression using up to 8 threads.
    • Compressing objects: 100% (15/15), done.
    • Writing objects: 100% (24/24), 1.91 KiB | 0 bytes/s, done.
    • Total 24 (delta 2), reused 0 (delta 0)
    • To https://github.com/schacon/simplegit
    • * new branch serverfix -> serverfix
      • 3. Конфликты разруливаются в момент слияния человеком. Например в git настраивается mergetool на работу с p4merge и в момент слияния git говорит есть конфликты. Вы даёте команду git mergetool она открывает каждый конфликтный файл в p4merge в котором 3 стороны как было в общем предке, как накодено сейчас в репе и как у вас и вы решаете как это разрулить.
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40010510
    Фотография Критик
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    А кто такой Code owner в git?
    Первый добавивший, или Maintainer, или owner со вкладки "Group members" web-интерфейса?
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40010574
    fkthat
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    Критик
    Какие есть удобные GUI-средства?

    Не так давно вышел удобный Windows Terminal
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40010761
    Alexey Tomin
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    Критик
    Как в GIT осуществляется работа по веткам DEV-TEST-PROD? (работа ведется в VS)

    Как мы это делали в TFS:
    - Сначала создали DEV-ветку, из нее клонируются TEST, PROD.
    - В DEV работают разработчики, по завершению разработки они делают merge своих изменений в DEV->TEST
    - Тестировщики работают TEST-ветке и могут как откатить changeset обратно, так и сделать merge в TEST->PROD
    - В релизный день содержимое PROD-ветки билдится и накатывается на продуктив


    Вы хотите git-flow. Например описана тут: https://habr.com/ru/post/106912/
    Моё мнение- штука не слишком удобная. Лучше использовать gitlab-flow, например вот описание: https://habr.com/ru/company/softmart/blog/316686/

    Критик
    В GIT же у меня какой-то локальный репозиторий master + репозиторий master на сервере.
    Я могу переименовать локальный репозиторий master в DEV, но в скобках там остается origin/master, что это? см картинка


    Не стоит. Совсем не стоит. Это запутывает.
    Вы хотите что-то сделать. Создаётелокальную ветку на основе DEV, пишите туда коммиты, пушите а потом делаете pull request (github) или merge request (gitlab) - суть почти так же.

    Критик
    Я могу создать локальную ветку, но мне не понятно, как создать серверную ветку TEST, которая потом будет собираться и выкладываться на тестовый сервер и ветку PROD?


    Например создать локально, а потом сделать push

    Критик
    Как в GIT решаются конфликты?


    Двое меняют одну строку локально- никак.
    Двое сделали push веток, создали merge/pull request - никак.
    Один из request'ов замержили - второй видит, что есть конфликт- правит его.

    Критик
    Вдогонку - чтобы на win-компе выполнять команды git`а что нужно установить?


    https://git-scm.com/download/win
    Он даже SSH настраивает (хотя в целом с ssh в винде плохо всё).


    Критик
    А кто такой Code owner в git?
    Первый добавивший, или Maintainer, или owner со вкладки "Group members" web-интерфейса?


    Вообще git сейчас используется не так, как задумывался.
    Изначально предполагалось, что "главного" сервера нет, есть только некоторый выделенный компьютер, а все обмениваются кодом делая pull-request - предлождение забрать с твоего компьютера код и вмержить его в репозиторий на компьютере "владельца".

    Но сейчас все используют сервера для хранения информации - https://github.com/ https://gitlab.com/ https://bitbucket.org/
    Первый теперь принадлежит Микрософту и поддерживает сборку кода в том числе для windows (и хорошо поддерживает- и java кучи версий есть, и innosetup и msys2).
    Причём на всех есть бесплатные планы, а есть платные на разных вкус (а можно и локально сервер поставить- у гитлаба бесплатно даже).
    Без сервера нынче никто не работает, а там настройка прав широкая- кто owner, кто master, и прочее.
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40010772
    fkthat
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    Alexey Tomin
    Лучше использовать gitlab-flow

    Пробовали - не понравилось. Git-flow он более, как бы сказать, регламентированный, и, что самое главное, он из коробки поддержиается самим Git (git flow ****). Для гитлаб-флоу все пляски с мержами, удалениями веток, пушами приходится делать руками. С гитфлоу я набирая в консоли: 'git flow feature finish -r -S -D --push' и все , сколько раз мне надо будет в бубен ударить для того же в случае гитлаб-флоу?

    Впрочем, у гитфлоу есть неудобство когда мы релизим новые версии, но при этом надо подерживать и старые - он лучше рассчитан на просто последовательный выпуск все более новых версий. Хотя в крайних версиях для этого, кажется, уже ввели специальные "support branches" - я, правда, не пробовал, у нас продукты все заказные, поэтому пока что нужды не возникало.
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40010775
    fkthat
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    hVostt
    Переименование веток нужно запретить.

    Так на самом деле переименования веток и не существует, если я не ошибаюсь. Хочешь переименовать - создавай новую а старую прибивай.
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40010801
    fkthat
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    Alexey Tomin
    Вообще git сейчас используется не так, как задумывался.
    Изначально предполагалось, что "главного" сервера нет, есть только некоторый выделенный компьютер

    Ну так гитхаб это и есть этот самый "выделенный компьютер". И, на самом деле, гит задумывался вообще без "выделенного компьютера", на то он и распределенный.
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40010830
    Alexey Tomin
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    fkthat
    Alexey Tomin
    Лучше использовать gitlab-flow

    Пробовали - не понравилось. Git-flow он более, как бы сказать, регламентированный, и, что самое главное, он из коробки поддержиается самим Git (git flow ****). Для гитлаб-флоу все пляски с мержами, удалениями веток, пушами приходится делать руками. С гитфлоу я набирая в консоли: 'git flow feature finish -r -S -D --push' и все , сколько раз мне надо будет в бубен ударить для того же в случае гитлаб-флоу?


    Создать pull/merge-request с галочкой "удалить ветку после мержа" и после ревью нажать кнопочку "merge"
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40010841
    fkthat
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    Alexey Tomin
    Создать pull/merge-request с галочкой "удалить ветку после мержа" и после ревью нажать кнопочку "merge"

    Ну да, без "галочек" и "кнопочек" нынешнему разработчику никуда. Гребанный стыд, даже в убунтушных туториалах уже повсюду "редактор nano"
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40010938
    Фотография Критик
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    Если разработчик начинает редактировать код, то он редактирует его в локальном репозитории. А если этот код уже кто-то поменял и отправил 3 новых версии в удаленный репозиторий? Насколько я понимаю, локальные репозитории ведь не обновляются сами?

    У разработчика будет сообщение об устаревшей версии до момента начала редактирования?
    Или он об этом узнает лишь постфактум? (когда он попробует сам зафиксировать код в удаленном репозитории и, наверное, получит merge-конфликт).

    Разработчик по приходу на работу обязательно должен нажать кнопку получения последней версии? Это чтобы свести такие ситуации к минимуму.
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40010946
    fkthat
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    Критик,

    В общем случае такого быть не должно. На каждый таск заводится отдельная фича-ветка и девелопер один в ней работает ни с кем не конфликтуя. Когда работа полностью закончена тогда его ветка мержится в общую develop-ветку. Напрямую писать что-то в develop-ветку нельзя, все изменения только через мерж (или через rebase + fast-forward). Обычно делают вторым способом, чтобы не устраивать хитросплетения из веток и мержей. Опционально, если детальная история изменений не так критична, то делают еще stash ("схлопывают" все коммиты в один большой).
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40010953
    Alexey Tomin
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    Критик
    Если разработчик начинает редактировать код, то он редактирует его в локальном репозитории. А если этот код уже кто-то поменял и отправил 3 новых версии в удаленный репозиторий? Насколько я понимаю, локальные репозитории ведь не обновляются сами?


    Вам надо читать основы git - про pull/push/fetch/merge и прочее.
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40010954
    Alexey Tomin
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    fkthat
    Alexey Tomin
    Создать pull/merge-request с галочкой "удалить ветку после мержа" и после ревью нажать кнопочку "merge"

    Ну да, без "галочек" и "кнопочек" нынешнему разработчику никуда.


    Я ревью смотрю либо в UI gitlab/github, либо в IDEA. Вот настолько к галочкам привык.

    fkthat
    Гребанный стыд, даже в убунтушных туториалах уже повсюду "редактор nano"


    Я вообще mcedit использую
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40011004
    fkthat
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    Alexey Tomin
    Вам надо читать основы git - про pull/push/fetch/merge и прочее.

    Тем более совершенно бесплатная книжка даже в русском переводе доступна.
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40011462
    fkthat
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    Alexey Tomin
    хотя в целом с ssh в винде плохо всё

    А что там с ssh не так? В десятке и клиент и сервер из коробки. Про сервер не скажу, но клиентом пользуюсь каждый день и все абсолютно ок. Гит, правда, кажется, своего собственного клиента использует, но с ним тоже все ок.
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40011469
    fkthat
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    Alexey Tomin
    Я ревью смотрю либо в UI gitlab/github, либо в IDEA. Вот настолько к галочкам привык.

    Да это я прикалываюсь. Хотя я сам в ГУИ (вижуал студия) только смотрю хистори, когда надо и конфликты резолвью, все остальное как-то исторически привык делать в командной строке.

    Alexey Tomin
    Я вообще mcedit использую

    Не. Тут я непреклонен и категоричен. Только vim Под студию и VS Code стоят вимовские расширения, если что по-мелкому быстро поправить, типа как в ноутпаде для этого стоит виндовая версия консольного, капслок специально переназначен на ескейп :))
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40011473
    Фотография hVostt
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    fkthat
    hVostt
    Переименование веток нужно запретить.

    Так на самом деле переименования веток и не существует, если я не ошибаюсь. Хочешь переименовать - создавай новую а старую прибивай.


    Ну я имею в виду вообще такое понятие как факт, как бы оно не выполнялось :)

    fkthat
    Пробовали - не понравилось. Git-flow он более, как бы сказать, регламентированный


    Гит-флоу чёткий, гибкий и кастомизируется под процессы.

    А вот это стремление всё "упрощать", зачастую приводит на деле к обыкновенной банальной деградации.
    При чём проявляется везде -- в искусстве, в дизайне, в работе.

    На примере gitlab-flow, типа есть фичи ветки и мастер. Всё.
    А чё дальше не пошли?

    В топку ветки. Только master, только хардкор, lean просто зашкаливающий.

    Упрощение понимают крайне искажённо. Не понимают, что простые в использовании вещи внутри сложные, а вовсе не наоборот. Чтобы процесс разработки был простым, значит он должен быть достаточно гибким и понятным, а не примитивным на подобие палки с мордой коня вместо сложного мотоцикла.

    Прям на ржач пробивает глядя на упрощателей всего и вся :))
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40011484
    fkthat
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    hVostt
    На примере gitlab-flow, типа есть фичи ветки и мастер. Всё.
    А чё дальше не пошли?

    Справедливости ради, там все же есть релизные ветки. Когда выпускается очередная версия, то для неё делаеься ветка от мастера и туда уже вносятся только фиксы. Но вообще с гитлабфлоу я видел бардак, т.к. в нем нет даже какого-то общепринятого стандарта именования веток - каждый точит, как он хочет.

    hVostt
    Прям на ржач пробивает глядя на упрощателей всего и вся :))

    Меня приколол такой аргумент в их мануалах, что, дескать, большой недостаток git-flow это то что там основная рабочая ветка это не master, как, типа, все привыкли, а develop. Кто эти "все привыкли", я не знаю. Гитхаб, например, изначально при создании репо назначает веткой по-умолчанию именно develop.

    И вообще я нелюбитель гитлаба в целом. У них этакий комбайн, в котором, вроде бы все есть, но любое отдельное из этого "все" на порядок хуже существующих альтернатив. Если уж сравнивать "комбайны", то тот же Azure DevOps по удобству и фичам кроет гитлаб как бык овцу.
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40011488
    Alexey Tomin
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    hVostt

    На примере gitlab-flow, типа есть фичи ветки и мастер. Всё.
    А чё дальше не пошли?

    В топку ветки. Только master, только хардкор, lean просто зашкаливающий.


    Это github-flow

    hVostt

    Упрощение понимают крайне искажённо. Не понимают, что простые в использовании вещи внутри сложные, а вовсе не наоборот. Чтобы процесс разработки был простым, значит он должен быть достаточно гибким и понятным, а не примитивным на подобие палки с мордой коня вместо сложного мотоцикла.

    Прям на ржач пробивает глядя на упрощателей всего и вся :))


    Дело, собственно, не в упрощении.
    Если посмотреть реальные отличия gitlab-glow от gitflow, то аналогом ветки develop - фичивая ветка.
    Аналог release - master
    Аналог master - v1.0 и прочие ветки конкретных версий.

    Я сейчас вот в основном своём проекте работаю по gitflow, а в "побочных" - gitlab-flow и github-flow, так что сравнить могу. Раньше был на основном, где gitlab-flow.
    В чём лично мне видится минус gitflow и плюс gitlab-flow?
    1. Непонятно как тестировать большую фичу без пересечением с другими фичами.
    2. Если надо поправить "позапрошлый" релиз то это сделать проще в gitlab-flow. Там всегда релиз имеет свою ветку.

    В чём плюс gitflow?
    1. Когда развернуть серверную часть дорого, то наличие 3х веток и не больше- это намного дешевле.
    2. Когда клиентских приложений 5 разных - то это позволяет синхронизировать весь это зоопарк.
    Собственно эти оба пункта про текущий проект, так что gitflow оправдан.

    В чём плюс github-flow? Хорошо на старте разработки, пока все постоянно рефакторинг фигачат - с мержем проблем нет.

    fkthat
    Но вообще с гитлабфлоу я видел бардак, т.к. в нем нет даже какого-то общепринятого стандарта именования веток - каждый точит, как он хочет.


    Уровень бардака определяется квалификацией участников, а не процессом.
    Попытки заменить квалифицированных разработчиков процессами всегда приводит к провалу.
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40011495
    fkthat
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    Alexey Tomin
    1. Непонятно как тестировать большую фичу без пересечением с другими фичами.

    Так фича живет в отдельной ветке, какие пересечения?

    Alexey Tomin
    2. Если надо поправить "позапрошлый" релиз то это сделать проще в gitlab-flow. Там всегда релиз имеет свою ветку.

    Это да, я об этом ранее тут писал. Но для этого, как я упоминал, уже достаточно давно ввели "support branches" которые полный аналог релизных веток гитлаб-флоу.

    Alexey Tomin

    Уровень бардака определяется квалификацией участников, а не процессом.
    Попытки заменить квалифицированных разработчиков процессами всегда приводит к провалу.

    Очень сильно сомневаюсь. За свою карьеру насмотрелся уже всевозможных квалифицированных поделий. По мне так даже команда макак, но делающих все по учебникам, гайдам и процессам представляет куда меньшую опасность.
    ...
    Рейтинг: 0 / 0
    GIT и DEV-TEST-PROD
        #40011554
    Фотография skyANA
    Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
    Участник
    fkthat
    Alexey Tomin
    1. Непонятно как тестировать большую фичу без пересечением с другими фичами.

    Так фича живет в отдельной ветке, какие пересечения?

    Речь видимо про то, что чем дольше живёт большая фича в своей ветке, тем чаще надо подмёрживать develop в неё.
    ...
    Рейтинг: 0 / 0
    25 сообщений из 62, страница 1 из 3
    Форумы / Управление процессом разработки ИС [игнор отключен] [закрыт для гостей] / GIT и DEV-TEST-PROD
    Целевая тема:
    Создать новую тему:
    Автор:
    Закрыть
    Цитировать
    Найденые пользователи ...
    Разблокировать пользователей ...
    Читали тему (0):
    Читали форум (0):
    Пользователи онлайн (0):
    x
    x
    Закрыть


    Просмотр
    0 / 0
    Close
    Debug Console [Select Text]