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

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

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

【原创内容,转载请注明出处】【关注微信公众号:wwwtangshua【转载请注明来源】【未经授权禁止转载】ngnet】

搭建git服务

搭建一台git服务非常方便,去腾讯云购买未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.net最便宜的云服务器。我喜欢ubuntu,所本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net以下面都是在ubuntu的服务器上作业。本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。git是点对点的服务,所以,搭建一台gi【转载请注明来源】【转载请注明来源】t服务超级简单,你都不需要做任何操作,系【转载请注明来源】【版权所有,侵权必究】统自带了git。如果系统不自带git,用本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net内置的安装命令安装它就可以了。

转载请注明出处:www.tangshua【版权所有,侵权必究】【未经授权禁止转载】ng.net【原创不易,请尊重版权】著作权归作者所有,禁止商业用途转载。

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

【原创内容,转载请注明出处】【本文首发于唐霜的博客】【本文首发于唐霜的博客】

在服务器上一个比较好记的路径下创建一个空【本文受版权保护】转载请注明出处:www.tangshuang.net目录,在该目录下执行:

本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshua【转载请注明来源】【未经授权禁止转载】ng.net
git init --bare

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

【转载请注明来源】未经授权,禁止复制转载。

也就是说,无论是用—bare创建的裸库,本文版权归作者所有,未经授权不得转载。【未经授权禁止转载】还是直接生成的.git目录,都可以被别人【转载请注明来源】本文版权归作者所有,未经授权不得转载。克隆和推送。

【关注微信公众号:wwwtangshua本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】ngnet】著作权归作者所有,禁止商业用途转载。【本文受版权保护】【转载请注明来源】

当我们在服务器上创建一个仓库之后,其他节未经授权,禁止复制转载。【本文首发于唐霜的博客】点就可以通过ssh或http(s)连接和转载请注明出处:www.tangshuang.net【版权所有,侵权必究】拉取、推送了:

【访问 www.tangshuang.n本文作者:唐霜,转载请注明出处。【本文受版权保护】et 获取更多精彩内容】转载请注明出处:www.tangshua【转载请注明来源】本文版权归作者所有,未经授权不得转载。ng.net
git clone user1@127.0.0.1:/home/user1/gittest

上面的连接方式基于ssh,user1是s【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。sh登陆用户,@后面是主机地址,:后面是【作者:唐霜】本文作者:唐霜,转载请注明出处。git仓库目录的路径。执行上面命令后,会【本文受版权保护】【版权所有,侵权必究】要求你输入主机上user1的密码,这样就本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.net可以把远程的仓库克隆到本地当前目录下。

【访问 www.tangshuang.n【访问 www.tangshuang.net 获取更多精彩内容】【本文首发于唐霜的博客】et 获取更多精彩内容】【原创内容,转载请注明出处】【转载请注明来源】【关注微信公众号:wwwtangshua本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】ngnet】

启用http服务

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

【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。

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

【原创不易,请尊重版权】【原创不易,请尊重版权】【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshu转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】ang.net

git支持的http协议,是称为“亚协议【本文受版权保护】【本文首发于唐霜的博客】”的http协议方式。这可以在git的官【关注微信公众号:wwwtangshuangnet】原创内容,盗版必究。网查到。简单说,就是,你可以把你的仓库放【访问 www.tangshuang.net 获取更多精彩内容】【转载请注明来源】在一个http请求目录下,然后直接用gi未经授权,禁止复制转载。未经授权,禁止复制转载。t clone对应的url路径即可。这样【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。,git会根据你提供的路径的协议自己选择【版权所有,侵权必究】未经授权,禁止复制转载。使用什么协议来传输文件。

未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】

搭建http服务这里就不赘述了,对于ub未经授权,禁止复制转载。【原创不易,请尊重版权】untu服务器而言,直接安装apache【访问 www.tangshuang.net 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。2即可。

【原创内容,转载请注明出处】【访问 www.tangshuang.n【关注微信公众号:wwwtangshuangnet】【作者:唐霜】et 获取更多精彩内容】

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

【访问 www.tangshuang.n转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。et 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。

git提供了一个叫git-http-ba著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】ckend的程序,它可以帮助你实现推送。本文作者:唐霜,转载请注明出处。【原创不易,请尊重版权】简单的说,它跟php一样,接收你git 【原创内容,转载请注明出处】【版权所有,侵权必究】push的内容,然后将这些内容写入到服务【转载请注明来源】【版权所有,侵权必究】器的文件系统。总之,利用这个程序就可以实【访问 www.tangshuang.net 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。现git push了。但是,到底要怎么实本文作者:唐霜,转载请注明出处。原创内容,盗版必究。现呢?

本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshua未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.netng.net【原创不易,请尊重版权】转载请注明出处:www.tangshua【版权所有】唐霜 www.tangshuang.net【转载请注明来源】ng.net

其实,你可以这样理解。它就是一段特殊的程【关注微信公众号:wwwtangshuangnet】【原创内容,转载请注明出处】序,就像你要让apache支持php一样【本文受版权保护】原创内容,盗版必究。,要给apache挂载一个插件(姑且这么【本文首发于唐霜的博客】【本文首发于唐霜的博客】讲吧),这样,当一个请求到达时,就会把这【访问 www.tangshuang.net 获取更多精彩内容】【作者:唐霜】个请求转发给这个程序去处理。

转载请注明出处:www.tangshua转载请注明出处:www.tangshuang.net【版权所有,侵权必究】ng.net著作权归作者所有,禁止商业用途转载。【访问 www.tangshuang.n著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。et 获取更多精彩内容】【原创不易,请尊重版权】

你需要在apche2的配置文件中增加这个【关注微信公众号:wwwtangshuangnet】【转载请注明来源】逻辑。

著作权归作者所有,禁止商业用途转载。【本文受版权保护】【原创不易,请尊重版权】
<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的目录。【转载请注明来源】本文版权归作者所有,未经授权不得转载。不过,我这个配置完全忽略了和其他服务共存本文版权归作者所有,未经授权不得转载。【本文受版权保护】的情况,直接采用了/作为ScriptAl【未经授权禁止转载】原创内容,盗版必究。ias的路径。你可以根据自己的实际情况进【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】行调整。

原创内容,盗版必究。【转载请注明来源】

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

本文作者:唐霜,转载请注明出处。【本文受版权保护】本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。

鉴权

接下来要解决的问题是,要阻止别人提交代码【版权所有】唐霜 www.tangshuang.net【关注微信公众号:wwwtangshuangnet】到你的仓库。你需要设置密码,就像gith本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.netub一样。那要怎么弄呢?

【原创内容,转载请注明出处】【本文受版权保护】【转载请注明来源】

其实很简单。http的鉴权有两种方式,一【关注微信公众号:wwwtangshuangnet】【关注微信公众号:wwwtangshuangnet】种是自建权限系统,另一种,是直接利用ht本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】passwd鉴权。无论哪种,都是对每一个【关注微信公众号:wwwtangshuangnet】【原创内容,转载请注明出处】请求进行鉴权,在请求交给应用程序去处理之转载请注明出处:www.tangshuang.net原创内容,盗版必究。前先拦截下来,鉴权通过再继续这个流程,否【作者:唐霜】原创内容,盗版必究。则直接拒绝请求。

转载请注明出处:www.tangshua【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。ng.net【转载请注明来源】

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

【作者:唐霜】【未经授权禁止转载】【本文受版权保护】

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

【版权所有,侵权必究】未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshu【本文首发于唐霜的博客】【原创内容,转载请注明出处】ang.net

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

转载请注明出处:www.tangshua转载请注明出处:www.tangshuang.net【原创不易,请尊重版权】ng.net未经授权,禁止复制转载。【版权所有,侵权必究】原创内容,盗版必究。
htpasswd -c http.passwd [username]

执行之后,会让你输入密码。这样,就会创建【本文受版权保护】本文作者:唐霜,转载请注明出处。一个名叫http.passwd的文件,并本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.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一点关系都没有,【本文首发于唐霜的博客】【关注微信公众号:wwwtangshuangnet】它仅不过是apache自带的一种认证方式原创内容,盗版必究。【未经授权禁止转载】

【本文受版权保护】转载请注明出处:www.tangshua原创内容,盗版必究。本文作者:唐霜,转载请注明出处。ng.net【版权所有】唐霜 www.tangshu转载请注明出处:www.tangshuang.net【本文受版权保护】ang.net著作权归作者所有,禁止商业用途转载。

结语

本文解释了利用自己的服务器,给自己提供一【访问 www.tangshuang.net 获取更多精彩内容】转载请注明出处:www.tangshuang.net个在线的git服务的的方法,利用git自本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。带的功能,提供一个git节点,并通过配置本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】apache实现可通过http传输的方式原创内容,盗版必究。【转载请注明来源】,最后,利用apache自己的功能,实现【原创不易,请尊重版权】【版权所有】唐霜 www.tangshuang.nethttp鉴权,这样就可以给自己提供一个在【作者:唐霜】转载请注明出处:www.tangshuang.net线的git仓库,走到哪里都可以方便地在不本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】同设备之间同步代码了。

【本文首发于唐霜的博客】转载请注明出处:www.tangshua【本文首发于唐霜的博客】【作者:唐霜】ng.net【未经授权禁止转载】

2018-11-24 17017

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

本文价值170.17RMB