Git服务搭建多见于linux环境,但windows主机也不少,目前网上文章诸多不全,且以讹传讹,不甚清楚。下面介绍windows环境下的自动部署和发布。
所需环境及资源:Java环境、Gitblit;示例服务器环境:windows server 2012
一、Java环境的安装
1)下载JRE安装包
windows环境下使用GitBlit,必须安装Java环境,而Java环境可采用JRE或JDK两种方式安装,这里采用JRE的方式,其安装包相对JDK也要小不少,若已安装JDK环境可忽略。
JRE安装包传送门https://www.java.com/zh_CN/download,根据需要下载合适的版本,大约七八十M,下载完后安装。
2)设置环境变量
这里以JRE为例,右键这台电脑 => 属性 => 高级系统设置 => 高级 => 环境变量 => 系统变量。
当前Java的安装目录如下:C:\Program Files\Java\jre1.8.0_261
新建变量名:JAVA_HOME,变量值:C:\Program Files\Java
新建变量名:CLASS_PATH, 变量值:.;%JAVA_HOME%\jre1.8.0_261\lib
编辑变量名:Path,在已有值的最后添加 :;%JAVA_HOME%\jre1.8.0_261\bin;
在命令行中运行 java -version ,看到输出版本号即安装成功。
二、下载GitBlit并解压(无需安装)
GitBlit下载地址:http://www.gitblit.com/,选择windows版本。下载后解压到目录如:E:\software\gitblit-1.9.1
1)新建空文件夹,如:E:\MyGit,用来存放项目(目前测下来依然跑到Gitblit目录下去了,有兴趣的同学可以看看);
2)进入E:\software\gitblit-1.9.1\data目录,编辑defaults.properties文件:
设置http端口,这里写了推荐的8080,httpBindInterface不用设置保留为空,方便后续本地、外网IP皆可访问
3)gitblit目录双击运行gitblit.cmd
4)浏览器访问http://localhost:8080,登录账户、密码均为:admin
5)设置Gitblit以服务方式启动(关闭命令行后,Gitblit会随之关闭)
5.1 编辑Gitblit目录下的installService.cmd文件,如图所示:
5.2 修改保存后,打开windows命令行窗口,进入到GitBlit根目录,运行installService.cmd
命令一:cd E:\software\gitblit-1.9.1
命令二:installService.cmd
5.3 鼠标右键Gitblit目录下的gitblitw.exe文件,作类似如下设置(根据自己的安装目录):
5.4 点击应用,回到General,点击start(已启动将为灰色),确定
5.5 windows+R,运行输入services.msc,找到gitblit,确保设置启动,且为自动模式。
三、Gitblit使用
1)admin登录后,创建版本库,如test、添加用户如testuser;而后可通过编辑版本库或编辑用户设置相应的版本库权限,这里以RWD权限为例,权限过低如R将导致提交不了git更新
2)回到本地,外网IP地址访问方式,登录创建的用户testuser,点击挂载的版本库(注意端口29418,以前前面步骤的8080等端口:服务器防火墙以及云服务器安全组均需开启相关端口)
至此,即可通过git方式clone该版本库,该方式每次提交更新需输入密码,可采取添加SSH Key方式免提提交;本地客户端生成SSH Key,可采用Git Gui或命令生成Key:
1、GUI生成SSH Key
2、命令生成Key
ssh-keygen -t rsa -C "abc@163.com",-C后内容为指定注释,标识秘钥,可输入邮箱或其他信息
注:如本机已有生成key,一般可到C:\Users\Administrator\.ssh下查看d_rsa.pub公钥文件
3)设置SSH Key
以testuser为外网IP登录Gitblit,将生成的Key复制粘贴到SSH Keys中,添加后即可免密提交Git。
四、Gitblit自动部署Web目录
为方便用户Git提交后,自动部署到Web站点目录,这里采用Gitblit的hook post-receive方式实现;
1)打开Gitblit目录下的data/groovy目录,如:E:\software\gitblit-1.9.1\data\groovy,复制localclone.groovy文件,重新命名为如:autoclone.groovy,修改其中内容如下:
import com.gitblit.GitBlit
import com.gitblit.Keys
import com.gitblit.models.RepositoryModel
import com.gitblit.models.TeamModel
import com.gitblit.models.UserModel
import com.gitblit.utils.JGitUtils
import com.gitblit.utils.StringUtils
import java.text.SimpleDateFormat
24 import org.eclipse.jgit.api.PullCommand
25 import org.eclipse.jgit.api.CloneCommand
import org.eclipse.jgit.api.Git
import org.eclipse.jgit.lib.Repository
import org.eclipse.jgit.lib.Config
import org.eclipse.jgit.revwalk.RevCommit
import org.eclipse.jgit.transport.ReceiveCommand
import org.eclipse.jgit.transport.ReceiveCommand.Result
import org.eclipse.jgit.util.FileUtils
import org.slf4j.Logger // Indicate we have started the script
logger.info("localclone hook triggered by ${user.username} for ${repository.name}") def rootFolder = 'E:/release/wwwroot'
def bare = false
def cloneAllBranches = true
def cloneBranch = 'refs/heads/master'
def includeSubmodules = true def repoName = repository.name
def destinationFolder = new File(rootFolder, StringUtils.stripDotGit(repoName))
def srcUrl = 'file://' + new File(gitblit.getRepositoriesFolder(), repoName).absolutePath if (destinationFolder.exists()) {
89
90 Git git = Git.open(destinationFolder)
91 //调用 pull 类下的 pull 方法
92
93 PullCommand cmd = git.pull()
94 //设置对象分支
95 cmd.setRemoteBranchName(cloneBranch)
96 //执行
97 cmd.call()
98 //关闭
99 git.close()
100 logger.info("File update succeeded")
101 clientLogger.info("File has been updated")
102
103 }else{
104
105 // delete any previous clone
106 // clone the repository
107 logger.info("cloning ${srcUrl} to ${destinationFolder}")
108 CloneCommand cmd = Git.cloneRepository();
109 cmd.setBare(bare)
110 if (cloneAllBranches)
111 cmd.setCloneAllBranches(true)
112 else
113 cmd.setBranch(cloneBranch)
114 cmd.setCloneSubmodules(includeSubmodules)
115 cmd.setURI(srcUrl)
116 cmd.setDirectory(destinationFolder)
117 Git git = cmd.call();
118 git.repository.close()
119
120 // report clone operation success back to pushing Git client
121 clientLogger.info("${repoName} cloned to ${destinationFolder}")
122 }
注意红标引用及相关代码:
rootFolder = 'E:/release/wwwroot',此处为你的站点根目录,当有git提交时,将触发钩子,判断是否已存在git仓储目录,存在则pull,不存在则clone;
初始化配置时,建议wwwroot下不要存在任何文件或目录,一切交由Gitblit自行处理,用户git提交后,wwwroot目录将会clone具体的仓储目录,如test(E:/release/wwwroot/test,同时该目录也是Nginx或IIS站点的具体指向路径)。 2)设置钩子文件到具体的版本库
以拥有相关版本库编辑权限的账户登录Gitblit,编辑版本库 => receive => post-receive,添加前面设置的aotoclone到Selected列表:
至此,用户Git提交新版本后,即可及时浏览到最新的发布站点。