Как сделать копию в личное хранилище github
Есть ли простой способ сделать резервную копию всего репозитория git, включая все ветви и теги?
Некоторые поисковые запросы, которые я проводил, не включали этот вопрос в свои результаты: "git clone абсолютно все разветвляет теги заметки"; "git clone все в хранилище"; msgstr "сделать клон репо со всеми заметками тэгов".
Как насчет просто сделать его клоном?
Каждый репозиторий является резервной копией своего удаленного.
@Daniel: если вы клонируете репозиторий, вы выбираете каждую ветку, но отмечается только одна ветка по умолчанию. Попробуй git branch -a . Возможно, это более очевидно: после клонирования репозитория вы не получаете каждую ветку, вы получаете каждый коммит. Ветви только ссылаются на существующий коммит.
Я думаю, что он хорошо знает команду клонирования, если он может задать такой вопрос, и ему явно недостаточно (потому что это клон, а не дамп). Дампы - это разные вещи в виде простых копий, например: 1) они не нужны для того, чтобы быть оптимальными (или даже способными) для нормальной работы 2) но они должны иметь хорошую устойчивость и защиту от повреждения данных.
@peterh Конечно, но git clone охватывает все это. (1) не является обязательным, не является обязательным требованием. Если результат все еще оптимизирован, это все еще резервная копия (2), уже покрытая самим git. - Смысл, который я хотел бы сказать, состоит в том, что, если git clone уже охватываются соответствующие пункты, для чего вам нужен другой инструмент? Хотя я также предпочитаю, git bundle я не думаю, что мой ответ неверен или недействителен. Вы можете рассматривать оба подхода как горячее резервное копирование.
git bundle будет упаковывать только те ссылки, которые отображаются в git show-ref : сюда входят заголовки, теги и удаленные заголовки.
Очень важно, чтобы используемая основа удерживалась пунктом назначения.
Можно допустить ошибку, если в файле пакета содержатся объекты, уже находящиеся в месте назначения, так как они игнорируются при распаковке в месте назначения.
Для использования этого пакета вы можете клонировать его, указав несуществующую папку (вне любого git-репо):
Это git bundle правильный ответ на мой взгляд, а не принятый. Я думаю, что он хорошо знает команду клонирования, если он может задать такой вопрос, и ему явно недостаточно (потому что это клон, а не дамп). Дампы - это разные вещи, такие как простые копии, например: 1) они не нужны для того, чтобы быть оптимальными (или даже способными) для нормальной работы 2) но они должны обладать хорошей устойчивостью и устойчивостью к повреждению данных 3) это часто полезно если они легко различимы для инкрементных резервных копий, тогда как это не является целью для копий.
Развивая некоторые другие ответы, это то, что я делаю:
Настройте репо: git clone --mirror user@server:/url-to-repo.git
Затем, когда вы хотите обновить резервную копию: git remote update из местоположения клона.
Это создает резервные копии всех веток и тегов, в том числе новых, которые добавляются позже, хотя стоит отметить, что удаляемые ветви не удаляются из клона (что для резервной копии может быть полезным).
Это атомарно, поэтому не имеет проблем, которые могут возникнуть у простой копии.
Расширяя великолепные ответы KingCrunch и VonC
Я объединил их обоих:
После этого у вас есть файл, reponame.bundle который можно легко скопировать. Затем вы можете создать новый нормальный git-репозиторий, используя это git clone reponame.bundle reponame .
Обратите внимание, что git bundle копируются только коммиты, которые приводят к некоторой ссылке (ветви или тегу) в хранилище. Таким образом, запутанные коммиты не сохраняются в связке.
Все содержится в .git каталоге. Просто сохраните это вместе с вашим проектом, как любой файл.
Означает ли это, что достаточно просто выполнить резервное копирование ВСЕХ содержимого каталога, содержащего проект Git?
И как вы гарантируете, что не будут внесены изменения в файлы в этом каталоге при создании резервной копии?
Как подсказал Райдвальд, этот метод может привести к непоследовательному резервному копированию и, следовательно, к потере данных. Следовательно, этот ответ следует удалить или, по крайней мере, предупредить о возможности потери данных.
Я думаю, что он хорошо знает команды copy или, cp и это не соответствует его потребностям. И я также думаю, что он думает о пустом хранилище (хотя его также можно скопировать, я думаю, что это не полнофункциональная резервная копия).
использовать git bundle или клонировать
копирование каталога git не является хорошим решением, поскольку оно не является атомарным. Если у вас большой репозиторий, копирование которого занимает много времени, и кто-то отправляет его в ваш репозиторий, это повлияет на резервное копирование. Клонирование или создание пакета не будет иметь этой проблемы.
Вы можете сделать резервную копию git-репозитория с помощью git-copy с минимальным объемом хранилища.
Затем вы можете восстановить свой проект с git clone
@VonC Да, но у него может быть какая-то дополнительная функция во время переупаковки, или он может анализировать внутреннюю структуру git-репо, которую он может использовать для некоторой оптимизации (реструктуризация места назначения, увеличение скорости и т. Д.).
Правильный ответ IMO - git clone --mirror . Это полностью сделает резервную копию вашего репо.
Git clone mirror клонирует весь репозиторий, заметки, заголовки, ссылки и т. Д. И обычно используется для копирования всего репозитория на новый git-сервер. Это уничтожит все ветки и все, весь репозиторий.
Обычно клонирование репо не включает все ветви, только Мастер.
Создает ли git clone --mirror согласованную резервную копию на определенный момент времени? Что пользователь нажимает на коммит во время резервного копирования? Это отклонено, поставлено в очередь или включено в резервную копию?
Итак, начнем с подбора исходного вопроса:
Затем обогатить его типичными пожеланиями и указать некоторые предварительные настройки:
git - инструмент для разработчиков и поддерживает эту точку зрения через git clone --mirror и git bundle --all .
git - инструмент для разработчиков, и оставляет это администратору. Резервное копирование конфигурации git и конфигурации ОС следует рассматривать как отдельное от резервного копирования содержимого.
- "Cold-Copy"
- Остановите службу, чтобы иметь эксклюзивный доступ к ее файлам. Простои!
- Сервис предоставляет фиксированное состояние для целей резервного копирования. Текущие изменения не влияют на это состояние.
Большинство из них являются общими для резервных копий.
- Достаточно ли места для хранения полных резервных копий? Сколько поколений будет храниться?
- Требуется ли поэтапный подход? Сколько поколений будет храниться и когда снова создавать полную резервную копию?
- Как проверить, что резервная копия не повреждена после создания или со временем?
- Поддерживает ли файловая система жесткие ссылки?
- Поместить резервную копию в один архивный файл или использовать структуру каталогов?
- документы: man git-gc
- Очищает и сжимает репозиторий.
- документы: man git-bundle, man git-rev-list
- Atomic = "Hot-Copy"
- Пакеты являются файлами дампа и могут использоваться напрямую с git (проверить, клонировать и т. Д.).
- Поддерживает пошаговое извлечение.
- Проверяется через git bundle verify .
git clone --mirror
- документы: man git-clone, man git-fsck, в чем разница между git clone --mirror и git clone --bare
- Atomic = "Hot-Copy"
- Зеркала - это настоящие git-репозитории.
- Основное назначение этой команды - создать полное активное зеркало, которое периодически получает обновления из исходного хранилища.
- Поддерживает жесткие ссылки для зеркал в той же файловой системе, чтобы избежать потери места.
- Проверяется через git fsck .
- Зеркала можно использовать как основу для полного резервного копирования файлов.
Резервное копирование в режиме холодного копирования всегда может сделать полное резервное копирование файла: запретить все обращения к репозиториям git, сделать резервное копирование и разрешить доступ снова.
Ищите, с чего бы начать изучение Git и GitHub? Хотите поработать с другими? Усердно трудитесь над проектом? Или вдруг заметили, что заслужить уважение среди технарей можно своим присутствием на GitHub?
Тогда эта статья специально для вас!
На самом деле, в Git нет ничего сложного. Если вы быстро читаете и не тратите уйму времени на установку и регистрацию, то начать работать с GitHub вы сможете уже через 10 минут.
Прочитав данную статью вы научитесь клонировать существующий репозиторий, создавать ветки, вносить изменения и отправлять запросы на изменения. Параллельно освоите работу в терминале, терминальные команды и редактирование файла Markdown ( .md ).
Если вы сможете все это сделать, то можно считать, что вы успешно справились с задачей. А еще вы сможете поучаствовать в своем первом open-source проекте — Стене на GitHub.
Если вы хотите стать настоящим профессионалом в Git и GitHub, то придется еще многому научиться. Однако информации ниже будет вполне достаточно для изучения основ.
Что такое Git и GitHub?
Git — это система управления версиями, которая пришлась по душе практически всем — от разработчиков до дизайнеров. GitHub можно считать соцсетью для хранения кода. Это настоящая Мекка для технарей. Здесь вы можете попрактиковаться в разработке и придумать что-то свое, найти множество open-source проектов, передовых технологий, различных функций и дизайнов.
На GitHub вы учитесь и участвуете в других проектах, храните код для работы или учебы, берете код других проектов и вникаете во все детали. А еще вы можете создавать сайты бесплатно напрямую из репозитория! (Научиться можно здесь)
Если вы хотите работать на GitHub, то вовсе не обязательно быть гуру в программировании, ведь все самое основное делается прямо на сайте.
Не лишним будет разобраться с терминалом, поскольку терминальные команды действительно упрощают жизнь.
Если в статье вы видите команду с угловыми скобками: , то смело удаляйте эти скобки и меняйте их содержимое на нужный вам текст.
Пример: git add . Здесь вы можете написать нечто подобное: git add hello_world.py . Это означает, что вы хотите добавить в репозиторий файл под названием hello_world.py .
Для начала необходимо запомнить следующие терминальные команды:
Затем к ним добавим еще вот эти:
Эти команды вам пригодятся в случае, если вы будете работать с другими людьми или захотите внести какие-то изменения в проект и протестировать их до создания коммита.
Не лишней будет и вот такая команда:
О ней мы также поговорим ниже.
(Если вы работаете на Mac, то у вас уже установлен терминал. Нажмите на иконку с лупой в верхнем правом углу экрана и напечатайте слово terminal ).
Зайдите на GitHub и создайте свой аккаунт. В принципе, этим можно и ограничиться. При желании можете установить Git. Но для работы с GitHub это вовсе не обязательно. Однако если вы планируете заниматься проектами на локальном компьютере, то установка вам все-таки нужна. Можете скачать установщик или установить файлы через менеджер пакетов.
Теперь перейдите в терминал, и начнем работу. Если хотите задать одно имя пользователя для всех репозиториев на компьютере, то напишите:
замените на свое имя в кавычках. Можете написать все, что угодно. Если хотите задать имя только для одного репозитория, то удалите из команды слово global .
Теперь напишите свой адрес электронной почты. Проследите, чтобы он совпадал с адресом, указанным при регистрации на GitHub.
При желании можете скрыть свой электронный адрес. Это сделать несложно, подробнее написано здесь. По сути, вам нужно проставить 2 галочки в своем GitHub-аккаунте.
Теперь вы готовы к работе с Git на локальном компьютере.
Начнем с создания нового репозитория на сайте GitHub. Вы также можете выполнить git init и создать новый репозиторий из директории проекта.
Вариант 1. Я уже знаком с терминалом
Вот как начать работу с Git из терминала.
Если у вас есть директория проекта, то просто перейдите в терминал, а в самой директории проекта выполните команду
Если хотите инициализировать проект со всеми файлами из директории проекта, то выполните команду
Допустим, в вашем проекте есть папка new_project . Вы можете перейти в нее из окна терминала и добавить локальный репозиторий. Это делается через следующую команду:
В вашем проекте появилась новая скрытая директория с названием .git . Именно здесь Git хранит все, что ему нужно для отслеживания проекта. Теперь вы можете последовательно добавлять файлы в область подготовки:
или добавьте сразу все файлы через:
Создать коммит с этими изменениями можно через команду:
Если изменения вас устраивают, напишите:
и отправьте эти изменения в репозиторий. Проверить, есть ли изменения для отправки, можно в любое время по команде:
При внесении изменений следует обновить и сами файлы:
Вариант 2. Я вообще ничего не знаю
Этот вариант выбирают совсем новички в разработке. Вполне возможно, у вас уже есть целая папка с файлами проекта для размещения на GitHub, но вы не знаете, с чего начать.
Ну что ж, приступим к делу!
Репозиторий — это место, в котором вы систематизируете свой проект. Здесь вы храните файлы, папки, видео, изображения, блокноты Jupyter Notebook, наборы данных и т.д. Перед началом работы с Git необходимо инициализировать репозиторий для проекта и правильно его подготовить. Это можно сделать на сайте GitHub.
Лучше сразу добавлять в репозиторий README-файл с информацией о проекте. Это можно сделать в момент создания репозитория, поставив галочку в соответствующем поле.
- Перейдите на сайт GitHub. Нажмите на значок + в верхнем правом углу, а затем выберите New repository.
- Придумайте имя репозитория и добавьте короткое описание.
- Решите, будет ли этот репозиторий размещаться в открытом доступе или останется закрытым для просмотра.
- Нажмите Initialize this repository with a README для добавления README-файла. Настоятельно рекомендую снабжать все ваши проекты файлом-описанием, ведь README — это первая вещь, на которую люди обращают внимание при просмотре репозитория. К тому же, здесь можно разместить нужную информацию для понимания или запуска проекта.
Новый репозиторий
Создание нового репозитория
При желании можете уже сейчас начинать работать над проектом. Добавляйте файлы, вносите в них изменения и т.д. напрямую с сайта GitHub. Однако конечный результат подобной деятельности может вас немного огорчить.
Вносить изменения в проект можно двумя способами. Вы можете изменять файлы/блокноты на компьютере либо делать это на сайте GitHub.
Допустим, вам захотелось подкорректировать README-файл на сайте GitHub.
Изменение файла на GitHub
Подготовка коммита с изменениями
Вы успешно внесли изменения в README-файл своего нового репозитория! Обратите внимание на небольшую кнопку на картинке выше. Она позволяет создавать новую ветку этого коммита и добавлять Pull request. Запомните ее, скоро к ней вернемся.
Как вы видите — ничего сложного!
Лично я предпочитаю работать с файлами на локальном компьютере, а не на сайте GitHub. Поэтому давайте научимся и этому.
Подайте мне вот этот проект!
Возможно, вы захотите клонировать свой новый репозиторий для дальнейшей работы с ним на локальном компьютере. Либо у вас уже есть существующий репозиторий, который вы хотели бы клонировать.
Клонирование или скачивание репозитория
Откройте терминал и перейдите в директорию для копирования репозитория. Например, для перехода на Рабочий стол напечатайте вот это:
Затем клонируйте туда репозиторий по следующей команде:
Все просто! Не забудьте изменить информацию в угловых скобках на нужную вам. И удалите сами скобки .
Если вы не очень хорошо ориентируетесь в терминале, то переход по директориям можно осуществлять через команду cd . Например, откройте терминал и напечатайте ls для отображения перечня доступных директорий. Вполне возможно, что в этом списке вы сразу увидите директорию Desktop . Либо напечатайте cd Desktop . Далее выполните команду git clone и склонируйте репозиторий на Рабочий стол.
Бывает и так, что вместо перечня расположений, вы видите различные имена пользователей. Тогда до того, как перейти в Desktop , вам потребуется выбрать нужного пользователя через команду cd (замените на нужное вам имя). Затем снова напечатайте ls , чтобы увидеть весь список. И вот теперь, увидев в списке Desktop , смело печатайте cd Desktop . Сейчас уже можно выполнять git clone !
Новый GitHub-репозиторий, склонированный на рабочий стол, готов! Данная команда создает точную копию репозитория в вашей системе. Здесь вы сможете с ним работать, редактировать, индексировать изменения, создавать коммиты с изменениями и отправлять их на GitHub.
Совсем не обязательно создавать репозиторий на Рабочем столе. Клонировать можно в любое место на компьютере. Команду git clone можно выполнять и сразу после открытия терминала. Однако, если вы не очень любите копаться в папках на компьютере, то неплохо будет разместить проект на виду, то есть на Рабочем столе…
Если хотите просто покопаться в каком-то проекте, то вместо клонирования можете сделать форк проекта на GitHub. Для этого нажмите кнопку Fork в верхнем правом углу сайта. Так вы добавите копию этого проекта в свои репозитории и сможете вносить туда любые изменения без вреда для оригинала.
Добавляем файлы в проект
Вот, чем мы займемся:
Но ничего сложного здесь нет!
Должно быть, у вас уже есть файлы, которые вы бы хотели разместить в новом репозитории. Отыщите их на компьютере и перетащите в новую папку репозитория на Рабочем столе.
Проверьте статус проекта.
Откройте терминал и перейдите в папку репозитория. Для проверки обновлений выполните:
Если вы перетаскивали файлы в папку проекта, то потребуется обновить состояние репозитория. Добавлять файлы в репозиторий можно по одному:
Это ваши предлагаемые изменения. Операцию можно повторить с новыми файлами либо с уже существующими, но измененными. По сути, ничего нового в сам проект вы не добавляете. Вы всего лишь загружаете новые файлы и указываете Git на эти изменения.
Процесс создания коммитов с изменениями начинается с выполнения команды:
Теперь ваши изменения сохранены в указателе локальной копии проекта. Для отправки изменений на удаленный репозиторий выполните команду:
Тем самым вы отправляете изменения напрямую в репозиторий. Если вы работаете на локальном компьютере и хотите, чтобы коммиты отображались в онлайн, то необходимо своевременно отправлять эти изменения на GitHub по команде git push .
Актуальность версии можно проверить в любое время через команду git status .
Итог: у вас есть свой GitHub репозиторий, вы научились добавлять и изменять в нем файлы.
Клонирование репозитория GitHub создает локальную копию удаленного репо. Это позволяет вам вносить все ваши изменения локально, а не непосредственно в исходные файлы исходного репо. Вот как клонировать репозиторий GitHub.
Первое, что вам нужно сделать, это скачать и установить Git на твоем компьютере. Процесс установки прост и дает вам много стандартной информации. Единственное, с чем следует быть осторожным, — это разрешить использование Git из командной строки.
Позвольте мастеру помочь вам в остальном. После завершения установки вы будете готовы клонировать репозиторий GitHub.
Следующее, что вам нужно сделать, это решить, где хранить репо на вашем локальном компьютере. Мы рекомендуем создать запоминающуюся папку, чтобы вы могли легко перейти к ней с помощью командной строки позже.
После того, как вы решили, где вы хотите сохранить репо, откройте свой веб-браузер и введите URL-адрес репозитория GitHub. В этом примере мы будем использовать популярный репозиторий, содержащий примеры на основе JavaScript предназначен для исследований и обучения.
Затем откройте командную строку (в Windows) или любой другой терминал, который вы используете на своем компьютере.
В терминале перейдите к месту, в котором вы хотите сохранить репо. Вы можете сделать это, набрав следующую команду:
В нашем примере мы должны ввести $ cd DocumentsGIT local.
Примечание: вы можете пропустить этот шаг, используя git вместо этого клонировать репо непосредственно в указанный каталог.
Теперь, когда URL-адрес репо все еще скопирован в буфер обмена, пришло время клонировать репо. Введите следующую команду:
Дайте процессу несколько минут на завершение. Вот как это выглядит, если все прошло гладко.
Рекомендуется убедиться, что репозиторий находится на вашем компьютере. Для этого перейдите в каталог, в котором он хранился.
Теперь вы можете приступить к редактированию каталога с помощью вашего любимого текстового редактора!
Создайте полную локальную копию существующего репозитория Git путем клонирования. При клонировании репозитория загружаются все фиксации и ветви в репозитории. При клонировании настраивается именованная связь с уже клонированным репозиторием. Используйте эту связь для взаимодействия с существующим репозиторием, отправки и получения изменений для совместного использования кода с вашей командой.
По умолчанию Git назначает в origin удаленный репозиторий, из которого выполняется клонирование. Большинству пользователей не требуется более одного удаленного, поэтому в руководстве используются соответствующие origin действия. Дополнительные сведения о настройке удаленных систем в репозитории Git.
Из этого руководства вы узнаете, как выполнить следующие задачи:
- Получение URL-адреса клона в репозитории
- Клонирование репозитория
Получение URL-адреса клона в репозитории
Прежде чем можно будет клонировать существующий репозиторий, вам потребуется URL-адрес, указывающий на существующий репозиторий. Этот URL-адрес представляет источник репозитория, который вы собираетесь копировать.
если вы используете Azure Repos, Azure DevOps Server 2019 или Team Foundation Server, этот URL-адрес клона можно найти на веб-портале.
в веб-браузере откройте командный проект для Azure DevOps организации и выберите Repos, а затем — файлы.
Выберите клон в правом верхнем углу.
если необходимо клонировать репозиторий GitHub, необходимо получить URL-адрес клона. Используйте кнопку клонировать или скачать при просмотре репозитория в интернете в GitHub.
Другие поставщики Git имеют аналогичные кнопки в пользовательском интерфейсе для получения URL-адреса клона.
Скопируйте этот URL-адрес в буфер обмена или сохраните его в месте, где его можно легко найти. Нельзя клонировать репозиторий без URL-адреса клона.
Клонирование репозитория
Visual Studio 2019 версии 16,8 и более поздних версий предоставляют новое меню Git для управления рабочим процессом git с меньшим переключением контекста, чем Team Explorer. процедуры, описанные в этой статье на вкладке Visual Studio 2019, содержат сведения о работе с Git и Team Explorer. Дополнительные сведения см. в разделе параллельное сравнение Git и Team Explorer.
клонирование из Azure Repos и Azure DevOps Server
в Team Explorer откройте страницу Подключение , нажав кнопку Подключение . выберите управление подключениями , а затем Подключение для Project.
в Подключение Projectвыберите репозиторий, который нужно клонировать, в списке и выберите клонировать.
Если ваш репозиторий не отображается в списке, отфильтруйте его, чтобы найти. может потребоваться добавить Azure DevOps Server, где размещен репозиторий. щелкните ссылку добавить Azure DevOps Server .
Проверьте расположение клонированного репозитория на компьютере и выберите клонировать.
Клонировать из другого поставщика Git
если вы не используете Azure Repos, вы по-прежнему можете клонировать репозиторий в Team Explorer и работать с кодом в Visual Studio.
в Team Explorer откройте представление Подключение , как описано выше.
Выберите клон в разделе локальные репозитории Git и введите URL-адрес репозитория Git. Этот URL-адрес предоставляется вашей командой или поставщиком размещения Git.
Выберите папку, в которой вы хотите клонировать репозиторий.
Выберите клон , чтобы клонировать репозиторий.
открытие решения в Visual Studio из клонированного репозитория
щелкните правой кнопкой мыши репозиторий в представлении Team Explorer Подключение и выберите открыть.
В представлении " Главная " в Team Explorer дважды щелкните файл решения проекта в области " решения ". Решение откроется в Обозреватель решений.
Предварительные условия
- Убедитесь, что вы установили пакет командной строки Git для своей платформы. Прежде чем продолжить, убедитесь, что у вас есть Диспетчер учетных данных Git или настроена проверка подлинности SSH .
Вам потребуется URL-адрес клона, чтобы сообщить Git, какой репозиторий вы хотите клонировать на компьютер. Используйте URL-адрес, скопированный ранее на предыдущем шаге в этой статье.
Используйте этот URL-адрес клона git clone для создания локальной копии репозитория:
git clone Создает точную копию репозитория из URL-адреса в папке текущего. Можно указать имя папки после URL-адреса, чтобы создать репозиторий в определенном расположении, например:
Читайте также: