Linux构建Git代码仓库与自动部署

git

Git是用于Linux内核开发的版本控制工具。与CVS、Subversion一类的集中式版本控制工具不一样,它采用了分布式版本库的做法,不须要服务器端软件,就能够运做版本控制,使得源代码的发布和交流极其方便。Git的速度很快,这对于诸如Linux内核这样的大项目来讲天然很重要。git最为出色的是它的合并追踪(merge tracing)能力。html

维基上关于git的解释,连接:https://zh.wikipedia.org/wiki/Gitgit

构建Git仓库的方式便可以在本地直接生成,也能够本身搭建一个Git服务器,本文介绍在Linux服务器上如何构建一个Git代码仓库。Let's Start!vim

Git server

  1. 建立一个git用户(专门的git用户用于git链接,限制只能处理代码等操做)
$ adduser git
复制代码
  1. opt目录下建立一个文件夹code
$ mkdir /opt/code
复制代码
  1. 进入文件夹后建立一个git空仓
$ cd code
    $ git init --bare test.git
复制代码
  1. 查看git仓库目录结构
$ cd test.git
复制代码

目录

  • HEAD:指示目前被检出的分支
  • config:包含项目特有的配置选项
  • description:仅供 GitWeb 程序使用
  • hooks:包含客户端或服务端的钩子脚本(hook scripts)
  • info:包含一个全局性排除(global exclude)文件,用以放置那些不但愿被记录在 .gitignore 文件中的忽略模式(ignored patterns)
  • objects:存储全部数据内容
  • refs:存储指向数据(分支)的提交对象的指针

自动部署函数

进入hooks中建立一个函数(当接收传送时自动调用的钩子),实现当代码更新时服务端运行代码同步更新(此步骤仅做自动化部署方案参考,实际运行环境应根据需求后使用)。bash

$ cd hooks
    $ vim post-receive
复制代码

内容为重写指定工做区文件,代码以下服务器

#!/bin/bash
git --work-tree=/www/wwwroot/test checkout -f
复制代码

实际状况应将‘/www/wwwroot/test’替换为目标项目位置,此目录git用户需有权限并发

chown -R git:root /www/wwwroot/test
复制代码

最后给post-receive文件执行权限分布式

chmod +x post-receive
复制代码

具体钩子建立与否需根据项目具体实现作不一样的调整,某些大厂的代码管理是用专门的服务器进行管理,在网页控制分支合并发布,一键部署等,抽象出版本管理这层,以便代码的发布,不知道你们都是怎么实现版本迭代,分支管理的呢?(若是仍是手动搬运代码就能够试着实现本身的自动化部署啦~)svn

Git client

  1. 将存储库(将IP替换为仓库ip地址)克隆到新目录(可用git BASH客户端使用),也可直接在服务器上使用,输入git clone /opt/code/test.git
$ git clone git@IP:/opt/code/test.git
复制代码
  1. 进入新建立的目录中,接着建立测试文件,代码以下
$ cd test
    $ touch index.html
复制代码
  1. 上传到仓库中,代码以下
$ git add .
    $ git commit -m 'create index.html'
    $ git push
复制代码
  1. 进入以前指定的工做区文件夹查看代码是否提交成功,或经过重复步骤一克隆一份新代码,若测试文件存在则成功。

如发生错误,有的多是由于用户权限的缘由,经过chmod命令配置权限给git用户便可函数

后记

现现在代码管理已发展了诸多工具(如svn,cvs),代码托管平台(如Github,Gitlab)可供选择,要说的话,代码如同货物,适合的版本管理如同高度自动化的船舶,仅需少数船员,便可驾驶着轮船稳健驶向新航线,提升效率,迎接新世纪。工具

\(•ㅂ•)/♥ 共勉~