Git服务器搭建简明教程-程序员宅基地

技术标签: 搭建  GIT服务器  git  ubuntu  教程  

1前言

本文详解在Ubantu 16下搭建Git服务器,力求让读者知其所以然,仅需安装Git和ssh,而无需其他软件。

2服务器搭建

在真实服务器或虚拟机里操作均可。另外,如果用VMware Workstation 16 Player的话,默认不用配置虚拟机网卡,本地机就能Ping通。教程使用普通用户操作,如果是root用户,就不用加sudo了,命令将更加简洁。

2.1安装Git和SSH

已安装过的最好也再来一遍,以更新到最新,除非自己很清楚。

sudo apt-get install git
sudo apt-get install ssh
service ssh start

2.2新建用户

方便管理仓库,这里新建一个叫git的用户,名字可以任意,但推荐取名为git。建议以后Git的相关的东西,都放到这个用户目录下。

注意,中途输入的密码是给新建的git用户设置的密码,其他直接回车使用默认信息即可。

sudo adduser git

注意,以上只是创建了叫git的用户,后续的操作并没有切换到该用户进行。

2.3创建登录证书

创建路径.ssh,然后创建authorized_keys文件,这里路径和文件名不能任取,该文件用于存放各个git客户端的RSA公钥,只有在这个列表里的客户端才能连接git服务。公钥在下一步创建。

cd /home/git/
sudo mkdir .ssh
sudo touch .ssh/authorized_keys

2.4本地端创建密钥

注意,这一步在本地端进行。不同的本地用户有不同的KEY。

ssh-keygen -t rsa

这里在windows下进行,这个命令可以在CMD、PowerShell或Git bash里执行。这里选Git bash,任意空白处右键点击Git bash here,然后右键粘贴执行,中途全默认按回车即可。

 如上图就已经生成,在用户根目录的.ssh文件夹内,id_rsa.pub就是我们要的公钥:

2.5本地端公钥上传

这里只是方法之一,只要能把id_rsa.pub传到服务器就行。scp是ssh的文件复制命令。

scp id_rsa.pub [email protected]:/home/git/

注意,使用你自己的ip地址。

我们来到上边.ssh文件夹内右键点击Git bash here,右键粘贴执行,中途输入yes,然后输入刚才创建git账号的密码,成功后如图:

 2.6服务器添加用户公钥

 注意,在服务器端进行。使用cat指令将公钥追加到authorized_keys文件。

sudo sh -c "cat id_rsa.pub >> .ssh/authorized_keys"

注意,如果不是root用户,使用如下方式则会报权限错误:

sudo cat id_rsa.pub >> .ssh/authorized_keys

如果想确认是否成功,可以输入命令查看:

head -n 5 authorized_keys

命令的意思是查看authorized_keys文件前5行的内容。

2.7创建仓库存放路径并设置所属用户为git

路径可任意起名,这里叫gitrepo。

sudo mkdir gitrepo
sudo chown git:git gitrepo

2.8初始化仓库并设置所属用户为git

这里建了一个叫test的仓库。

cd /home/git/gitrepo
sudo git init --bare test.git
sudo chown -R git:git test.git

因为这里的test.git路径下有多个文件,所以加-R参数递归。

到此,git服务器就算搭建完成,URL地址如下:

[email protected]:/home/git/gitrepo/test.git

安全选项

公钥列表里的客户端都可以无需密码直接可以使用git用户登录shell,如:

ssh [email protected]

下面通过修改/etc/passwd实现限制:

sudo nano /etc/passwd

按pagedown翻到最下面:

 找到git用户,一般都在最后,按键盘方向键移动光标到最后,将

git:x:1001:1001:,,,:/home/git:/bin/bash

改成:

git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell

改完之后按照提示,分别按ctrl+X,y,回车,实现保存退出,这样就OK了。

3测试

以下简单测试Clone和Push,如果你之前用过git,那么得到上边的仓库地址后应该就非常熟悉了。

3.1 Clone

在本地电脑上新建一个文件夹A,右键打开Git bash here,试试克隆,会得到一个空的test文件夹。

git clone [email protected]:/home/gitrepo/test.git

注意,ip地址请改成自己的。 还有,这里并不需要输入上边创建git用户的密码,如果需要输入密码,说明公钥添加有误,请重新检查。

 3.2 Push

进入test文件夹内,右键新建文本文档,内容任意。

右键打开Git bash here,添加所有文件,然后提交。

git add -A
git commit

在弹出的文本中填入本次更改日志,测试用就随意写,然后保存关闭。

通过克隆来的远程仓库,默认有个别名叫origin,所以推送可以直接这样:

git push origin master

 3.3再次克隆

新建一个文件夹B,并进入,右键打开Git bash here克隆,和之前一样:

git clone [email protected]:/home/git/gitrepo/test.git

可以看到这个就是刚才提交的文本文档:

 4使用TortoiseGit的密码弹窗问题

TortoiseGit是一个图形界面的Git,不用打“繁琐”的命令了。

4.1 尝试Clone

建一个新建文件夹C,右键Git Clone,在URL中填入:

[email protected]:/home/git/gitrepo/test.git

 如果这时直接点击OK,那么会有输入远端git用户密码的提示框,因为远端已经有本地机的公钥了,这显然不符合常理。这一点TortoiseGit和Git bash不一样,需要另外加载私钥。

当然,这里要是输入了上边创建的git用户的密码,也能克隆,这个密码只有管理员知道,自己现在就是管理员,多个git客户端的情况下别人就不知道了,除非你把密码告诉世界上所有人咯。

4.2创建PPK私钥

 找到开始菜单TortoiseGit文件夹下的PuTTYgen打开:

 按图中步骤操作,中间会有弹窗提示,默认即可。加载2.4步骤创建密钥生成的私钥id_rsa,然后另存为putty_rsa.ppk。

 4.3 Clone

回到新建文件夹C下,右键Git Clone,Load Putty Key 中加载刚才生成的putty_rsa.ppk

 可以看到,已经能正常Clone了。

END

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_40692629/article/details/124420970

智能推荐

前端开发之vue-grid-layout的使用和实例-程序员宅基地

文章浏览阅读1.1w次,点赞7次,收藏34次。vue-grid-layout的使用、实例、遇到的问题和解决方案_vue-grid-layout

Power Apps-上传附件控件_powerapps点击按钮上传附件-程序员宅基地

文章浏览阅读218次。然后连接一个数据源,就会在下面自动产生一个添加附件的组件。把这个控件复制粘贴到页面里,就可以单独使用来上传了。插入一个“编辑”窗体。_powerapps点击按钮上传附件

C++ 面向对象(Object-Oriented)的特征 & 构造函数& 析构函数_"object(cnofd[\"ofdrender\"])十条"-程序员宅基地

文章浏览阅读264次。(1) Abstraction (抽象)(2) Polymorphism (多态)(3) Inheritance (继承)(4) Encapsulation (封装)_"object(cnofd[\"ofdrender\"])十条"

修改node_modules源码,并保存,使用patch-package打补丁,git提交代码后,所有人可以用到修改后的_修改 node_modules-程序员宅基地

文章浏览阅读133次。删除node_modules,重新npm install看是否成功。在 package.json 文件中的 scripts 中加入。修改你的第三方库的bug等。然后目录会多出一个目录文件。_修改 node_modules

【】kali--password:su的 Authentication failure问题,&sudo passwd root输入密码时Sorry, try again._password: su: authentication failure-程序员宅基地

文章浏览阅读883次。【代码】【】kali--password:su的 Authentication failure问题,&sudo passwd root输入密码时Sorry, try again._password: su: authentication failure

整理5个优秀的微信小程序开源项目_微信小程序开源模板-程序员宅基地

文章浏览阅读1w次,点赞13次,收藏97次。整理5个优秀的微信小程序开源项目。收集了微信小程序开发过程中会使用到的资料、问题以及第三方组件库。_微信小程序开源模板

随便推点

Centos7最简搭建NFS服务器_centos7 搭建nfs server-程序员宅基地

文章浏览阅读128次。Centos7最简搭建NFS服务器_centos7 搭建nfs server

Springboot整合Mybatis-Plus使用总结(mybatis 坑补充)_mybaitis-plus ruledataobjectattributemapper' and '-程序员宅基地

文章浏览阅读1.2k次,点赞2次,收藏3次。前言mybatis在持久层框架中还是比较火的,一般项目都是基于ssm。虽然mybatis可以直接在xml中通过SQL语句操作数据库,很是灵活。但正其操作都要通过SQL语句进行,就必须写大量的xml文件,很是麻烦。mybatis-plus就很好的解决了这个问题。..._mybaitis-plus ruledataobjectattributemapper' and 'com.picc.rule.management.d

EECE 1080C / Programming for ECESummer 2022 Laboratory 4: Global Functions Practice_eece1080c-程序员宅基地

文章浏览阅读325次。EECE 1080C / Programming for ECESummer 2022Laboratory 4: Global Functions PracticePlagiarism will not be tolerated:Topics covered:function creation and call statements (emphasis on global functions)Objective:To practice program development b_eece1080c

洛谷p4777 【模板】扩展中国剩余定理-程序员宅基地

文章浏览阅读53次。被同机房早就1年前就学过的东西我现在才学,wtcl。设要求的数为\(x\)。设当前处理到第\(k\)个同余式,设\(M = LCM ^ {k - 1} _ {i - 1}\) ,前\(k - 1\)个的通解就是\(x + i * M\)。那么其实第\(k\)个来说,其实就是求一个\(y\)使得\(x + y * M ≡ a_k(mod b_k)\)转化一下就是\(y * M ...

android 退出应用没有走ondestory方法,[Android基础论]为何Activity退出之后,系统没有调用onDestroy方法?...-程序员宅基地

文章浏览阅读1.3k次。首先,问题是如何出现的?晚上复查代码,发现一个activity没有调用自己的ondestroy方法我表示非常的费解,于是我检查了下代码。发现再finish代码之后接了如下代码finish();System.exit(0);//这就是罪魁祸首为什么这样写会出现问题System.exit(0);////看一下函数的原型public static void exit (int code)//Added ..._android 手动杀死app,activity不执行ondestroy

SylixOS快问快答_select函数 导致堆栈溢出 sylixos-程序员宅基地

文章浏览阅读894次。Q: SylixOS 版权是什么形式, 是否分为<开发版税>和<运行时版税>.A: SylixOS 是开源并免费的操作系统, 支持 BSD/GPL 协议(GPL 版本暂未确定). 没有任何的运行时版税. 您可以用她来做任何 您喜欢做的项目. 也可以修改 SylixOS 的源代码, 不需要支付任何费用. 当然笔者希望您可以将使用 SylixOS 开发的项目 (不需要开源)或对 SylixOS 源码的修改及时告知笔者.需要指出: SylixOS 本身仅是笔者用来提升自己水平而开发的_select函数 导致堆栈溢出 sylixos

推荐文章

热门文章

相关标签