版本号控制-搭建gitserver

  GitHub是一个免费托管开源码的Gitserver,假设我们不想公开项目的源码,又不想付费使用。那么我们能够自己搭建一台Gitserver。

  以下我们就看看,怎样在Ubuntu上搭建Gitserver。我们使用VMware虚拟机安装两台Ubantu系统,分别命名为gitServer和gitClient_01。

1、安装OpenSSH并配置SSH无password登陆

  通过命令 sudo apt-get install openssh-server,安装SSH服务。

  通过命令 ps –e|grep ssh,查看ssh服务是否启动。

  通过以上命令,我们为Ubantu系统安装SSH服务。并配置SSH无password登陆。首先我们改动主机和ip配置文件:gedit /ect/hosts

2、创建用户git,用来管理执行git服务。

3、配置无passwordSSH登陆

  在gitClient_01上。我们使用命令:ssh-keygen –t rsa 生成密钥。例如以下图

  完毕之后,在.ssh文件夹下,我们能够看到id_rsa和id_rsa.pub文件。id_rsa.pub为公钥,我们通过命令scp /home/git/.ssh/id_rsa.pub gitServer:/home/git将gitClient_01上生成的公钥复制到gitServer上。

  在gitServer上我们首先查看/home/git/.ssh文件夹下是否存在authorized_kesys文件,

假设没有。能够通过touch authorized_keys创建此文件。

  Authorized_keys创建完毕后,将gitClient_01上拷贝过来的公钥id_rsa.pub的内容追加到authroized_keys中,注意是追加到此文件里,能够使用命令cat /home/git/id_rsa.pub>>/home/git/.ssh/authorized_keys.

  以上内容完毕后。我们在gitClient_01中。能够使用命令ssh gitServer就可以完毕无password登陆。

4、安装Git

  通过命令 sudo apt-get install git-core,安装git

5、建立git仓库的存储文件夹。

6、初始化server端仓库

  使用命令 git –bare init /home/git/myRep.git,初始化化仓库

7、在gitClient_01上,通过git clone命令进行克隆远程仓库。并在各自的电脑上执行开发。

  Git clone
[email protected]:/home/git/myRep.git

  通过以上的步骤我们就完毕了gitserver的搭建。完毕搭建后,我们须要了解一下与gitserver交互过程中所用到命令。主要命令有 git clone、git remote、git fetch、git pull、git push等。以下我们逐一了解

1、git clone

  此命令是我们和远程仓库交互的第一步,通过此命令,我们能够将远程版本号库克隆到本地。如上面第7步我们就使用了此命令,将远程库克隆道了本地。

  语法:git clone 版本号库的网址     本地库名称

  本地库名称能够省略,省略后在本地会生成一个和远程版本号库名字同样的文件夹。

2、git remote

  此命令用于管理远程主机名,此命令在没有參数的情况下能够列出全部主机名。

  显示origin是在使用clone命令,克隆远程版本号库时Git自己主动为远程主机命名。

  通过命令 git remote –v,可查看版本号库的网址。

3、git fetch

此命令能够将远程版本号库的更新,更新到本地库。

语法:git fetch 主机名字

  在默认情况下,git fetch origin将会更新远程主机origin上的全部分支,假设仅仅想更新某个分支,则在主机名origin后面加分支名。

  语法:git fetch origin master

4、git push

  此命令用于将本地分支的更新推送到远程主机。

  语法:git push 远程主机名 本地分支名:远程分支名

  假设省略远程分支名。则表示将本地分支推送与存在终于关系的远程分支,假设远程分支不存在。则会被新建。

  如:git push origin master,表示将本地master分支推送到origin主机的master分支上。

  假设省略本地分子名,则表示要删除远程主机中分支,如git push origin : master,则表示删除origin主机中master分支

5、git pull

  此命令用于获取远程分支中更新。

  语法:git pull 远程主机 远程分支:本地分支如:git pull origin master:master,表示将远程主机origin中的master分支跟新到本地分支master。

  如有疑问咨询或技术交流。请增加官方QQ群: (452379712)

作者:杰瑞教育

出处:http://blog.csdn.net/jerehedu/

本文版权归烟台杰瑞教育科技有限公司和CSDN共同拥有,欢迎转载,但未经作者允许必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

时间: 2024-11-08 23:00:13

版本号控制-搭建gitserver的相关文章

从零開始写游戏引擎(一) - project创建以及文件夹设置还有版本号控制

一句话提要 好的開始等于成功了一半. 创建文件夹结构 project文件夹下最好分为以下几个文件夹 Docs - 开发文档,设计文档 Assets - 角色,动作,模型和音效等 Source - 代码,project文件或者makefile也放在这里,假设有引用第三方的lib,在里面建立一个3rdParty的文件夹,放在里面. Temp - 用于防止编译生成的文件 Lib - 放置编译好的lib文件,将source编译成lib能够更好地保护源码. Game - 用于放置release buid,

EA+svn实现UML的版本号控制

一.安装软件 1.VisualSvn Server svnserver 2.Tortoise Svn svnclient 3.Slik-Subversion-1.7.8-x64版本号控制插件 4.Enterprise Architect 二.设置EA版本号控制 1. 建一个目录作为EA的工作空间 2. 使用SVN检出已有的ea项目到新建的EA工作空间 3. 在EA中新建一个项目,右击Model--Package Controll--Version Controll Settings 当中Uniq

mac 版本号控制工具SmartSVN7.5.4(破解版)

SmartSVN7.5.4和破解工具,下载地址:http://download.csdn.net/detail/pearlhuzhu/7407319 操作步骤: 1.在MAC上选中smartsvn-macosx-10_78-7_5_4.dmg,双击 2.进入iNViSiBLE目录 3.双击syntevo_keygen.jar 假设没有安装java会自己主动提示安装的 4.输入Name Email(随便输入), 注意选对Application下的选项,我用的是SVN所以选Syntevo Smart

Android开发Git版本号控制,究竟哪些文件不要提交

安卓开发的小伙伴们.想必大家在创建项目的时候,都有为project的哪些文件须要提交的git的版本号控制而犯愁过吧.深怕有些文件提交了影响团队其它成员的更新使用.尤其是把一些暂时的编译构建文件给提交了,被Team Leader骂的不要不要的. 下面就是不须要经过git版本号控制来提交的文件和文件夹,详细代码能够查看project的.gitignore文件: IntelliJ IDEA(IDE相关的设置) .idea *.iml *.ipr *.iws Gradle(gradle相关的) .gra

取消SVN版本号控制的bash脚本

原理非常easy,递归删除当前文件夹下全部的 .svn 文件. 把 .svn 换成 .git 就可以用于删除 git 控制 取消SVN版本号控制的bash脚本

[Android]egit取消文件版本号控制

开发项目,多人合作开发变得越来越重要了,在此同一时候,使用git作为协同工具也是越来越多.在此.介绍一下egit取消文件版本号控制的方法. (egit即为eclipse中的git插件) 1.打开Navigator视图(呃. .怎么打开?菜单条中的Window-->Show View-->Navigator)找到相应项目下的.gitignore文件,若没有便能够创建它. 2.双击打开.gitignore文件.在里面加入须要移除版本号控制的文件或目录,比如: 这样便能够实如今commit的时候不再

ASP.NET JS和CSS通过版本号控制缓存

Web.Config里加 <!--JS/CSS版本号控制-->    <add key="jscssVer" value ="1.0.0031"/> 页面CS里加 public string GetVer()     {         string sVer = ConfigurationManager.AppSettings["jscssVer"];         return sVer;     } 页面调用 &l

LINUX总结第13篇:LINUX下动态库及版本号控制

感觉讲得挺详细 注: ln 命令用法 ln –s 源文件 目标文件 (目标文件即为软链接文件) 可用ls -l查看软链接文件具体指向哪个文件 目录[-] 1. File libhello.c 2. File libhello.h 3. File main.c 前言 针对同一动态组件的不同版本链接和加载. 一.概念                  DLL HELL字面意思是DLL"灾难",是由于com组件(动态库)升级引起的程序不能运行的情况.        原因         有三

Git版本号控制:Git分支处理

http://blog.csdn.net/pipisorry/article/details/46958699分支的意义创建分支能够避免提交代码后对主分支的影响,同一时候也使你有了相对独立的开发环境. 假设你准备开发一个新功能.可是须要两周才干完毕,第一周你写了50%的代码,假设立马提交,由于代码还没写完,不完整的代码库会导致别人不能干活了. 假设等代码所有写完再一次提交.又存在丢失每天进度的巨大风险.如今有了分支,就不用怕了.你创建了一个属于你自己的分支.别人看不到,还继续在原来的分支上正常工