# GitLab GitLab es una plataforma HostSelf para Git, bastante pesada pero con muchas propiedades, utilidades y funcionalidades. Ésta será la plataforma de trabajo compartido que se usará. > El Git sólo se mirará para trabajar desde Linux desde la propia VM que gestiona el proyecto. Si se hace uso de otro sistema será mejor Googlear y no seguir esta guía. ## Instalación de GitLab En este caso se usó un Debian puro versión 10.9.0 amd64 en Core con 4GB de RAM y 1 Core virtualizado sobre un i7 4970K con 32GB de RAM Dual Channel 1600 en VirtualBox. Se seleccionaron solo 4GB de RAM y 1 Core por el hecho de no trabajar, previsiblemente más de 50 personas simultáneamente, preveendo más o menos unos 10, el resto de usuarios serán visitantes no autenticados. La estructura de Red es acceso mediante un Router el cual establece una apertura de puertos mediante iptables contra una máquina que vincula y balancea la carga con Nginx, y ésta será la encargada de gestionar las peticiones contra la máquina que contiene el GitLab. ```mermaid graph TB R[Router] --> N[VM Nginx] G --> N N --> R subgraph Servidor N --> G[VM GitLab] end ``` El primer problema al que nos enfrentamos es que GitLab no será quien recoja la petición de forma directa, sino que pasará por un Proxy de entrada el cual redirigirá la petición a la máquina de GitLab. De primeras, ésto no debería de ser un problema pero GitLab posee otro Nginx por detrás que es el que gestiona las peticiones Web del mismo. La dirección DNS no la pilla de la petición, sino de la cabecera X-FORWARDED-FOR, que por lo general es la dirección IP de la que parte la petición, por lo que es necesario implementar, en este caso, una línea en la configuración del sitio Nginx con la dirección DNS para dicha cabecera. > **NOTA**: No vale poner $server-name, en la definición de cabeceras no funciona, lo que nos obliga a usar una única dirección DNS como sale en el ejemplo siguiente. ```conf server { listen XXXXX; server_name ~^git\.k3y\.pw$; location / { proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-Proto https; proxy_set_header X-Forwarded-For $remote_addr; proxy_set_header X-Forwarded-Host git.k3y.pw; proxy_pass https://XXX.XXX.XXX.XXX$request_uri; } } ``` Sabiendo esto, simplemente hemos de seguir los pasos de la guía de instalación del GitLab Enterprise Edition, pero cambiando en todo momento "gitlab-ee" por "gitlab-ce" desde la guía oficial, la cual dejamos a continuación: https://about.gitlab.com/install/#debian > En nuestro caso no tenemos instalado "sudo", por lo que hay que adaptar los comandos sobre un entorno "su". En el caso del CURL para el Script Deb se descargó mediante "wget" y se ejecutó sobre "su", por ejemplo. ## Establecer Memoria en el Login Lo primero es instalar el Git en nuestro equipo, donde tendríamos las siguientes opciones más comunes:
Debian | Fedora / Red Hat | Arch | Windows 10 |
---|---|---|---|
```sh apt install git ``` | ```sh yum install git ``` | ```sh pacman install git ``` | ```bat widget install git ``` |