Home Development Tools git Teach you step by step how to deploy LDAP in GitLab

Teach you step by step how to deploy LDAP in GitLab

Apr 03, 2023 am 11:53 AM

GitLab is an efficient code management tool that can help teams manage code more efficiently and achieve better collaboration. In a team, sometimes different permissions need to be granted to different people. In this case, LDAP needs to be used to authenticate GitLab. Next, let's learn how to deploy LDAP in GitLab.

1. Install the LDAP plug-in

First, before installing GitLab, you need to install the LDAP plug-in. After installing GitLab, we enter the GitLab installation directory and install the LDAP dependency package.

yum install openldap openldap-devel -y
Copy after login

After installing the dependent packages, we need to install GitLab’s LDAP plug-in. First, enter the GitLab plug-in directory:

cd /usr/share/gitlab/lib/gitlab/auth/backends/
Copy after login

Then, we need to download the tar package of the LDAP plug-in:

sudo curl -o ldap.tar.gz https://gitlab.com/gitlab-org/gitlab-ce/repository/archive.tar.gz?ref=master
Copy after login

Extract the tar package of the LDAP plug-in and overwrite the original file:

sudo tar -zxf ldap.tar.gz --strip-components 2 gitlab-ce-master/lib/gitlab/auth/backends/gitlab_ldap/
Copy after login

Re-execute the GitLab configuration:

sudo gitlab-ctl reconfigure
Copy after login

2. Configure LDAP

After installing the LDAP plug-in , we need to configure LDAP for GitLab. Open the GitLab configuration file and add the LDAP configuration content:

sudo vim /etc/gitlab/gitlab.rb
Copy after login

The main parameters we need to configure are as follows:

gitlab_rails['ldap_enabled'] = true
gitlab_rails['ldap_servers'] = YAML.load <<-&#39;EOS&#39;
  main: # ‘main’其实是名称,可以根据实际情况进行配置,下面也需要使用同样的名称
    label: &#39;LDAP&#39;
    host: &#39;ldap.example.com&#39; # LDAP服务器地址
    port: 389 # LDAP服务器端口
    uid: &#39;sAMAccountName&#39; # 用户登录时需要使用的属性
    block_auto_created_users: false # 是否阻止自动创建
    bind_dn: &#39;CN=ldapuser,OU=Web Services,DC=example,DC=com&#39; # LDAP的管理员账户
    password: &#39;yourpassword&#39; # LDAP管理员账户的密码
    encryption: &#39;plain&#39; # 加密方式,plain或tls
    base: &#39;CN=Users,DC=example,DC=com&#39; # 查询的基础DN
    user_filter: &#39;&#39; # 根据需要设置用户筛选规则
EOS
Copy after login

After the configuration is completed, re-execute the GitLab configuration:

sudo gitlab-ctl reconfigure
Copy after login

3. Test the LDAP connection

After configuring LDAP, we need to test whether the LDAP connection is successful. First, we need to create a test account on LDAP, for example: testuser.

Use the ldapsearch command on the GitLab server to test the LDAP connection, for example:

ldapsearch -H ldap://ldap.example.com -x -b "CN=Users,DC=example,DC=com" -D "CN=ldapuser,OU=Web Services,DC=example,DC=com" -w &#39;yourpassword&#39;
Copy after login

If the connection is successful, we can view the user information in LDAP, for example:

# testuser, Users, example.com
dn: CN=testuser,CN=Users,DC=example,DC=com
objectClass: top
objectClass: person
...
Copy after login

If the above appears message indicating that the connection is successful.

4. Enable LDAP in GitLab

After the LDAP connection is successful, we need to enable LDAP in GitLab. After LDAP is enabled, each LDAP user can log in to GitLab and use its allowed permissions.

In the GitLab user panel, click "Administrator area" -> "Settings" -> "LDAP", and then enable the LDAP option.

The main parameters we need to configure are as follows:

  • "Host": LDAP server address
  • "Port": LDAP server port
  • " Base": LDAP's base DN

According to the situation, we can also modify the attribute name used when logging in, and add custom rules in the LDAP filter to filter specific users.

5. Summary

Through the introduction of this article, we can know how to deploy LDAP in GitLab. Enabling LDAP in GitLab can effectively manage users in the team, providing a good foundation for future development work.

The above is the detailed content of Teach you step by step how to deploy LDAP in GitLab. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Git vs. GitHub: Version Control and Code Hosting Git vs. GitHub: Version Control and Code Hosting Apr 11, 2025 am 11:33 AM

Git is a version control system, and GitHub is a Git-based code hosting platform. Git is used to manage code versions and supports local operations; GitHub provides online collaboration tools such as Issue tracking and PullRequest.

Is Git the same as GitHub? Is Git the same as GitHub? Apr 08, 2025 am 12:13 AM

Git and GitHub are not the same thing. Git is a version control system, and GitHub is a Git-based code hosting platform. Git is used to manage code versions, and GitHub provides an online collaboration environment.

How to download git projects to local How to download git projects to local Apr 17, 2025 pm 04:36 PM

To download projects locally via Git, follow these steps: Install Git. Navigate to the project directory. cloning the remote repository using the following command: git clone https://github.com/username/repository-name.git

Is GitHub difficult to learn? Is GitHub difficult to learn? Apr 02, 2025 pm 02:45 PM

GitHub is not difficult to learn. 1) Master the basic knowledge: GitHub is a Git-based version control system that helps track code changes and collaborative development. 2) Understand core functions: Version control records each submission, supporting local work and remote synchronization. 3) Learn how to use: from creating a repository to push commits, to using branches and pull requests. 4) Solve common problems: such as merge conflicts and forgetting to add files. 5) Optimization practice: Use meaningful submission messages, clean up branches, and manage tasks using the project board. Through practice and community communication, GitHub’s learning curve is not steep.

How to use git commit How to use git commit Apr 17, 2025 pm 03:57 PM

Git Commit is a command that records file changes to a Git repository to save a snapshot of the current state of the project. How to use it is as follows: Add changes to the temporary storage area Write a concise and informative submission message to save and exit the submission message to complete the submission optionally: Add a signature for the submission Use git log to view the submission content

How to update code in git How to update code in git Apr 17, 2025 pm 04:45 PM

Steps to update git code: Check out code: git clone https://github.com/username/repo.git Get the latest changes: git fetch merge changes: git merge origin/master push changes (optional): git push origin master

What to do if the git download is not active What to do if the git download is not active Apr 17, 2025 pm 04:54 PM

Resolve: When Git download speed is slow, you can take the following steps: Check the network connection and try to switch the connection method. Optimize Git configuration: Increase the POST buffer size (git config --global http.postBuffer 524288000), and reduce the low-speed limit (git config --global http.lowSpeedLimit 1000). Use a Git proxy (such as git-proxy or git-lfs-proxy). Try using a different Git client (such as Sourcetree or Github Desktop). Check for fire protection

How to merge code in git How to merge code in git Apr 17, 2025 pm 04:39 PM

Git code merge process: Pull the latest changes to avoid conflicts. Switch to the branch you want to merge. Initiate a merge, specifying the branch to merge. Resolve merge conflicts (if any). Staging and commit merge, providing commit message.

See all articles