Git: различия между версиями

Материал из support.qbpro.ru
imported>Vix
Нет описания правки
imported>Vix
 
(не показаны 24 промежуточные версии этого же участника)
Строка 1: Строка 1:
==GOGS==
==GIT==
ОПИСАНИЕ:
'''* Команды git:'''
 
Создание нового репозитария:
 
touch README.md
git init
git add .
git commit -m "first commit"
git remote add origin http://gitserver.org/dev_user/testrep.git
git push -u origin dev_user
 
 
* Как обнулить историю Git?
<hr>
<hr>
'''Gogs''' — продукт китайских разработчиков. На первый взгляд он почти ничем не отличается от GitHub или BitBucket — это даже по дизайну заметно.
Но при всех внешних сходствах у него есть одно выгодное отличие от существующих аналогов: легковесность.


'''Gogs''' написан на Go (собственно, это название представляет собой сокращение от Go Git Service). Из этого факта вытекают серьёзные преимущества: низкие требования к системным ресурсам, минимум зависимостей, простота установки и настройки.
git reset --hard commitId #УДАЛЯЕТ ИСТОРИЮ GIT


В числе важнейших характеристик '''Gogs''' также следует назвать:
или


* поддержку протоколов '''HTTP(s) и SSH''';
* [https://ru.stackoverflow.com/questions/229431/%D0%9A%D0%B0%D0%BA-%D0%BE%D0%B1%D0%BD%D1%83%D0%BB%D0%B8%D1%82%D1%8C-%D0%B8%D1%81%D1%82%D0%BE%D1%80%D0%B8%D1%8E-git взято тут...]
* поддержку '''SMTP''' и '''LDAP''';
 
* возможность создания как приватных, так и публичных репозиториев;
Все эти инструкции верны, если на удаленном сервере у вас пусто, а локально - есть проект и репозиторий Git с историей, которую вы хотите удалить.
* интеграцию с социальными сетями (пока что поддерживаются '''GitHub, Google+''', а также китайские сервисы '''QQ и Weibo''');
Что будет потеряно безвозвратно
* возможность работы в связке с сервисами непрерывной интеграции и '''DevOps-сервисами'''
 
УСТАНОВКА и НАСТРОЙКА:
    Собственно, история. Вы точно хотите ее потерять? Ради нее весь Git и придумывался.
<hr>
    Весь код в не-слитых (unmerged) ветках.
* Представлено в виде скрипта для Debian:
    Весь код в orphaned ветках.
#!/bin/bash
 
  ## https://linode.com/docs/development/version-control/install-gogs-on-debian/
Быстрый способ
gogs_path="/home/git/gogs";
 
  git_path="/home/git";
Найдите первый коммит в ветке, запомните его sha1.
## подготовка
 
sudo apt update && sudo apt upgrade
  git log --oneline
sudo apt-get install -y git golang golang-1.8 golang-1.8-doc golang-1.8-go golang-1.8-src golang-any golang-doc golang-src
 
  sudo adduser --disabled-login --gecos 'Gogs' git
Переключитесь на тот коммит, который хотите сохранить в итоге.
mkdir -p $gogs_path
 
chown -R git:git $gogs_path
  git checkout master
cd $git_path;
 
sudo su - git
Теперь используем git reset --soft чтобы сделать из всей истории один коммит (подробнее - пункт 4.1: Как вернуться (откатиться) к более раннему коммиту? ).
# сборка
 
go get -u github.com/gogits/gogs;
git reset --soft <first-commit-sha1>
cd $git_path/go/src/github.com/gogits/gogs;
  git commit -m'слил историю в один коммит'
go build
 
cd
Долгий способ
ln -s go/src/github.com/gogits/gogs/ gogs
 
exit;
Сделайте бэкап локального репозитория. Можно запушить на резервный удаленный репозиторий, а можно просто взять и переместить папку .git в другое место.
  # установка на debian
 
cp -f $gogs_path/src/github.com/gogits/gogs/scripts/init/debian/gogs /etc/init.d/gogs
  mkdir ../git-backup
update-rc.d gogs defaults
  mv .git ../git-backup/.git
  chmod 0755 /etc/init.d/gogs
 
cp -f $gogs_path/src/github.com/gogits/gogs/scripts/systemd/gogs.service /lib/systemd/system/gogs.service
Если не переместили локально, а забэкапили куда-то еще: удаляем папку.
systemctl enable gogs.service
 
# правим конфиг под базу данных postgresql если надо или через localhost:3000
  rm -Rf .git
#editor go/src/github.com/gogits/gogs/conf/app.ini
 
# и копируем его в go/src/github.com/gogits/gogs/custom/conf/app.ini
Теперь заново инициализируем репозиторий:
  systemctl start gogs.service
 
##
  git init
## перенаправляем порт 3000 на 80
 
## section NAT
Добавляем все файлы в рабочей области и делаем коммит.
  iptables -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-port 3000
 
## сохряняем для восстановления при перезагрузке
  git add .
iptables-save > rule
  git commit -m'начал с нуля' 
##
 
* дальше необходимо создать базу данных (у меня используется Postgresql), краткий пример:
Когда все готово
  #sudo apt-get install -y postgresql postgresql-client libpq-dev
 
  #sudo -u postgres psql -d template1
Подключаем удаленный репозиторий и заливаем на него изменения:
#CREATE USER gogs CREATEDB;
#\password gogs
#
#CREATE DATABASE gogs OWNER gogs;
#\q
#
#
Все подробности по Postgresql смотрим [http://support.qbpro.ru/index.php?title=PostgreSQL тут]


git remote add origin <url>
git push -u origin --all


* Если возникает ошибка: "Peer's Certificate issuer is not recognized"
используйте параметр: git -c http.sslVerify=false clone ...
==[[GOGS]]==
<br>
==[[Git-Ifs]]==
<br>


==ПОЛЕЗНОЕ==
* [https://eax.me/git-commands/ Моя шпаргалка по работе с Git]
* [https://git-scm.com/book/ru/v2/%D0%9E%D1%81%D0%BD%D0%BE%D0%B2%D1%8B-Git-%D0%97%D0%B0%D0%BF%D0%B8%D1%81%D1%8C-%D0%B8%D0%B7%D0%BC%D0%B5%D0%BD%D0%B5%D0%BD%D0%B8%D0%B9-%D0%B2-%D1%80%D0%B5%D0%BF%D0%BE%D0%B7%D0%B8%D1%82%D0%BE%D1%80%D0%B8%D0%B9 Основы Git - Запись изменений в репозиторий]
* [https://ru.stackoverflow.com/questions/431520/%D0%9A%D0%B0%D0%BA-%D0%B2%D0%B5%D1%80%D0%BD%D1%83%D1%82%D1%8C%D1%81%D1%8F-%D0%BE%D1%82%D0%BA%D0%B0%D1%82%D0%B8%D1%82%D1%8C%D1%81%D1%8F-%D0%BA-%D0%B1%D0%BE%D0%BB%D0%B5%D0%B5-%D1%80%D0%B0%D0%BD%D0%BD%D0%B5%D0%BC%D1%83-%D0%BA%D0%BE%D0%BC%D0%BC%D0%B8%D1%82%D1%83 Как вернуться (откатиться) к более раннему коммиту?]
* [https://githowto.com/ru?gf_page=upload обучение Git]
* [https://habr.com/ru/post/342116/ Git на практике]
* [[Ошибка git "fatal: unable to access 'https://...': Peer's Certificate issuer is not recognized."]]
* [[ Push Error: RPC failed; result=22, HTTP code = 413]]


'''ИСТОЧНИКИ:'''
'''ИСТОЧНИКИ:'''

Текущая версия от 12:15, 4 августа 2022

GIT

* Команды git:

Создание нового репозитария:

touch README.md
git init
git add .
git commit -m "first commit"
git remote add origin http://gitserver.org/dev_user/testrep.git
git push -u origin dev_user


  • Как обнулить историю Git?

git reset --hard commitId #УДАЛЯЕТ ИСТОРИЮ GIT

или

Все эти инструкции верны, если на удаленном сервере у вас пусто, а локально - есть проект и репозиторий Git с историей, которую вы хотите удалить. Что будет потеряно безвозвратно

   Собственно, история. Вы точно хотите ее потерять? Ради нее весь Git и придумывался.
   Весь код в не-слитых (unmerged) ветках.
   Весь код в orphaned ветках.

Быстрый способ

Найдите первый коммит в ветке, запомните его sha1.

git log --oneline

Переключитесь на тот коммит, который хотите сохранить в итоге.

git checkout master

Теперь используем git reset --soft чтобы сделать из всей истории один коммит (подробнее - пункт 4.1: Как вернуться (откатиться) к более раннему коммиту? ).

git reset --soft <first-commit-sha1>
git commit -m'слил историю в один коммит'

Долгий способ

Сделайте бэкап локального репозитория. Можно запушить на резервный удаленный репозиторий, а можно просто взять и переместить папку .git в другое место.

mkdir ../git-backup
mv .git ../git-backup/.git

Если не переместили локально, а забэкапили куда-то еще: удаляем папку.

rm -Rf .git

Теперь заново инициализируем репозиторий:

git init

Добавляем все файлы в рабочей области и делаем коммит.

git add .
git commit -m'начал с нуля'   

Когда все готово

Подключаем удаленный репозиторий и заливаем на него изменения:

git remote add origin <url>
git push -u origin --all
  • Если возникает ошибка: "Peer's Certificate issuer is not recognized"

используйте параметр: git -c http.sslVerify=false clone ...

GOGS


Git-Ifs


ПОЛЕЗНОЕ

ИСТОЧНИКИ: