Установка и настройка Git сервера — различия между версиями

Материал из ARK-HOSTER.RU | Документация хостинга
Перейти к: навигация, поиск
Строка 38: Строка 38:
  
 
3. Создайте директорию для репозиториев:
 
3. Создайте директорию для репозиториев:
<code>sudo mkdir -p /home/git/repositories
+
<code>sudo mkdir -p /home/git/repositories</code>
sudo chown git:git /home/git/repositories
+
<code>sudo chown git:git /home/git/repositories</code>
sudo chmod 755 /home/git/repositories</code>
+
<code>sudo chmod 755 /home/git/repositories</code>
  
 
=== Настройка SSH ключей ===
 
=== Настройка SSH ключей ===
Строка 48: Строка 48:
  
 
2. Создайте директорию для SSH ключей:
 
2. Создайте директорию для SSH ключей:
<code>mkdir -p ~/.ssh
+
<code>mkdir -p ~/.ssh</code>
chmod 700 ~/.ssh</code>
+
<code>chmod 700 ~/.ssh</code>
  
 
3. Создайте файл authorized_keys:
 
3. Создайте файл authorized_keys:
<code>touch ~/.ssh/authorized_keys
+
<code>touch ~/.ssh/authorized_keys</code>
chmod 600 ~/.ssh/authorized_keys</code>
+
<code>chmod 600 ~/.ssh/authorized_keys</code>
  
 
== 4. Создание репозиториев ===
 
== 4. Создание репозиториев ===
Строка 60: Строка 60:
  
 
1. Создайте голый репозиторий:
 
1. Создайте голый репозиторий:
<code>cd /home/git/repositories
+
<code>cd /home/git/repositories</code>
git init --bare my-project.git</code>
+
<code>git init --bare my-project.git</code>
  
 
2. Установите права доступа:
 
2. Установите права доступа:
<code>sudo chown -R git:git my-project.git
+
<code>sudo chown -R git:git my-project.git</code>
sudo chmod -R 755 my-project.git</code>
+
<code>sudo chmod -R 755 my-project.git</code>
  
 
=== Создание репозитория с GitWeb ===
 
=== Создание репозитория с GitWeb ===
  
 
1. Создайте репозиторий для GitWeb:
 
1. Создайте репозиторий для GitWeb:
<code>cd /home/git/repositories
+
<code>cd /home/git/repositories</code>
git init --bare --shared=group my-project-web.git</code>
+
<code>git init --bare --shared=group my-project-web.git</code>
  
 
2. Настройте описание репозитория:
 
2. Настройте описание репозитория:
Строка 132: Строка 132:
  
 
3. Включите сайт:
 
3. Включите сайт:
<code>sudo a2ensite gitweb
+
<code>sudo a2ensite gitweb</code>
sudo systemctl restart apache2</code>
+
<code>sudo systemctl restart apache2</code>
  
 
== 6. Настройка Git Daemon ===
 
== 6. Настройка Git Daemon ===
Строка 143: Строка 143:
  
 
2. Настройте параметры:
 
2. Настройте параметры:
<code>GIT_DAEMON_ENABLE=1
+
<code>GIT_DAEMON_ENABLE=1</code>
GIT_DAEMON_USER=git
+
<code>GIT_DAEMON_USER=git</code>
GIT_DAEMON_BASE_PATH=/home/git/repositories
+
<code>GIT_DAEMON_BASE_PATH=/home/git/repositories</code>
GIT_DAEMON_OPTIONS="--export-all --reuseaddr --verbose --base-path=/home/git/repositories"</code>
+
<code>GIT_DAEMON_OPTIONS="--export-all --reuseaddr --verbose --base-path=/home/git/repositories"</code>
  
 
3. Запустите Git Daemon:
 
3. Запустите Git Daemon:
<code>sudo systemctl start git-daemon
+
<code>sudo systemctl start git-daemon</code>
sudo systemctl enable git-daemon</code>
+
<code>sudo systemctl enable git-daemon</code>
  
 
=== Настройка репозиториев для Git Daemon ===
 
=== Настройка репозиториев для Git Daemon ===
Строка 168: Строка 168:
  
 
2. Добавьте настройки для Git:
 
2. Добавьте настройки для Git:
<code># Настройки для Git
+
<code>Match User git</code>
Match User git
+
<code>AllowUsers git</code>
    AllowUsers git
+
<code>ForceCommand git-shell</code>
    ForceCommand git-shell
+
<code>X11Forwarding no</code>
    X11Forwarding no
+
<code>AllowTcpForwarding no</code>
    AllowTcpForwarding no</code>
 
  
 
3. Перезапустите SSH:
 
3. Перезапустите SSH:
Строка 181: Строка 180:
  
 
1. Создайте директорию для Git Shell:
 
1. Создайте директорию для Git Shell:
<code>sudo mkdir -p /home/git/git-shell-commands
+
<code>sudo mkdir -p /home/git/git-shell-commands</code>
sudo chown git:git /home/git/git-shell-commands</code>
+
<code>sudo chown git:git /home/git/git-shell-commands</code>
  
 
2. Создайте скрипт для отображения репозиториев:
 
2. Создайте скрипт для отображения репозиториев:
Строка 188: Строка 187:
  
 
3. Добавьте содержимое:
 
3. Добавьте содержимое:
<code>#!/bin/bash
+
<code>echo "Available repositories:"</code>
echo "Available repositories:"
+
<code>ls -la /home/git/repositories/</code>
ls -la /home/git/repositories/</code>
 
  
 
4. Сделайте скрипт исполняемым:
 
4. Сделайте скрипт исполняемым:
<code>sudo chmod +x /home/git/git-shell-commands/list-repos
+
<code>sudo chmod +x /home/git/git-shell-commands/list-repos</code>
sudo chown git:git /home/git/git-shell-commands/list-repos</code>
+
<code>sudo chown git:git /home/git/git-shell-commands/list-repos</code>
  
 
== 8. Настройка файрвола ===
 
== 8. Настройка файрвола ===
Строка 215: Строка 213:
  
 
1. Разрешите необходимые порты:
 
1. Разрешите необходимые порты:
<code>sudo iptables -A INPUT -p tcp --dport 22 -j ACCEPT
+
<code>sudo iptables -A INPUT -p tcp --dport 22 -j ACCEPT</code>
sudo iptables -A INPUT -p tcp --dport 80 -j ACCEPT
+
<code>sudo iptables -A INPUT -p tcp --dport 80 -j ACCEPT</code>
sudo iptables -A INPUT -p tcp --dport 9418 -j ACCEPT</code>
+
<code>sudo iptables -A INPUT -p tcp --dport 9418 -j ACCEPT</code>
  
 
2. Сохраните правила:
 
2. Сохраните правила:
Строка 227: Строка 225:
  
 
1. Создайте новый репозиторий:
 
1. Создайте новый репозиторий:
<code>cd /home/git/repositories
+
<code>cd /home/git/repositories</code>
sudo -u git git init --bare new-project.git</code>
+
<code>sudo -u git git init --bare new-project.git</code>
  
 
2. Установите права доступа:
 
2. Установите права доступа:
<code>sudo chown -R git:git new-project.git
+
<code>sudo chown -R git:git new-project.git</code>
sudo chmod -R 755 new-project.git</code>
+
<code>sudo chmod -R 755 new-project.git</code>
  
 
3. Настройте описание:
 
3. Настройте описание:
Строка 264: Строка 262:
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>#!/bin/bash
+
<code>echo "$(date): $SSH_ORIGINAL_COMMAND" >> /home/git/git-activity.log</code>
echo "$(date): $SSH_ORIGINAL_COMMAND" >> /home/git/git-activity.log</code>
 
  
 
3. Сделайте скрипт исполняемым:
 
3. Сделайте скрипт исполняемым:
<code>sudo chmod +x /home/git/git-shell-commands/log-activity
+
<code>sudo chmod +x /home/git/git-shell-commands/log-activity</code>
sudo chown git:git /home/git/git-shell-commands/log-activity</code>
+
<code>sudo chown git:git /home/git/git-shell-commands/log-activity</code>
  
 
=== Просмотр логов ===
 
=== Просмотр логов ===
Строка 288: Строка 285:
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>#!/bin/bash
+
<code>if systemctl is-active --quiet ssh; then</code>
 
+
<code>echo "SSH is running"</code>
# Проверка статуса Git сервисов
+
<code>else</code>
if systemctl is-active --quiet ssh; then
+
<code>echo "SSH is not running"</code>
    echo "SSH is running"
+
<code>fi</code>
else
+
<code>if systemctl is-active --quiet git-daemon; then</code>
    echo "SSH is not running"
+
<code>echo "Git Daemon is running"</code>
fi
+
<code>else</code>
 
+
<code>echo "Git Daemon is not running"</code>
if systemctl is-active --quiet git-daemon; then
+
<code>fi</code>
    echo "Git Daemon is running"
+
<code>if systemctl is-active --quiet apache2; then</code>
else
+
<code>echo "Apache is running"</code>
    echo "Git Daemon is not running"
+
<code>else</code>
fi
+
<code>echo "Apache is not running"</code>
 
+
<code>fi</code>
if systemctl is-active --quiet apache2; then
+
<code>REPO_COUNT=$(ls -1 /home/git/repositories/ | wc -l)</code>
    echo "Apache is running"
+
<code>echo "Number of repositories: $REPO_COUNT"</code>
else
+
<code>DISK_USAGE=$(du -sh /home/git/repositories/ | cut -f1)</code>
    echo "Apache is not running"
+
<code>echo "Repository disk usage: $DISK_USAGE"</code>
fi
 
 
 
# Проверка репозиториев
 
REPO_COUNT=$(ls -1 /home/git/repositories/ | wc -l)
 
echo "Number of repositories: $REPO_COUNT"
 
 
 
# Проверка использования диска
 
DISK_USAGE=$(du -sh /home/git/repositories/ | cut -f1)
 
echo "Repository disk usage: $DISK_USAGE"</code>
 
  
 
3. Сделайте скрипт исполняемым:
 
3. Сделайте скрипт исполняемым:
Строка 342: Строка 330:
  
 
1. Проверьте статус служб:
 
1. Проверьте статус служб:
<code>sudo systemctl status ssh
+
<code>sudo systemctl status ssh</code>
sudo systemctl status git-daemon
+
<code>sudo systemctl status git-daemon</code>
sudo systemctl status apache2</code>
+
<code>sudo systemctl status apache2</code>
  
 
2. Проверьте подключения:
 
2. Проверьте подключения:
Строка 353: Строка 341:
  
 
4. Проверьте права доступа:
 
4. Проверьте права доступа:
<code>ls -la /home/git/
+
<code>ls -la /home/git/</code>
ls -la /home/git/repositories/</code>
+
<code>ls -la /home/git/repositories/</code>
  
 
== 12. Дополнительные настройки ===
 
== 12. Дополнительные настройки ===
Строка 364: Строка 352:
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>#!/bin/bash
+
<code>echo "Repository updated: $(date)" | mail -s "Git Update" admin@example.com</code>
echo "Repository updated: $(date)" | mail -s "Git Update" admin@example.com</code>
 
  
 
3. Сделайте хук исполняемым:
 
3. Сделайте хук исполняемым:
<code>sudo chmod +x /home/git/repositories/my-project.git/hooks/post-receive
+
<code>sudo chmod +x /home/git/repositories/my-project.git/hooks/post-receive</code>
sudo chown git:git /home/git/repositories/my-project.git/hooks/post-receive</code>
+
<code>sudo chown git:git /home/git/repositories/my-project.git/hooks/post-receive</code>
  
 
=== Настройка резервного копирования ===
 
=== Настройка резервного копирования ===
Строка 377: Строка 364:
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>#!/bin/bash
+
<code>BACKUP_DIR="/backup/git"</code>
 
+
<code>REPO_DIR="/home/git/repositories"</code>
BACKUP_DIR="/backup/git"
+
<code>DATE=$(date +%Y%m%d_%H%M%S)</code>
REPO_DIR="/home/git/repositories"
+
<code>mkdir -p $BACKUP_DIR</code>
DATE=$(date +%Y%m%d_%H%M%S)
+
<code>tar -czf $BACKUP_DIR/git_repos_$DATE.tar.gz -C $REPO_DIR .</code>
 
+
<code>find $BACKUP_DIR -name "git_repos_*.tar.gz" -mtime +7 -delete</code>
# Создание директории для бэкапа
+
<code>echo "Git backup completed: git_repos_$DATE.tar.gz"</code>
mkdir -p $BACKUP_DIR
 
 
 
# Резервное копирование репозиториев
 
tar -czf $BACKUP_DIR/git_repos_$DATE.tar.gz -C $REPO_DIR .
 
 
 
# Удаление старых бэкапов (старше 7 дней)
 
find $BACKUP_DIR -name "git_repos_*.tar.gz" -mtime +7 -delete
 
 
 
echo "Git backup completed: git_repos_$DATE.tar.gz"</code>
 
  
 
3. Сделайте скрипт исполняемым:
 
3. Сделайте скрипт исполняемым:
Строка 398: Строка 376:
  
 
4. Добавьте в crontab:
 
4. Добавьте в crontab:
<code># Ежедневный бэкап в 2:00
+
<code>0 2 * * * /usr/local/bin/git-backup.sh</code>
0 2 * * * /usr/local/bin/git-backup.sh</code>
 
  
 
== Заключение ==
 
== Заключение ==

Версия 19:57, 14 октября 2025

Содержание

Установка и настройка Git сервера

1. Подготовка системы

  • Войдите в систему под учетной записью с правами root или пользователя с правами sudo.
  • Убедитесь, что у вас есть доступ к серверу через SSH или консоль.

2. Установка Git =

Установка пакета

1. Обновите список пакетов: sudo apt update

2. Установите Git: sudo apt install git

3. Установите дополнительные компоненты: sudo apt install git-core gitweb git-daemon-run

Проверка установки

1. Проверьте версию Git: git --version

2. Проверьте конфигурацию: git config --list

3. Настройка Git сервера =

Создание пользователя для Git

1. Создайте пользователя для Git: sudo useradd -m -s /bin/bash git

2. Установите пароль: sudo passwd git

3. Создайте директорию для репозиториев: sudo mkdir -p /home/git/repositories sudo chown git:git /home/git/repositories sudo chmod 755 /home/git/repositories

Настройка SSH ключей

1. Переключитесь на пользователя git: sudo su - git

2. Создайте директорию для SSH ключей: mkdir -p ~/.ssh chmod 700 ~/.ssh

3. Создайте файл authorized_keys: touch ~/.ssh/authorized_keys chmod 600 ~/.ssh/authorized_keys

4. Создание репозиториев =

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

1. Создайте голый репозиторий: cd /home/git/repositories git init --bare my-project.git

2. Установите права доступа: sudo chown -R git:git my-project.git sudo chmod -R 755 my-project.git

Создание репозитория с GitWeb

1. Создайте репозиторий для GitWeb: cd /home/git/repositories git init --bare --shared=group my-project-web.git

2. Настройте описание репозитория: echo "My Project Repository" > my-project-web.git/description

3. Включите GitWeb: echo "gitweb" > my-project-web.git/gitweb

5. Настройка GitWeb =

Установка и настройка GitWeb

1. Установите GitWeb: sudo apt install gitweb

2. Отредактируйте конфигурацию GitWeb: sudo nano /etc/gitweb.conf

3. Настройте основные параметры: # Основные настройки $projectroot = "/home/git/repositories"; $git_temp = "/tmp"; $projects_list = $projectroot;

  1. Настройки отображения

$site_name = "Git Server"; $site_html_head_string = "<link rel='stylesheet' type='text/css' href='/gitweb.css'/>"; $site_header = "/gitweb-header.html"; $site_footer = "/gitweb-footer.html";

  1. Настройки безопасности

$export_ok = "git-daemon-export-ok"; $strict_export = 1;

Настройка веб-сервера для GitWeb

1. Создайте конфигурацию для Apache: sudo nano /etc/apache2/sites-available/gitweb.conf

2. Добавьте конфигурацию: <VirtualHost *:80>

   ServerName git.example.com
   DocumentRoot /usr/share/gitweb
   
   Alias /gitweb /usr/share/gitweb
   <Directory /usr/share/gitweb>
       Options +ExecCGI
       AddHandler cgi-script .cgi
       DirectoryIndex gitweb.cgi
       Require all granted
   </Directory>
   
   ScriptAlias /gitweb.cgi /usr/share/gitweb/gitweb.cgi
   <Directory /usr/share/gitweb>
       Options +ExecCGI
       AddHandler cgi-script .cgi
       Require all granted
   </Directory>

</VirtualHost>

3. Включите сайт: sudo a2ensite gitweb sudo systemctl restart apache2

6. Настройка Git Daemon =

Настройка Git Daemon

1. Отредактируйте конфигурацию Git Daemon: sudo nano /etc/default/git-daemon

2. Настройте параметры: GIT_DAEMON_ENABLE=1 GIT_DAEMON_USER=git GIT_DAEMON_BASE_PATH=/home/git/repositories GIT_DAEMON_OPTIONS="--export-all --reuseaddr --verbose --base-path=/home/git/repositories"

3. Запустите Git Daemon: sudo systemctl start git-daemon sudo systemctl enable git-daemon

Настройка репозиториев для Git Daemon

1. Создайте файл для экспорта репозитория: touch /home/git/repositories/my-project.git/git-daemon-export-ok

2. Установите права доступа: sudo chown git:git /home/git/repositories/my-project.git/git-daemon-export-ok

7. Настройка SSH доступа =

Настройка SSH для Git

1. Отредактируйте SSH конфигурацию: sudo nano /etc/ssh/sshd_config

2. Добавьте настройки для Git: Match User git AllowUsers git ForceCommand git-shell X11Forwarding no AllowTcpForwarding no

3. Перезапустите SSH: sudo systemctl restart ssh

Настройка Git Shell

1. Создайте директорию для Git Shell: sudo mkdir -p /home/git/git-shell-commands sudo chown git:git /home/git/git-shell-commands

2. Создайте скрипт для отображения репозиториев: sudo nano /home/git/git-shell-commands/list-repos

3. Добавьте содержимое: echo "Available repositories:" ls -la /home/git/repositories/

4. Сделайте скрипт исполняемым: sudo chmod +x /home/git/git-shell-commands/list-repos sudo chown git:git /home/git/git-shell-commands/list-repos

8. Настройка файрвола =

Настройка UFW

1. Разрешите SSH трафик: sudo ufw allow ssh

2. Разрешите HTTP трафик для GitWeb: sudo ufw allow 80/tcp

3. Разрешите Git Daemon порт: sudo ufw allow 9418/tcp

4. Проверьте статус: sudo ufw status

Настройка iptables

1. Разрешите необходимые порты: sudo iptables -A INPUT -p tcp --dport 22 -j ACCEPT sudo iptables -A INPUT -p tcp --dport 80 -j ACCEPT sudo iptables -A INPUT -p tcp --dport 9418 -j ACCEPT

2. Сохраните правила: sudo iptables-save > /etc/iptables/rules.v4

9. Управление репозиториями =

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

1. Создайте новый репозиторий: cd /home/git/repositories sudo -u git git init --bare new-project.git

2. Установите права доступа: sudo chown -R git:git new-project.git sudo chmod -R 755 new-project.git

3. Настройте описание: echo "New Project Repository" | sudo tee new-project.git/description

Управление доступом

1. Добавьте SSH ключ пользователя: sudo -u git bash -c "echo 'ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC...' >> /home/git/.ssh/authorized_keys"

2. Удалите SSH ключ: sudo -u git bash -c "sed -i '/ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC.../d' /home/git/.ssh/authorized_keys"

Управление репозиториями

1. Просмотрите список репозиториев: ls -la /home/git/repositories/

2. Удалите репозиторий: sudo rm -rf /home/git/repositories/old-project.git

3. Переименуйте репозиторий: sudo mv /home/git/repositories/old-name.git /home/git/repositories/new-name.git

10. Мониторинг и логирование =

Настройка логирования

1. Создайте скрипт логирования Git операций: sudo nano /home/git/git-shell-commands/log-activity

2. Добавьте содержимое: echo "$(date): $SSH_ORIGINAL_COMMAND" >> /home/git/git-activity.log

3. Сделайте скрипт исполняемым: sudo chmod +x /home/git/git-shell-commands/log-activity sudo chown git:git /home/git/git-shell-commands/log-activity

Просмотр логов

1. Просмотрите логи SSH: sudo tail -f /var/log/auth.log | grep git

2. Просмотрите логи Git активности: sudo tail -f /home/git/git-activity.log

3. Просмотрите логи Apache для GitWeb: sudo tail -f /var/log/apache2/access.log | grep gitweb

Создание скрипта мониторинга

1. Создайте скрипт мониторинга: sudo nano /usr/local/bin/git-monitor.sh

2. Добавьте содержимое: if systemctl is-active --quiet ssh; then echo "SSH is running" else echo "SSH is not running" fi if systemctl is-active --quiet git-daemon; then echo "Git Daemon is running" else echo "Git Daemon is not running" fi if systemctl is-active --quiet apache2; then echo "Apache is running" else echo "Apache is not running" fi REPO_COUNT=$(ls -1 /home/git/repositories/ | wc -l) echo "Number of repositories: $REPO_COUNT" DISK_USAGE=$(du -sh /home/git/repositories/ | cut -f1) echo "Repository disk usage: $DISK_USAGE"

3. Сделайте скрипт исполняемым: sudo chmod +x /usr/local/bin/git-monitor.sh

11. Устранение неполадок =

Частые проблемы

1. Не могу клонировать репозиторий:

  • Проверьте SSH ключи: ssh -T git@server
  • Проверьте права доступа: ls -la /home/git/repositories/
  • Проверьте SSH конфигурацию

2. GitWeb не работает:

  • Проверьте Apache: sudo systemctl status apache2
  • Проверьте конфигурацию GitWeb: sudo nano /etc/gitweb.conf
  • Проверьте права доступа к репозиториям

3. Git Daemon не работает:

  • Проверьте статус: sudo systemctl status git-daemon
  • Проверьте конфигурацию: sudo nano /etc/default/git-daemon
  • Проверьте файрвол: sudo ufw status

Диагностика

1. Проверьте статус служб: sudo systemctl status ssh sudo systemctl status git-daemon sudo systemctl status apache2

2. Проверьте подключения: sudo netstat -tlnp | grep -E ':(22|80|9418)'

3. Проверьте SSH подключение: ssh -T git@localhost

4. Проверьте права доступа: ls -la /home/git/ ls -la /home/git/repositories/

12. Дополнительные настройки =

Настройка хуков

1. Создайте хук для уведомлений: sudo nano /home/git/repositories/my-project.git/hooks/post-receive

2. Добавьте содержимое: echo "Repository updated: $(date)" | mail -s "Git Update" admin@example.com

3. Сделайте хук исполняемым: sudo chmod +x /home/git/repositories/my-project.git/hooks/post-receive sudo chown git:git /home/git/repositories/my-project.git/hooks/post-receive

Настройка резервного копирования

1. Создайте скрипт резервного копирования: sudo nano /usr/local/bin/git-backup.sh

2. Добавьте содержимое: BACKUP_DIR="/backup/git" REPO_DIR="/home/git/repositories" DATE=$(date +%Y%m%d_%H%M%S) mkdir -p $BACKUP_DIR tar -czf $BACKUP_DIR/git_repos_$DATE.tar.gz -C $REPO_DIR . find $BACKUP_DIR -name "git_repos_*.tar.gz" -mtime +7 -delete echo "Git backup completed: git_repos_$DATE.tar.gz"

3. Сделайте скрипт исполняемым: sudo chmod +x /usr/local/bin/git-backup.sh

4. Добавьте в crontab: 0 2 * * * /usr/local/bin/git-backup.sh

Заключение

Git сервер успешно установлен и настроен! Теперь вы можете предоставлять услуги управления версиями.

Для размещения ваших Git серверов на надежном хостинге рекомендуем воспользоваться услугами [ARK-HOSTER.RU](https://ark-hoster.ru):

Наши специалисты помогут с настройкой Git сервера и обеспечением безопасности ваших репозиториев!