GitHub는 수백만 명의 등록 사용자와 수백만 개의 오픈 소스 코드 저장소를 보유한 세계에서 가장 인기 있는 코드 호스팅 플랫폼 중 하나입니다. 그러나 기업이나 개인의 경우 자체 서버에서 코드를 호스팅하면 보안과 데이터 제어가 강화될 수 있습니다. 따라서 이번 글에서는 GitHub 서버를 설정하는 방법을 소개하겠습니다.
1. 환경 준비
1. 하드웨어 준비
GitHub 서버에 필요한 하드웨어 요구 사항은 그리 높지 않으며 일반적으로 일반 서버에서 수행할 수 있습니다. 하지만 서버의 대역폭이 1Mbps보다 크고, 코드 라이브러리, 로그 등의 데이터를 수용할 수 있는 충분한 저장 공간이 있는지 확인하는 것이 가장 좋습니다.
2. 소프트웨어 준비
다음 소프트웨어를 설치해야 합니다:
a.Git 및 기타 필요한 도구
Git은 GitHub의 핵심 버전 관리 시스템이며 클라이언트를 다운로드하여 설치해야 합니다.
b. SSH
SSH는 안전하지 않은 네트워크에서 네트워크 서비스에 대한 보안 연결을 제공하기 위해 인터넷에서 사용되는 네트워크 프로토콜입니다. SSH 클라이언트 구성 요소를 설치해야 합니다.
c. Nginx
Nginx는 경량 웹 서버이자 역방향 프록시 서버입니다. HTTP 서비스를 외부에 제공하기 위해서는 설치가 필요합니다.
d. OpenSSL
OpenSSL은 SSL 및 TLS 프로토콜을 지원하고 안전한 통신 연결을 제공하는 오픈 소스 암호화 라이브러리입니다. HTTPS 프로토콜을 지원하려면 이 라이브러리를 설치해야 합니다.
2. GitLab 설치
GitLab을 설치하기 전에 위의 소프트웨어를 설치하고 정상적으로 실행되는지 확인해야 합니다.
1. GitLab 설치
GitLab 공식 웹사이트에서 최신 GitLab 설치 패키지를 다운로드하고 다음 명령을 사용하여 설치하세요.
sudo dpkg -i gitlab-ce_*_amd64.deb
참고: GitLab의 오픈 소스 버전 여기서는 Enterprise Edition이 아닌 GitLab Community Edition 버전이 사용됩니다.
2. GitLab 구성
1) GitLab 시작
설치가 완료되면 다음 명령을 사용하여 GitLab을 시작합니다.
sudo gitlab-ctl reconfigure
2) GitLab에 액세스
시작이 완료되면 브라우저(http://your-server-ip/)를 통해 GitLab에 접속할 수 있으며 관리자 계정을 생성하고 새 창고를 생성할 수 있습니다.
3. Nginx 구성, HTTPS
1) Nginx 구성
서버에 Nginx를 설치하고 다음 명령을 사용하여 설치합니다.
sudo apt-get install nginx
다음과 같이 Nginx 구성 파일에 GitLab 구성을 추가합니다. :
업스트림 gitlab-workhorse {
server unix:/var/opt/gitlab/gitlab-workhorse/socket;
}
server {
listen 80;
server_name your-domain.com;
return 301 https://$server_name$request_uri;
}
server {
# Nginx는 포트 8080에서 수신 대기하고 GitLab Puma는 포트 8081에서 수신 대기
기본 8080 수신;
server_name your-domain.com;
# # 성능 최적화는 구성을 사용할 수 있습니다
# server_tokens off
## ~ 정규식으로 시작
## /ci 정규식은 /ci와 관련된 모든 요청을 GitLab Puma HTTP 서버
location /ci로 전달하는 것입니다. {
proxy_read_timeout 300; proxy_connect_timeout 300; proxy_redirect off; proxy_http_version 1.1; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_set_header Connection ''; proxy_pass http://127.0.0.1:8081;
}
}
2) SSL 인증서 생성
서버에서 SSL 인증서를 생성하려면 다음 명령을 사용하세요:
openssl req -new -newkey rsa:2048 -days 365 -nodes - x509 -keyout your- key-file.key -out your-ssl-file.crt
Nginx 구성 파일에 SSL 인증서 관련 구성을 추가합니다.
server {
# HTTPS 수신 443 포트
listen 443 ssl;
server_name your -domain.com;
ssl_certificate /path/to/your-ssl-file.crt;
ssl_certificate_key /path/to/your-key-file.key;
## ~시작은 정규 표현식
위치 /ci {
proxy_read_timeout 300; proxy_connect_timeout 300; proxy_redirect off; proxy_http_version 1.1; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_set_header Connection ''; proxy_pass http://127.0.0.1:8081;
}
}
3. 요약
이 글에서는 GitHub 서버 구축 방법을 소개합니다: 환경 준비, GitLab 설치, Nginx 구성, HTTPS 구성. 이 글이 GitLab 서버를 설정해야 하는 독자들에게 도움이 되기를 바랍니다.
위 내용은 GitHub 서버 설정 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!