Як встановити GitLab Community Edition (CE) 11.x на Debian 9

Оскільки GitHub був придбаний Microsoft, чимало розробників планували перенести свої власні сховища коду з github.com на альтернативне рішення для самостійного розміщення. GitLab Community Edition (CE) є найпоширенішим вибором.

Як складне та гнучке рішення, GitLab CE можна розгорнути за допомогою різних методів, але тут буде розглянуто лише офіційно рекомендований метод, установка пакету Omnibus.

Передумови

  • Свіжий екземпляр сервера Vultr Debian 9 x64 з принаймні 4 Гб пам’яті. Рекомендується 8 ГБ або більше для обслуговування до 100 користувачів. Скажімо, його адреса IPv4: 203.0.113.1.
  • Користувач sudo .
  • Домен, gitlab.example.comщо вказується на згаданий вище екземпляр.

Примітка: під час розгортання на власному екземплярі сервера обов’язково замініть усі прикладні значення на фактичні.

Крок 1: Виконайте основні завдання для розміщення GitLab CE

Запустіть термінал SSH та увійдіть у свій екземпляр сервера Debian 9 x64 як користувач sudo.

Додайте розділ підкачки та налаштуйте параметр підкачки

Під час розгортання GitLab CE 11.x на машині з 4 ГБ пам’яті потрібно налаштувати розділ підкачки 4 ГБ для безперебійної роботи.

sudo dd if=/dev/zero of=/swapfile count=4096 bs=1M
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile
echo '/swapfile   none    swap    sw    0   0' | sudo tee -a /etc/fstab
free -m

Примітка. Якщо ви використовуєте інший розмір сервера, розмір розділу підкачки може відрізнятися.

Для цілей продуктивності системи рекомендується налаштувати параметр підкачки ядра на низьке значення, наприклад 10:

echo 'vm.swappiness=10' | sudo tee -a /etc/sysctl.conf
sudo sysctl -p
cat /proc/sys/vm/swappiness

Результатом catкоманди буде 10.

Налаштуйте ім’я хоста комп’ютера та повне доменне ім’я (FQDN)

Використовуйте такі команди, щоб налаштувати ім’я хоста gitlab, і FQDN gitlab.example.com, для машини:

sudo hostnamectl set-hostname gitlab
sudo sed -i "1 i\203.0.113.1 gitlab.example.com gitlab" /etc/hosts

Ви можете підтвердити результати:

hostname
hostname -f

Налаштувати правила брандмауера

Налаштуйте розумні правила брандмауера для роботи веб-сайту:

sudo iptables -F
sudo iptables -X
sudo iptables -Z
sudo iptables -A INPUT -s $(echo $(w -h ${USER}) | cut -d " " -f3) -p tcp --dport 22 -j ACCEPT
sudo iptables -A INPUT -i lo -j ACCEPT
sudo iptables -A INPUT -d 127.0.0.0/8 -j REJECT
sudo iptables -A INPUT -p tcp ! --syn -m state --state NEW -j DROP
sudo iptables -A INPUT -p tcp --tcp-flags ALL NONE -j DROP
sudo iptables -A INPUT -p tcp --tcp-flags ALL ALL -j DROP
sudo iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
sudo iptables -A INPUT -p tcp --dport 80 -j ACCEPT
sudo iptables -A INPUT -p tcp --dport 443 -j ACCEPT
sudo iptables -A INPUT -p tcp --dport 22 -j ACCEPT
sudo iptables -A INPUT -p icmp --icmp-type echo-request -j ACCEPT
sudo iptables -P INPUT DROP
sudo iptables -P OUTPUT ACCEPT
sudo iptables -P FORWARD DROP

Усі вищенаведені налаштування набудуть чинності негайно. Використовуйте таку команду, щоб перерахувати їх для перегляду:

sudo iptables -L -n

Використовуйте iptable-persistentінструмент, щоб зберегти всі існуючі правила iptables у файлі /etc/iptables/rules.v4, зробивши всі правила iptables постійними:

sudo apt install -y iptables-persistent

Під час встановлення вас запитають, чи хочете ви зберегти поточні правила IPv4/IPv6. Натисніть ENTERдвічі, щоб зберегти поточні правила IPv4 та IPv6 у /etc/iptables/rules.v4та /etc/iptables/rules.v6.

Якщо ви спробуєте оновити правила IPv4 пізніше, використовуйте наступне, щоб зберегти оновлення:

sudo bash -c 'iptables-save > /etc/iptables/rules.v4'

Оновіть систему

sudo apt update
sudo apt upgrade -y && sudo shutdown -r now

Коли система знову запрацює, увійдіть як той самий користувач sudo, щоб продовжити.

Крок 2: Встановіть необхідні залежності

Перед встановленням GitLab CE вам потрібно встановити необхідні залежності:

sudo apt install -y curl openssh-server ca-certificates

Крім того, якщо ви хочете використовувати Postfix для надсилання сповіщень, вам потрібно встановити Postfix:

sudo apt install -y postfix

Під час встановлення може з'явитися екран конфігурації:

  1. Натисніть, TABщоб виділити <OK>кнопку на першому екрані, а потім натисніть ENTER.
  2. Виберіть Internet Siteі натисніть ENTER.
  3. Для цього mail nameполя введіть FQDN вашого сервера gitlab.example.com, і натисніть ENTER.
  4. Якщо з’являться інші екрани, натисніть, ENTERщоб прийняти налаштування за замовчуванням.

Запустіть і ввімкніть службу Postfix:

sudo systemctl enable postfix.service
sudo systemctl start postfix.service

Змініть правила брандмауера для Postfix:

sudo iptables -A INPUT -i eth0 -p tcp --dport 25 -m state --state NEW,ESTABLISHED -j ACCEPT
sudo iptables -A INPUT -i eth0 -p tcp --dport 143 -m state --state NEW,ESTABLISHED -j ACCEPT
sudo iptables -A INPUT -i eth0 -p tcp --dport 993 -m state --state NEW,ESTABLISHED -j ACCEPT
sudo iptables -A INPUT -i eth0 -p tcp --dport 110 -m state --state NEW,ESTABLISHED -j ACCEPT
sudo iptables -A INPUT -i eth0 -p tcp --dport 995 -m state --state NEW,ESTABLISHED -j ACCEPT
sudo bash -c 'iptables-save > /etc/iptables/rules.v4'

Після встановлення Postfix вам необхідно налаштувати Postfix, відредагувавши його основний конфігураційний файл /etc/postfix/main.cfвідповідно до фактичних налаштувань сервера.

Примітка. На додаток до наведених вище інструкцій вам потрібно надіслати заявку в службу підтримки, щоб скасувати блокування Vultr за замовчуванням на порту SMTP 25.

Крім того, якщо ви хочете використовувати інше рішення для обміну повідомленнями, просто пропустіть встановлення Postfix і виберіть використання зовнішнього SMTP-сервера після встановлення GitLab CE.

Крок 3: Налаштуйте репозиторію GitLab APT, а потім встановіть GitLab CE

Налаштуйте репозиторій GitLab CE APT у вашій системі:

cd
curl -sS https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.deb.sh | sudo bash

Далі встановіть GitLab CE 11.x:

sudo EXTERNAL_URL="http://gitlab.example.com" apt install -y gitlab-ce

Установка може зайняти деякий час.

Нарешті, наведіть свій улюблений веб-браузер на http://gitlab.example.com, а потім надішліть новий пароль, коли буде запропоновано завершити встановлення.

Відтепер використовуйте облікові дані нижче, щоб увійти як адміністратор:

  • Ім'я користувача: root
  • Пароль: <your-new-password>

Крок 4. Увімкніть доступ HTTPS, інтегрувавши сертифікат Let's Encrypt SSL

На даний момент ви успішно встановили GitLab CE 11.x на вашому сервері, і користувачі вже можуть відвідувати сайт за допомо��ою протоколу HTTP. З міркувань безпеки рекомендується увімкнути доступ HTTPS до вашого сервера GitLab, інтегрувавши сертифікат Let's Encrypt SSL.

Використовуйте viредактор, щоб відкрити файл конфігурації GitLab CE:

sudo vi /etc/gitlab/gitlab.rb

Знайдіть такі два рядки:

external_url 'http://gitlab.example.com'
# letsencrypt['contact_emails'] = [] # This should be an array of email addresses to add as contacts

Замініть їх відповідно:

external_url 'https://gitlab.example.com'
letsencrypt['contact_emails'] = ['[email protected]']

Збережіть і вийдіть:

:wq!

Переналаштуйте GitLab CE за допомогою оновлених параметрів:

sudo gitlab-ctl reconfigure

Повторна конфігурація може зайняти деякий час.

Після завершення реконфігурації всі користувачі будуть змушені використовувати протокол HTTPS під час доступу до сайту GitLab.

Примітка. Після переходу з HTTP на HTTPS застарілі файли cookie можуть викликати помилку GitLab 422. Очищення файлів cookie вирішує цю проблему.


Як налаштувати автоматичне оновлення на Debian 9 (розтягнути)

Як налаштувати автоматичне оновлення на Debian 9 (розтягнути)

Використання іншої системи? Якщо ви купуєте сервер Debian, ви завжди повинні мати останні виправлення та оновлення безпеки, спите ви чи ні

Налаштуйте власний DNS-сервер на Debian/Ubuntu

Налаштуйте власний DNS-сервер на Debian/Ubuntu

У цьому посібнику пояснюється, як налаштувати DNS-сервер за допомогою Bind9 на Debian або Ubuntu. Протягом усієї статті замініть your-domain-name.com відповідно. На го

Скомпілюйте та встановіть Nginx за допомогою модуля PageSpeed ​​на Debian 8

Скомпілюйте та встановіть Nginx за допомогою модуля PageSpeed ​​на Debian 8

У цій статті ми побачимо, як зібрати та встановити Nginx mainline з офіційних джерел Nginx за допомогою модуля PageSpeed, який дозволяє вам

Як встановити Kanboard на Debian 9

Як встановити Kanboard на Debian 9

Використання іншої системи? Вступ Kanboard — це безкоштовна програма з відкритим вихідним кодом для управління проектами, яка призначена для полегшення та візуалізації

Як встановити Gitea на Debian 9

Як встановити Gitea на Debian 9

Використання іншої системи? Gitea — це альтернативна система контролю версій із відкритим вихідним кодом на базі Git. Gitea написана на Голанг і є

Встановіть Lynis на Debian 8

Встановіть Lynis на Debian 8

Вступ Lynis — це безкоштовний інструмент аудиту системи з відкритим вихідним кодом, який використовується багатьма системними адміністраторами для перевірки цілісності та зміцнення своїх систем. я

Як встановити Thelia 2.3 на Debian 9

Як встановити Thelia 2.3 на Debian 9

Використання іншої системи? Thelia — інструмент із відкритим кодом для створення веб-сайтів електронного бізнесу та керування онлайн-контентом, написаним на PHP. Вихідний код Thelia i

Створення мережі серверів Minecraft за допомогою BungeeCord на Debian 8, Debian 9 або CentOS 7

Створення мережі серверів Minecraft за допомогою BungeeCord на Debian 8, Debian 9 або CentOS 7

Що вам знадобиться Vultr VPS з принаймні 1 Гб оперативної пам’яті. Доступ по SSH (з правами root/адміністратора). Крок 1: Встановлення BungeeCord Перш за все

Як встановити Golang 1.8.3 на CentOS 7, Ubuntu 16.04 і Debian 9

Як встановити Golang 1.8.3 на CentOS 7, Ubuntu 16.04 і Debian 9

Golang — мова програмування, розроблена Google. Завдяки своїй універсальності, простоті та надійності Голанг став одним із найпопулярніших

Скиньте пароль root MySQL на Debian/Ubuntu

Скиньте пароль root MySQL на Debian/Ubuntu

Якщо ви забули свій пароль root MySQL, ви можете скинути його, виконавши дії, описані в цій статті. Процес досить простий і працює на них

Налаштування Counter Strike: Source на Debian

Налаштування Counter Strike: Source на Debian

У цьому посібнику ми будемо налаштовувати ігровий сервер Counter Strike: Source на Debian 7. Ці команди були перевірені на Debian 7, але вони також повинні працювати

Як встановити Unturned 2.2.5 на Debian 8

Як встановити Unturned 2.2.5 на Debian 8

У цьому посібнику ви дізнаєтеся, як налаштувати сервер Unturned 2.2.5 на Vultr VPS під керуванням Debian 8. Примітка. Це відредагована версія Unturned, яка не

Як встановити Cachet на Debian 8

Як встановити Cachet на Debian 8

У цьому підручнику ви дізнаєтеся, як встановити Cachet на Debian 8. Cachet — це потужна система сторінок стану з відкритим вихідним кодом. Встановлення. Цей підручник триває

Автоматично резервне копіювання кількох баз даних MySQL або MariaDB

Автоматично резервне копіювання кількох баз даних MySQL або MariaDB

Вступ У цій статті розглянемо, як створити резервну копію кількох баз даних MySQL або MariaDB, які знаходяться на одній машині за допомогою спеціального сценарію bash.

Налаштування Chroot на Debian

Налаштування Chroot на Debian

Ця стаття навчить вас, як налаштувати в’язницю chroot на Debian. Я припускаю, що ви використовуєте Debian 7.x. Якщо ви використовуєте Debian 6 або 8, це може спрацювати, але

Як встановити Reader Self 3.5 RSS Reader на Debian 9 LAMP VPS

Як встановити Reader Self 3.5 RSS Reader на Debian 9 LAMP VPS

Використання іншої системи? Reader Self 3.5 — це простий і гнучкий, безкоштовний і відкритий код для читання RSS з власним розміщенням і альтернатива Google Reader. Читач Сел

Як встановити Backdrop CMS 1.8.0 на Debian 9 LAMP VPS

Як встановити Backdrop CMS 1.8.0 на Debian 9 LAMP VPS

Використання іншої системи? Backdrop CMS 1.8.0 — це проста та гнучка, зручна для мобільних пристроїв, безкоштовна і відкрита система керування вмістом (CMS), яка дозволяє нам

Як встановити SteamCMD на свій VPS

Як встановити SteamCMD на свій VPS

У цьому підручнику ми встановимо SteamCMD. SteamCMD можна використовувати для завантаження та встановлення багатьох ігрових серверів Steam, таких як Counter-Strike: Global Offensiv

Оновіть Python на Debian

Оновіть Python на Debian

Як ви, можливо, знаєте, репозиторії Debian оновлюються дуже повільно. На момент написання статті версії випуску Python були 2.7.12 і 3.5.2, але в репозиторії Debian 8

Як налаштувати Samba за допомогою блочного сховища на Debian 9

Як налаштувати Samba за допомогою блочного сховища на Debian 9

Samba — це рішення з відкритим вихідним кодом, яке дозволяє користувачам швидко і безпечно налаштувати спільні файли та друк. У цій статті я розповім, як налаштувати Samba wit

Повстання машин: застосування ШІ в реальному світі

Повстання машин: застосування ШІ в реальному світі

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

DDOS-атаки: короткий огляд

DDOS-атаки: короткий огляд

Ви також стали жертвою DDOS-атак і спантеличені методами запобігання? Прочитайте цю статтю, щоб вирішити свої запитання.

Ви коли-небудь замислювалися, як хакери заробляють гроші?

Ви коли-небудь замислювалися, як хакери заробляють гроші?

Можливо, ви чули, що хакери заробляють багато грошей, але чи замислювалися ви коли-небудь, як вони заробляють такі гроші? давайте обговоримо.

Революційні винаходи від Google, які полегшать ваше життя.

Революційні винаходи від Google, які полегшать ваше життя.

Ви хочете побачити революційні винаходи Google і як ці винаходи змінили життя кожної людини сьогодні? Тоді читайте в блозі, щоб побачити винаходи Google.

Friday Essential: Що сталося з автомобілями, керованими штучним інтелектом?

Friday Essential: Що сталося з автомобілями, керованими штучним інтелектом?

Концепція самокерованих автомобілів, щоб вирушати в дороги за допомогою штучного інтелекту, є мрією, яку ми давно мріємо. Але, незважаючи на кілька обіцянок, їх ніде не видно. Прочитайте цей блог, щоб дізнатися більше…

Технологічна сингулярність: віддалене майбутнє людської цивілізації?

Технологічна сингулярність: віддалене майбутнє людської цивілізації?

Оскільки наука розвивається швидкими темпами, бере на себе багато наших зусиль, ризики піддати себе незрозумілій Сингулярності також зростає. Читайте, що може означати для нас сингулярність.

Еволюція зберігання даних – інфографіка

Еволюція зберігання даних – інфографіка

Методи зберігання даних можуть розвиватися з моменту народження Даних. Цей блог висвітлює еволюцію зберігання даних на основі інфографіки.

Функціональні можливості шарів еталонної архітектури великих даних

Функціональні можливості шарів еталонної архітектури великих даних

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

6 дивовижних переваг використання пристроїв розумного дому в нашому житті

6 дивовижних переваг використання пристроїв розумного дому в нашому житті

У цьому цифровому світі пристрої розумного дому стали важливою частиною життя. Ось кілька дивовижних переваг пристроїв розумного дому щодо того, як вони роблять наше життя гідним життя та спрощують його.

Оновлення доповнення macOS Catalina 10.15.4 спричиняє більше проблем, ніж вирішує

Оновлення доповнення macOS Catalina 10.15.4 спричиняє більше проблем, ніж вирішує

Нещодавно Apple випустила додаткове оновлення macOS Catalina 10.15.4, щоб виправити проблеми, але схоже, що оновлення викликає більше проблем, що призводять до блокування комп’ютерів Mac. Прочитайте цю статтю, щоб дізнатися більше