Git是全球开发人员使用的开源版本控制系统。接下来,我们将介绍如何创建自己的Git Linux服务器来托管项目。
Git服务器用于托管项目的存储库,其中包含源代码和其他核心文件。虽然在大多数情况下,您可以依赖于像GitHub这样的全球知名的Git托管服务,但在某些情况下,最好托管您自己的个人Git服务器,以增加隐私、可定制性和安全性。
现在,让我们学习如何在Linux上设置私有Git服务器。
在开始设置您的私有Git服务器之前,您需要拥有访问备用计算机或订阅云提供商的权限。这一点很重要,因为您将把备用计算机设置为Git服务器,并从本地计算机连接到该服务器并执行Git操作。
虽然没有明确的系统要求,但1GB的RAM应该足以让Git服务器正常运行。此外,请确保您在计算机上安装并运行了Linux发行版。
不用说,作为预备步骤,您需要在 Linux 服务器上安装 Git。启动终端并使用 Linux 发行版的包管理器来安装 Git:
在 Debian/Ubuntu 衍生产品上:
sudo apt install git
基于Arch的发行版:
sudo pacman -S git
在 CentOS/RHEL/Fedora 上:
sudo dnf install git
“
在您的系统上安装 Git 后,请继续执行以下步骤来配置您的 Linux 系统,以将您的 Git 存储库作为 Git 服务器托管。
通过 SSH、RDP 或任何其他远程访问协议连接到您的 Linux 服务器。或者,如果您使用备用计算机作为服务器,请将其打开并创建一个新用户帐户来处理您的存储库。
ssh username@address sudo useradd git
“
添加新用户后,使用su命令切换到该用户:
su git
创建专用git用户帐户是一种安全协议,可确保连接到您的 Git 服务器的客户端对机器上的资源的可见性和访问权限有限。这使您可以在多个团队成员将访问您的服务器的小组项目中安全地协作。
创建一个**.ssh**目录对于存储公钥和其他基本数据是必要的,这些数据将决定谁可以访问这个 Git 服务器。首先,登录到您之前创建的 git 用户帐户,创建 .ssh 目录,并将访问权限限制为仅 git 用户:
ssh git@address mkdir .ssh chmod 700 .ssh/ touch .ssh/authorized_keys
“
使用chmod命令保护目录访问权限,以确保除了您之外没有人可以对其进行更改。进入**.ssh目录并使用****touch**命令创建一个新文件“authorized_keys” 。
cd .ssh ssh-keygen -t rsa #如果您没有 id_rsa.pub 文件,请使用此命令 cat id_rsa.pub
“
您必须使用您希望授予对 Git 服务器访问权限的客户端的 SSH 公钥来更新此文件。暂停 SSH 会话并使用文本编辑器或cat 命令在本地计算机中打开**.ssh/id_rsa.pub**文件。该文件包含您的公共加密密钥,当将其写入authorized_keys 文件时,您将无需密码即可访问Git 服务器。
cd .sshvi authorized_keys
复制公钥并启动到 Git 服务器的新 SSH 连接。进入**.ssh**目录,使用文本编辑器打开 authorized_keys 文件并粘贴公钥。保存更改并退出。
从那时起,您应该能够在没有任何密码的情况下连接到服务器。对将连接到服务器的每台计算机重复此步骤。
访问 Linux 服务器并创建一个目录或使用内置目录作为根目录。请记住,这是存储所有存储库的目录。为了更整洁地组织项目,这是一个很好的做法。
mkdir directory_name
创建目录后,继续本指南的最后一步以完成 Git 服务器的设置。
您现在实际上已经完成了 Git 服务器的设置。现在您只需要通过初始化存储库并将远程源添加到本地计算机来开始开发。使用cd命令进入父目录并创建一个**.git**项目目录:
cd parent_director ymkdir new_project.git
现在,初始化一个裸 git 存储库:
git init --bare
初始化存储库后,是时候在本地计算机上添加远程源了:
git remote add origin name git@address:new_project.git
这就是您在服务器端需要做的所有事情。现在任何经过身份验证的客户端都可以执行常规的 Git 操作,例如推送、拉取、合并、克隆等。要开始新项目,每次创建新项目时都必须重复此步骤。
通过执行 git push 测试其功能:
touch testfile git add testfile git commit -m "test file" git push name master git clone git@address:new_project.git
您的文件将成功推送到远程源。要交叉检查推送操作是否有效,您可以克隆存储库,您应该在存储库中找到测试文件。
随着 Git 服务器的启动和运行,您必须密切注意它的安全状态,因为它是您的个人服务器,维护和保护它免受外部威胁是您的唯一责任。要采用的一些最佳安全实践是:
您可以在 Linux 服务器上实施许多此类安全配置和安全措施,以保护其免受攻击者的侵害并防止未经授权的访问。
以上是如何在 Linux 上设置私有 Git 服务器的详细内容。更多信息请关注PHP中文网其他相关文章!