데비안 9에 GitLab Community Edition (CE) 11.x를 설치하는 방법

GitHub가 Microsoft에 의해 인수 된 이후, 상당수의 개발자가 자체 코드 리포지토리를 github.com에서 다른 자체 호스팅 솔루션으로 마이그레이션 할 계획이었습니다. GitLab Community Edition (CE)이 가장 일반적인 선택입니다.

정교하고 유연한 솔루션 인 GitLab CE는 다양한 방법으로 배포 할 수 있지만 공식적으로 권장되는 방법 인 Omnibus 패키지 설치 만 여기에서 다룰 것입니다.

전제 조건

  • 최소 4GB의 메모리가있는 새로운 Vultr Debian 9 x64 서버 인스턴스. 최대 100 명의 사용자를 지원하려면 8GB 이상이 권장됩니다. IPv4 주소가 203.0.113.1입니다.
  • sudo는 사용자 .
  • gitlab.example.com위에서 언급 한 사례를 향한 도메인 .

참고 : 자체 서버 인스턴스에 배포 할 때는 모든 예제 값을 실제 값으로 바꾸십시오.

1 단계 : GitLab CE 호스팅을위한 기본 작업 수행

SSH 터미널을 시작하고 sudo 사용자로 Debian 9 x64 서버 인스턴스에 로그인하십시오.

스왑 파티션을 추가하고 swappiness 설정을 조정하십시오

4GB의 메모리가있는 머신에 GitLab CE 11.x를 배포 할 때는 원활한 실행을 위해 4GB 스왑 파티션을 설정해야합니다.

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

참고 : 다른 서버 크기를 사용하는 경우 스왑 파티션의 크기가 다를 수 있습니다.

시스템 성능을 위해 커널의 swappiness 설정을 다음과 같이 낮은 값으로 구성하는 것이 좋습니다 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가 설치되면 /etc/postfix/main.cf실제 서버 설정에 따라 기본 구성 파일을 편집하여 Postfix를 구성해야합니다 .

참고 : 위의 지침 외에도 SMTP 포트 25에서 Vultr의 기본 블록을 취소하려면 지원 티켓을 제출해야합니다.

또는 다른 메시징 솔루션을 사용하려면 Postfix 설치를 건너 뛰고 GitLab CE가 설치된 후 외부 SMTP 서버를 사용하도록 선택하십시오.

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 단계 : SSL 암호화 인증서를 통합하여 HTTPS 액세스 사용

지금은 서버 인스턴스에 GitLab CE 11.x를 성공적으로 설치했으며 사용자는 이미 HTTP 프로토콜을 사용하여 사이트를 방문 할 수 있습니다. 보안을 위해 Let 's Encrypt SSL 인증서를 통합하여 GitLab 서버에 대한 HTTPS 액세스를 활성화하는 것이 좋습니다.

사용 viGitLab 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

재구성하는 데 시간이 걸릴 수 있습니다.

재구성이 완료되면 모든 사용자는 GitLab 사이트에 액세스 할 때 HTTPS 프로토콜을 사용해야합니다.

참고 : HTTP에서 HTTPS로 전환 한 후 레거시 쿠키는 GitLab 422 오류를 일으킬 수 있습니다. 쿠키를 지우면이 문제가 해결됩니다.



Leave a Comment

WsgiDAV를 사용하여 Debian 10에 WebDAV 배포

WsgiDAV를 사용하여 Debian 10에 WebDAV 배포

WebDAV (Web Distributed Authoring and Versioning)를 이용한 원격 파일 작성을 위한 프레임워크로, WsgiDAV 설치 및 구성 방법을 안내합니다.

데비안 7에 Mailcow 설치

데비안 7에 Mailcow 설치

Mailcow는 DoveCot, Postfix 및 기타 여러 오픈 소스 패키지를 기반으로 하는 경량 메일 서버입니다. 데비안에서 Mailcow 설치 방법을 안내합니다.

데비안에서 NFS 공유 설정

데비안에서 NFS 공유 설정

NFS는 컴퓨터가 컴퓨터 네트워크를 통해 파일에 액세스 할 수 있도록하는 네트워크 기반 파일 시스템입니다. 이 가이드는 NF를 통해 폴더를 노출하는 방법을 설명합니다

데비안에서 Chroot 설정

데비안에서 Chroot 설정

이 기사는 데비안에서 chroot jail을 설정하는 방법을 알려줍니다. 데비안 7.x를 사용한다고 가정합니다. 데비안 6 또는 8을 실행하고 있다면 작동 할 수 있습니다.

데비안에 PiVPN을 설치하는 방법

데비안에 PiVPN을 설치하는 방법

소개 데비안에서 VPN 서버를 설정하는 쉬운 방법은 PiVPN을 사용하는 것입니다. PiVPN은 OpenVPN 용 설치 프로그램 및 래퍼입니다. 그것은 당신을 위해 간단한 명령을 만듭니다

데비안 9의 소스에서 Brotli를 빌드하는 방법

데비안 9의 소스에서 Brotli를 빌드하는 방법

다른 시스템을 사용하십니까? Brotli는 Gzip보다 압축률이 더 좋은 새로운 압축 방법입니다. 소스 코드는 Github에서 공개적으로 호스팅됩니다. 티

데비안 9에 Neos CMS를 설치하는 방법

데비안 9에 Neos CMS를 설치하는 방법

다른 시스템을 사용하십니까? Neos는 CMS와 응용 프로그램 프레임 워크가 핵심 인 콘텐츠 응용 프로그램 플랫폼입니다. 이 가이드는 설치하는 방법을 보여줍니다

데비안 제시에 선인장 설치

데비안 제시에 선인장 설치

소개 Cacti는 RRD 데이터를 기반으로하는 오픈 소스 모니터링 및 그래프 도구입니다. Cacti를 통해 거의 모든 유형의 희생자를 모니터링 할 수 있습니다

CentOS 8, Ubuntu 18.04, Debian 10 및 Fedora 31에 Golang 1.13을 설치하는 방법 31

CentOS 8, Ubuntu 18.04, Debian 10 및 Fedora 31에 Golang 1.13을 설치하는 방법 31

Go (Golang이라고도 함)는 Google에서 개발 한 정적으로 형식이 지정된 컴파일 된 C 유사 프로그래밍 언어입니다. 단순성과 다목적 성으로 인해 b가되었습니다.

데비안 8 또는 데비안 9에 FFmpeg를 설치하는 방법

데비안 8 또는 데비안 9에 FFmpeg를 설치하는 방법

소개 FFmpeg는 비디오 및 오디오 인코딩 / 디코딩을위한 오픈 소스 명령 줄 도구입니다. 주요 특징은 고속, 품질 및 작은 fil입니다

Ubuntu 16.04 및 Debian 9에 TermRecord를 설치하는 방법

Ubuntu 16.04 및 Debian 9에 TermRecord를 설치하는 방법

다른 시스템을 사용하십니까? TermRecord는 Python으로 작성된 간단한 오픈 소스 도구로, 터미널 세션을 공유하기 쉬운 자체 오염 물질에 저장할 수 있습니다.

데비안 9에서 Matomo Analytics를 설치하는 방법

데비안 9에서 Matomo Analytics를 설치하는 방법

다른 시스템을 사용하십니까? Matomo (이전 Piwik)는 Google 애널리틱스의 대안 인 오픈 소스 분석 플랫폼입니다. Matomo 소스가 호스팅됩니다

OS 선택 : CentOS, Ubuntu, Debian, FreeBSD, CoreOS 또는 Windows Server

OS 선택 : CentOS, Ubuntu, Debian, FreeBSD, CoreOS 또는 Windows Server

이 기사는 Vultr에서 템플릿으로 제공되는 서버 운영 체제에 대한 간략한 개요를 제공합니다. CentOS CentOS는 RHEL의 공개 소스 버전입니다 (Re

데비안 10에 X-Cart 5를 설치하는 방법

데비안 10에 X-Cart 5를 설치하는 방법

다른 시스템을 사용하십니까? X-Cart는 다양한 기능과 통합 기능을 갖춘 매우 유연한 오픈 소스 전자 상거래 플랫폼입니다. X-Cart 소스 코드는 호스트입니다

Munin으로 데비안 서버 상태 모니터링

Munin으로 데비안 서버 상태 모니터링

Munin은 시스템의 프로세스 및 리소스를 조사하고 웹 인터페이스를 통해 그래프로 정보를 제공하는 모니터링 도구입니다. 다음을 사용하십시오

Debian 9 LAMP VPS에 Tiny Tiny RSS Reader를 설치하는 방법

Debian 9 LAMP VPS에 Tiny Tiny RSS Reader를 설치하는 방법

다른 시스템을 사용하십니까? Tiny Tiny RSS Reader는 무료로 제공되는 오픈 소스 자체 호스팅 웹 기반 뉴스 피드 (RSS / Atom) 리더 및 수집기입니다.

서버에 IP 주소 범위 추가 (CentOS / Ubuntu / Debian)

서버에 IP 주소 범위 추가 (CentOS / Ubuntu / Debian)

소개이 튜토리얼에서는 CentOS, Debian 또는 Ubuntu를 실행하는 Linux 서버에 전체 IP 범위 / 서브넷을 추가하는 프로세스를 다룹니다. 프로세스

카운터 스트라이크 설정 : 데비안 소스

카운터 스트라이크 설정 : 데비안 소스

이 가이드에서는 데비안 7에서 카운터 스트라이크 : 소스 게임 서버를 설정합니다.이 명령은 데비안 7에서 테스트되었지만 작동해야합니다.

데비안 Wheezy에 iRedMail 설정

데비안 Wheezy에 iRedMail 설정

다른 시스템을 사용하십니까? 이 튜토리얼에서는 Debian Wheezy를 새로 설치할 때 그룹웨어 iRedMail을 설치하는 방법을 보여줍니다. 서브를 사용해야합니다

데비안 9에서 디아스포라로 소셜 네트워크 구축

데비안 9에서 디아스포라로 소셜 네트워크 구축

다른 시스템을 사용하십니까? 디아스포라는 프라이버시를 인식하는 오픈 소스 소셜 네트워크입니다. 이 학습서에서는 Diaspora po를 설정하고 구성하는 방법을 학습합니다.

NTLite를 사용하여 업데이트로 Windows 사용자 지정 ISO를 만드는 방법

NTLite를 사용하여 업데이트로 Windows 사용자 지정 ISO를 만드는 방법

NTLite를 사용하여 Vultr 시스템과 호환되는 Windows 사용자 지정 ISO를 만드는 방법을 단계별로 설명합니다. 최신 드라이버와 업데이트 통합을 포함한 완벽 가이드.

Vultr에서 BGP 구성

Vultr에서 BGP 구성

Vultr BGP 설정을 위한 단계별 튜토리얼. ASN 할당부터 IP 라우팅 구성, BIRD 데몬 설정, FreeBSD 특이사항 및 실전 문제 해결 팁 7가지 포함한 최종 가이드

WsgiDAV를 사용하여 Debian 10에 WebDAV 배포

WsgiDAV를 사용하여 Debian 10에 WebDAV 배포

WebDAV (Web Distributed Authoring and Versioning)를 이용한 원격 파일 작성을 위한 프레임워크로, WsgiDAV 설치 및 구성 방법을 안내합니다.

데비안 7에 Mailcow 설치

데비안 7에 Mailcow 설치

Mailcow는 DoveCot, Postfix 및 기타 여러 오픈 소스 패키지를 기반으로 하는 경량 메일 서버입니다. 데비안에서 Mailcow 설치 방법을 안내합니다.

AI가 랜섬웨어 공격의 증가와 싸울 수 있습니까?

AI가 랜섬웨어 공격의 증가와 싸울 수 있습니까?

랜섬웨어 공격이 증가하고 있지만 AI가 최신 컴퓨터 바이러스를 처리하는 데 도움이 될 수 있습니까? AI가 답인가? AI boone 또는 bane인지 여기에서 읽으십시오.

ReactOS: 이것이 Windows의 미래입니까?

ReactOS: 이것이 Windows의 미래입니까?

오픈 소스이자 무료 운영 체제인 ReactOS가 최신 버전과 함께 제공됩니다. 현대 Windows 사용자의 요구 사항을 충족하고 Microsoft를 무너뜨릴 수 있습니까? 이 구식이지만 더 새로운 OS 환경에 대해 자세히 알아보겠습니다.

WhatsApp 데스크톱 앱 24*7을 통해 연결 유지

WhatsApp 데스크톱 앱 24*7을 통해 연결 유지

Whatsapp은 마침내 Mac 및 Windows 사용자용 데스크톱 앱을 출시했습니다. 이제 Windows 또는 Mac에서 Whatsapp에 쉽게 액세스할 수 있습니다. Windows 8 이상 및 Mac OS 10.9 이상에서 사용 가능

AI는 어떻게 프로세스 자동화를 다음 단계로 끌어올릴 수 있습니까?

AI는 어떻게 프로세스 자동화를 다음 단계로 끌어올릴 수 있습니까?

인공 지능이 소규모 회사에서 어떻게 인기를 얻고 있으며 어떻게 인공 지능이 성장할 가능성을 높이고 경쟁자가 우위를 점할 수 있는지 알아보려면 이 기사를 읽으십시오.

macOS Catalina 10.15.4 추가 업데이트로 인해 해결보다 더 많은 문제가 발생함

macOS Catalina 10.15.4 추가 업데이트로 인해 해결보다 더 많은 문제가 발생함

최근 Apple은 문제를 해결하기 위해 macOS Catalina 10.15.4 추가 업데이트를 출시했지만 이 업데이트로 인해 Mac 컴퓨터의 브릭킹으로 이어지는 더 많은 문제가 발생하는 것 같습니다. 자세히 알아보려면 이 기사를 읽어보세요.

빅데이터의 13가지 상용 데이터 추출 도구

빅데이터의 13가지 상용 데이터 추출 도구

빅데이터의 13가지 상용 데이터 추출 도구