In collaborative software development, having a robust version control system is paramount. GitLab, a web-based Git repository manager, provides a comprehensive platform for managing source code repositories, CI/CD pipelines, and collaboration among development teams.

In this guide, we will walk through the process of installing GitLab on Debian 11, empowering you to enhance your team’s productivity and code management.

Step 1 – Add GitLab Repository

By default, GitLab is not included in the Debian default repository, so you will need to install it from the GitLab official repository.

First, install all the required dependencies using the following command.

apt install curl debian-archive-keyring lsb-release ca-certificates apt-transport-https software-properties-common -y

Next, run the following script to add the GitLab repository.

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

Next, edit the GitLab source file and replace the Debian 11 code name with Debian 10:

nano /etc/apt/sources.list.d/gitlab_gitlab-ce.list

Find the following lines:

deb https://packages.gitlab.com/gitlab/gitlab-ce/debian/ bullseye main
deb-src https://packages.gitlab.com/gitlab/gitlab-ce/debian/ bullseye main

Replace them with the following lines:

deb https://packages.gitlab.com/gitlab/gitlab-ce/debian/ buster main
deb-src https://packages.gitlab.com/gitlab/gitlab-ce/debian/ buster main

Save and close the file, then update the repository with the following command:

apt-get update -y

Step 2 – Install GitLab CE

You can install the GitLab CE using the following command.

apt install gitlab-ce

Once the installation is finished, you will see the following output.

It looks like GitLab has not been configured yet; skipping the upgrade script.

       *.                  *.
      ***                 ***
     *****               *****
    .******             *******
    ********            ********
   ,,,,,,,,,***********,,,,,,,,,
  ,,,,,,,,,,,*********,,,,,,,,,,,
  .,,,,,,,,,,,*******,,,,,,,,,,,,
      ,,,,,,,,,*****,,,,,,,,,.
         ,,,,,,,****,,,,,,
            .,,,***,,,,
                ,*,.
  


     _______ __  __          __
    / ____(_) /_/ /   ____ _/ /_
   / / __/ / __/ /   / __ `/ __ \
  / /_/ / / /_/ /___/ /_/ / /_/ /
  \____/_/\__/_____/\__,_/_.___/
  

Thank you for installing GitLab!
GitLab was unable to detect a valid hostname for your instance.
Please configure a URL for your GitLab instance by setting `external_url`
configuration in /etc/gitlab/gitlab.rb file.
Then, you can start your GitLab instance by running the following command:
  sudo gitlab-ctl reconfigure

Step 3 – Configure GitLab CE

You can edit the GitLab default configuration file with the following command.

nano /etc/gitlab/gitlab.rb

Define your domain name as shown below:

external_url 'http://gitlab.mydomain.com'

Save and close the file and reconfigure GitLab using the following command.

gitlab-ctl reconfigure

You will see the following output.

Notes:
Default admin account has been configured with following details:
Username: root
Password: You didn't opt-in to print initial root password to STDOUT.
Password stored to /etc/gitlab/initial_root_password. This file will be cleaned up in first reconfigure run after 24 hours.

NOTE: Because these credentials might be present in your log files in plain text, it is highly recommended to reset the password following https://docs.gitlab.com/ee/security/reset_user_password.html#reset-your-root-password.

gitlab Reconfigured!

Step 4 – Access GitLab CE

Before accessing GitLab, you will need a root password to log into the GitLab interface. You can retrieve the GitLab root password with the following command.

cat /etc/gitlab/initial_root_password

You will see the following output.

# WARNING: This value is valid only in the following conditions
#          1. If provided manually (either via `GITLAB_ROOT_PASSWORD` environment variable or via `gitlab_rails['initial_root_password']` setting in `gitlab.rb`, it was provided before database was seeded for the first time (usually, the first reconfigure run).
#          2. Password hasn't been changed manually, either via UI or via command line.
#
#          If the password shown here doesn't work, you must reset the admin password following https://docs.gitlab.com/ee/security/reset_user_password.html#reset-your-root-password.

Password: 6MRtx/5pk7r7PqF3Ss8+EGu+Ihn8UQT8tt+vyHY/TVg=

# NOTE: This file will be automatically deleted in the first reconfigure run after 24 hours.

Now, open your web browser and access GitLab CE using the URL http://gitlab.mydomain.com. You will see the GitLab login screen.

Provide your admin username as root and the password from the above output, then click on Sign In. You will see the GitLab CE dashboard on the following screen.

Step 5 – Secure GitLab CE with Let’s Encrypt SSL

For security reasons, it is always recommended to secure GitLab with SSL. To do so, edit the GitLab configuration file.

nano /etc/gitlab/gitlab.rb

Define your secure URL and change the following lines:

external_url 'https://gitlab.mydomain.com'

letsencrypt['enable'] = true
letsencrypt['contact_emails'] = ['user@mydomain.com']
letsencrypt['auto_renew'] = true
letsencrypt['auto_renew_hour'] = 3
letsencrypt['auto_renew_day_of_month'] = "*/7"

Save and close the file, then reconfigure GitLab using the following command.

gitlab-ctl reconfigure

You can now access GitLab securely using the URL https://gitlab.mydomain.com.

Step 6 – Manage GitLab CE

If you want to change the GitLab root password, run the following command.

gitlab-rake 'gitlab:password:reset[root]'

Define your new password as shown below:

Enter password: 
Confirm password: 
Password successfully updated for user with username root.

To check the status of GitLab, run the following command.

gitlab-ctl status

To stop GitLab, run the following command.

gitlab-ctl stop

To restart GitLab, run:

gitlab-ctl restart

Conclusion

Congratulations! You have successfully installed GitLab on Debian 11. GitLab provides a powerful and user-friendly version control and collaboration platform, offering features like code repositories, issue tracking, and continuous integration. Explore GitLab further to optimize your team’s workflow and streamline development. You can not implement the CI/CD pipeline using GitLab CE on dedicated server hosting from Atlantic.Net!