搭建自己的git http(s)私有服务器

广告位招租
扫码页面底部二维码联系

平时自己喜欢写点代码,在家里、办公室、手【本文受版权保护】转载请注明出处:www.tangshuang.net机上同步代码是一件烦人的事,怎么解决呢?【作者:唐霜】【本文受版权保护】自然是想要一个git中心化服务。虽然gi【作者:唐霜】著作权归作者所有,禁止商业用途转载。t本身是去中心化的,但是想要让多个节点之未经授权,禁止复制转载。【本文受版权保护】间保持同步,必须有一个在公网同时可访的节本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。点作为桥梁,只要在任何环境、设备下,这台本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net机器都可以被访问,通过git获取和推送代原创内容,盗版必究。本文作者:唐霜,转载请注明出处。码,就算实现了我的目标。于是开始折腾。

本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshu【原创内容,转载请注明出处】【作者:唐霜】ang.net【未经授权禁止转载】

搭建git服务

搭建一台git服务非常方便,去腾讯云购买本文版权归作者所有,未经授权不得转载。【本文受版权保护】最便宜的云服务器。我喜欢ubuntu,所【访问 www.tangshuang.net 获取更多精彩内容】转载请注明出处:www.tangshuang.net以下面都是在ubuntu的服务器上作业。转载请注明出处:www.tangshuang.net【作者:唐霜】git是点对点的服务,所以,搭建一台gi【原创内容,转载请注明出处】【未经授权禁止转载】t服务超级简单,你都不需要做任何操作,系【关注微信公众号:wwwtangshuangnet】【未经授权禁止转载】统自带了git。如果系统不自带git,用本文作者:唐霜,转载请注明出处。【未经授权禁止转载】内置的安装命令安装它就可以了。

【转载请注明来源】【转载请注明来源】

当你的服务器安装好git之后,就具备了g【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。it服务。由于git是去中心化的,每一个【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】安装了git的电脑,都可以为其他节点提供【原创不易,请尊重版权】【本文受版权保护】服务(其实并没有提供服务,而只是提供了数转载请注明出处:www.tangshuang.net【版权所有,侵权必究】据传输的方式,怎么传输,还是要靠协议层)未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。。它可以依托ssh, http(s)协议【版权所有】唐霜 www.tangshuang.net【转载请注明来源】来传输数据。默认,ssh是最便捷的git【作者:唐霜】本文版权归作者所有,未经授权不得转载。传输协议。基于ssh,你在clone的时【关注微信公众号:wwwtangshuangnet】本文版权归作者所有,未经授权不得转载。候,甚至不需要在仓库地址中写协议段。

【版权所有,侵权必究】未经授权,禁止复制转载。原创内容,盗版必究。【版权所有,侵权必究】

在服务器上一个比较好记的路径下创建一个空本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。目录,在该目录下执行:

【转载请注明来源】【访问 www.tangshuang.n本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。et 获取更多精彩内容】
git init --bare

其中—bare参数表示,这个目录要作为裸【转载请注明来源】【版权所有】唐霜 www.tangshuang.net库,也就是纯粹作为存储代码的地方,而非进未经授权,禁止复制转载。【转载请注明来源】行代码撰写的地方。而普通执行git in【本文受版权保护】【未经授权禁止转载】it会在当前目录下创建一个.git目录,【本文首发于唐霜的博客】未经授权,禁止复制转载。在*nix系统中是个隐藏目录。它里面的内著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshuang.net容个执行git init —bare产生未经授权,禁止复制转载。原创内容,盗版必究。的内容结构一模一样。

【本文受版权保护】【本文首发于唐霜的博客】【未经授权禁止转载】【版权所有】唐霜 www.tangshu【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】ang.net

也就是说,无论是用—bare创建的裸库,转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。还是直接生成的.git目录,都可以被别人未经授权,禁止复制转载。原创内容,盗版必究。克隆和推送。

原创内容,盗版必究。【未经授权禁止转载】【作者:唐霜】

当我们在服务器上创建一个仓库之后,其他节【原创内容,转载请注明出处】【关注微信公众号:wwwtangshuangnet】点就可以通过ssh或http(s)连接和【关注微信公众号:wwwtangshuangnet】本文版权归作者所有,未经授权不得转载。拉取、推送了:

【转载请注明来源】【未经授权禁止转载】【版权所有,侵权必究】
git clone user1@127.0.0.1:/home/user1/gittest

上面的连接方式基于ssh,user1是s【原创不易,请尊重版权】【本文受版权保护】sh登陆用户,@后面是主机地址,:后面是【版权所有】唐霜 www.tangshuang.net【转载请注明来源】git仓库目录的路径。执行上面命令后,会【转载请注明来源】转载请注明出处:www.tangshuang.net要求你输入主机上user1的密码,这样就本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net可以把远程的仓库克隆到本地当前目录下。

本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。【转载请注明来源】

启用http服务

前面已经启用了ssh服务,这样虽然我们可【原创内容,转载请注明出处】【本文首发于唐霜的博客】以连接到服务器上获取代码,但是有一个问题本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net,如果在一些屏蔽了22端口的网络环境下怎原创内容,盗版必究。【本文受版权保护】么办呢?这种事情常有发生,因为很多公司内【转载请注明来源】未经授权,禁止复制转载。部为了安全起见,都会封闭大部分端口,只保本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。留几个端口,比如常用的80、443、80【转载请注明来源】本文作者:唐霜,转载请注明出处。80。如果是这样,那上面那种直接使用gi本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshuangnet】t内置连接方式连接的办法就不行了,因为g本文作者:唐霜,转载请注明出处。【原创不易,请尊重版权】it内置的连接办法是ssh的,也就是需要著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】支持22端口(当然,你可以在本机的ssh本文作者:唐霜,转载请注明出处。【访问 www.tangshuang.net 获取更多精彩内容】 config中进行配置,但是,你总不可【本文首发于唐霜的博客】【原创内容,转载请注明出处】能在本地和服务器上都为了git而修改ss本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。h的配置吧。而且,即使这样,你也得让你的【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。网关支持你修改的端口。

【本文受版权保护】未经授权,禁止复制转载。【未经授权禁止转载】【原创不易,请尊重版权】

既然这样,我们就要像github一样,实未经授权,禁止复制转载。【原创内容,转载请注明出处】现一种基于http(s)的服务,这样,在著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。这样的公司内网,就可以通过http(s)转载请注明出处:www.tangshuang.net【版权所有,侵权必究】来拉取和推送代码了。

本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshua【原创不易,请尊重版权】【访问 www.tangshuang.net 获取更多精彩内容】ngnet】著作权归作者所有,禁止商业用途转载。

git支持的http协议,是称为“亚协议原创内容,盗版必究。【原创内容,转载请注明出处】”的http协议方式。这可以在git的官【作者:唐霜】本文作者:唐霜,转载请注明出处。网查到。简单说,就是,你可以把你的仓库放【原创内容,转载请注明出处】原创内容,盗版必究。在一个http请求目录下,然后直接用gi原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。t clone对应的url路径即可。这样本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net,git会根据你提供的路径的协议自己选择【转载请注明来源】【本文受版权保护】使用什么协议来传输文件。

本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshu著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。ang.net本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshua【转载请注明来源】本文作者:唐霜,转载请注明出处。ngnet】

搭建http服务这里就不赘述了,对于ub本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.netuntu服务器而言,直接安装apache【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】2即可。

未经授权,禁止复制转载。【版权所有,侵权必究】

但是就如上一段讲到的,你只能通过http未经授权,禁止复制转载。【作者:唐霜】 clone这个仓库,只能拉取代码,推送转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。代码是无效的。怎么样才能通过http推送【版权所有】唐霜 www.tangshuang.net本文版权归作者所有,未经授权不得转载。代码上去呢?

【版权所有】唐霜 www.tangshu【未经授权禁止转载】【原创不易,请尊重版权】ang.net【版权所有】唐霜 www.tangshu【本文首发于唐霜的博客】转载请注明出处:www.tangshuang.netang.net转载请注明出处:www.tangshua【转载请注明来源】未经授权,禁止复制转载。ng.net本文版权归作者所有,未经授权不得转载。

git提供了一个叫git-http-ba原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。ckend的程序,它可以帮助你实现推送。【关注微信公众号:wwwtangshuangnet】【本文受版权保护】简单的说,它跟php一样,接收你git 【作者:唐霜】【版权所有,侵权必究】push的内容,然后将这些内容写入到服务本文版权归作者所有,未经授权不得转载。【转载请注明来源】器的文件系统。总之,利用这个程序就可以实本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。现git push了。但是,到底要怎么实【转载请注明来源】本文作者:唐霜,转载请注明出处。现呢?

【关注微信公众号:wwwtangshua未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.netngnet】【转载请注明来源】著作权归作者所有,禁止商业用途转载。

其实,你可以这样理解。它就是一段特殊的程转载请注明出处:www.tangshuang.net【未经授权禁止转载】序,就像你要让apache支持php一样【原创不易,请尊重版权】转载请注明出处:www.tangshuang.net,要给apache挂载一个插件(姑且这么【未经授权禁止转载】【原创内容,转载请注明出处】讲吧),这样,当一个请求到达时,就会把这【本文受版权保护】本文作者:唐霜,转载请注明出处。个请求转发给这个程序去处理。

著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshu【原创不易,请尊重版权】转载请注明出处:www.tangshuang.netang.net【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。

你需要在apche2的配置文件中增加这个【本文首发于唐霜的博客】【原创不易,请尊重版权】逻辑。

【作者:唐霜】【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshu本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】ang.net
<VirtualHost *:80>
  SetEnv GIT_HTTP_EXPORT_ALL
  SetEnv GIT_PROJECT_ROOT /home/git/repos
  ScriptAlias / /usr/lib/git-core/git-http-backend/
  DocumentRoot /home/git/repos

  RewriteEngine On
  RewriteCond %{QUERY_STRING} service=git-receive-pack [OR]
  RewriteCond %{REQUEST_URI} /git-receive-pack$
  RewriteRule ^/ - [E=AUTHREQUIRED]
</VirtualHost>

红色部分是关键,GIT_PROJECT_ROOT表示要使用git backend的目录。【版权所有,侵权必究】转载请注明出处:www.tangshuang.net不过,我这个配置完全忽略了和其他服务共存原创内容,盗版必究。【访问 www.tangshuang.net 获取更多精彩内容】的情况,直接采用了/作为ScriptAl【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。ias的路径。你可以根据自己的实际情况进【访问 www.tangshuang.net 获取更多精彩内容】【本文首发于唐霜的博客】行调整。

【版权所有,侵权必究】未经授权,禁止复制转载。【未经授权禁止转载】

简单总结,就是在apache的配置中增加未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.netScriptAlias,通过一个类似al【未经授权禁止转载】原创内容,盗版必究。ias的规则,把一个特定uri下的访问交【原创不易,请尊重版权】原创内容,盗版必究。给git http backen这个程序【版权所有】唐霜 www.tangshuang.net【本文首发于唐霜的博客】去处理,这样,在接收到这个uri的git【未经授权禁止转载】本文作者:唐霜,转载请注明出处。 push请求时,就可以交给这个程序去完【作者:唐霜】未经授权,禁止复制转载。成写入仓库的逻辑。

【关注微信公众号:wwwtangshua【本文受版权保护】【版权所有】唐霜 www.tangshuang.netngnet】本文作者:唐霜,转载请注明出处。

鉴权

接下来要解决的问题是,要阻止别人提交代码未经授权,禁止复制转载。【原创不易,请尊重版权】到你的仓库。你需要设置密码,就像gith本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。ub一样。那要怎么弄呢?

【版权所有】唐霜 www.tangshu原创内容,盗版必究。未经授权,禁止复制转载。ang.net原创内容,盗版必究。【原创不易,请尊重版权】

其实很简单。http的鉴权有两种方式,一【原创不易,请尊重版权】著作权归作者所有,禁止商业用途转载。种是自建权限系统,另一种,是直接利用ht【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。passwd鉴权。无论哪种,都是对每一个【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。请求进行鉴权,在请求交给应用程序去处理之【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshuang.net前先拦截下来,鉴权通过再继续这个流程,否【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。则直接拒绝请求。

转载请注明出处:www.tangshua未经授权,禁止复制转载。【访问 www.tangshuang.net 获取更多精彩内容】ng.net【本文受版权保护】

相对来说,直接利用htpasswd鉴权最【未经授权禁止转载】转载请注明出处:www.tangshuang.net简单。这种鉴权方式传统,到有效。说它传统原创内容,盗版必究。【本文受版权保护】,是因为只有老式的网站通过这种方式使网站【关注微信公众号:wwwtangshuangnet】【作者:唐霜】变为私有网站,进入网站会弹出一个对话框,本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】必须输入正确的用户名和密码才能进入。

【本文受版权保护】【版权所有,侵权必究】

这种鉴权方法对任何http(s)网站都是【版权所有,侵权必究】未经授权,禁止复制转载。通用的,这里说下怎么实现。

本文作者:唐霜,转载请注明出处。【访问 www.tangshuang.n未经授权,禁止复制转载。【转载请注明来源】et 获取更多精彩内容】

先在/home/git目录下执行:

原创内容,盗版必究。【本文受版权保护】【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。
htpasswd -c http.passwd [username]

执行之后,会让你输入密码。这样,就会创建本文版权归作者所有,未经授权不得转载。【本文受版权保护】一个名叫http.passwd的文件,并【未经授权禁止转载】本文作者:唐霜,转载请注明出处。且里面包含了你刚才创建和输入的用户和密码著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。信息。

【访问 www.tangshuang.n原创内容,盗版必究。【转载请注明来源】et 获取更多精彩内容】本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshu本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】ang.net【原创内容,转载请注明出处】

接下来,要在apache配置文件中配置:

【作者:唐霜】本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。
<VirtualHost *:80>
  SetEnv GIT_HTTP_EXPORT_ALL
  SetEnv GIT_PROJECT_ROOT /home/git/repos
  ScriptAlias / /usr/lib/git-core/git-http-backend/
  DocumentRoot /home/git/repos

  <Location />
    AuthType Basic
    AuthName "Git Acess"
    AuthUserFile /home/git/http.passwd
    Require valid-user
    Allow from all
  </Location>

  RewriteEngine On
  RewriteCond %{QUERY_STRING} service=git-receive-pack [OR]
  RewriteCond %{REQUEST_URI} /git-receive-pack$
  RewriteRule ^/ - [E=AUTHREQUIRED]
</VirtualHost>

说到底,这个配置跟git一点关系都没有,【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net它仅不过是apache自带的一种认证方式原创内容,盗版必究。【关注微信公众号:wwwtangshuangnet】

未经授权,禁止复制转载。【版权所有】唐霜 www.tangshu【本文首发于唐霜的博客】转载请注明出处:www.tangshuang.netang.net【版权所有,侵权必究】【访问 www.tangshuang.n【关注微信公众号:wwwtangshuangnet】【原创不易,请尊重版权】et 获取更多精彩内容】

结语

本文解释了利用自己的服务器,给自己提供一【转载请注明来源】【关注微信公众号:wwwtangshuangnet】个在线的git服务的的方法,利用git自【原创不易,请尊重版权】本文作者:唐霜,转载请注明出处。带的功能,提供一个git节点,并通过配置【转载请注明来源】著作权归作者所有,禁止商业用途转载。apache实现可通过http传输的方式本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。,最后,利用apache自己的功能,实现转载请注明出处:www.tangshuang.net【本文受版权保护】http鉴权,这样就可以给自己提供一个在【本文受版权保护】【转载请注明来源】线的git仓库,走到哪里都可以方便地在不【本文首发于唐霜的博客】原创内容,盗版必究。同设备之间同步代码了。

本文作者:唐霜,转载请注明出处。【访问 www.tangshuang.n【原创不易,请尊重版权】未经授权,禁止复制转载。et 获取更多精彩内容】

2018-11-24 16952

为价值买单,打赏一杯咖啡

本文价值169.52RMB