搭建简单的Git服务器
搭建 Git 服务器最重要的是 .git 文件夹和里面的内容,
创建一个裸仓库:
$ git clone --bare my_project/.git myproject.git
该命令等效于:
$ cp -Rf my_project/.git myproject.git
这样就可以取出 仓库 本身,而不是工作目录
然后把 myproject.git 上传到服务器上,若服务器上的路径为 /src/myproject.git
$ git clone user@server.com:/src/myproject.git
通过这个命令就可以拷贝仓库了。在这之前首先要在服务器上设置该 Git 仓库可以共享:
$ cd /src/myproject.git$ git init --bare --shared
另外,也可以用服务器上的 git 用户在服务器上创建一个空的 git 仓库,之后再在本地上将任意一个 git 仓库 push 到服务器上。操作是类似的。
仓库拷贝下来后就有所有的文件都会在当前的目录下面,那么就可以开始项目了。
之后的操作就像使用 GitHub 一样,不过远程仓库并不是在 GitHub 上而是在私有的服务器上。
但是这样的话,在每次 push 或者 pull 操作都需要输入密码。
搭建通过 SSH 访问的 Git 服务器
首先在服务器上添加一个专门用于 git 访问的用户
$ sudo adduser git$ su git$ cd ~$ mkdir .ssh && chmod 700 .ssh$ touch .ssh/authorized_keys && chmod 600 .ssh/authorized_keys
这样就创建了用户 git,并且 git 在 /home 目录下有自己的 HOME 目录。
之后是在 git 的 HOME 目录中创建 .ssh 文件夹和 authorized_keys 文件,权限设置为仅能 git 用户访问。
然后收集需要访问该 Git 服务器上的用户的公钥,一般公钥存放在 id_rsa.pub 文件中:
~/.ssh/id_rsa.pub
若 A 把自己的公钥文件上传到服务器上,用 git 用户添加到 /home/git/.ssh/authorized_keys 这个文件中,那么 A 就可以通过 SSH 访问 git 仓库,而不用再输入密码。
如果需要限制 git 用户的 shell 访问,可以将 /etc/passwd 文件中的 git 那一行的 /bin/bash 改成 /usr/bin/git-shell 就可以限制 git 用户的 shell 登陆了。:
references: