`
什么世道
  • 浏览: 219331 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

让GitHub托管代码吧

阅读更多

    有时我们一个团队在做项目时,可能有一个明确的分工,每个成员做一个部分,并对该部分进行测试然后实现该部分的功能,到最后所有部分整合在一起。那么,将所有部分整合在一起是一个极需要时间和空间配合的环节。用U盘拷贝?在线或者离线发送?too old too trouble!!!

 

    假如每一步都需要良好的整合?那么每次整合对所有成员来说都是泪流满面啊!!!程序员岂不华丽转身变为程序猿? 

 

    那么,这里就不得不提到数据仓库托管。数据仓库可以实时得共享数据,团队成员可以对代码的上传,更新以及下载。这对于团队项目是一个莫大的惊喜,大大节约了团队开发的时间和精力。

 

    当然,现在网上有很多的数据仓库托管工具。其中用的比较多的是GitHub和SVN。本博文主要介绍GitHub的入门使用,对于老鸟可以跳过。假如对数据安全比较敏感并且不嫌架设 Git 服务器麻烦,那就自己上手年搭建Git服务器托管吧~~~

 

托管步骤:

(一) 在GitHub上注册一个账号,已注册的跳过第一步

注册地址:https://github.com/

 

(二) 新建一个远端仓库(Repository),仓库的类型定为SSH



 

 

 

 

(三)安装客户端GithubWindows

    github是服务端,要想在自己电脑上使用git我们还需要一个git客户端,我这里选用msysgit,这个只是提供了git的核心功能,而且是基于命令行的。下载地址:http://code.google.com/p/msysgit/

 

   装完msysgit后右键鼠标会多出一些选项来,在本地仓库里右键选择Git Init Here,会多出来一个.git文件夹,这就表示本地git创建成功。右键Git Bash进入git命令行,为了把本地的仓库传到github,还需要配置ssh key。

 

(四) 建立本地SSH key,并在GitHub上设置SSH key,配置Git

    打开git bash:  

    首先在本地创建ssh key;     

 
$ ssh-keygen -t rsa -C "your_email@youremail.com"

    后面的your_email@youremail.com改为你的邮箱,之后会要求确认路径和输入密码,我们这使用默认的一路回车就行。成功的话会在~/下生成.ssh文件夹,进去,打开id_rsa.pub,复制里面的key。

 

    回到github,进入Account Settings,左边选择SSH Keys,Add SSH Key,title随便填,粘贴key。为了验证是否成功,在git bash下输入:

 

 
$ ssh -T git@github.com

 

    如果是第一次的会提示是否continue,输入yes就会看到:You’ve successfully authenticated, but GitHub does not provide shell access 。这就表示已成功连上github。

    接下来我们要做的就是把本地仓库传到github上去,在此之前还需要设置username和email,因为github每次commit都会记录他们。

$ git config --global user.name "your name"
$ git config --global user.email "your_email@youremail.com"

 

进入要上传的仓库,右键git bash,添加远程地址:

 
$ git remote add origin git@github.com:yourName/yourRepo.git
 

后面的yourName和yourRepo表示你再github的用户名和刚才新建的仓库,加完之后进入.git,打开config,这里会多出一个remote “origin”内容,这就是刚才添加的远程地址,也可以直接修改config来配置远程地址。

 

 

(五)提交、上传数据。

接下来在本地仓库里添加一些文件,比如README,

 
$ git add README
$ git commit -m "first commit"

上传到github:

 
$ git push origin master

git push命令会将本地仓库推送到远程服务器。
git pull命令则相反。在此就不班门弄斧了、

 

上传文件夹:

先输入cd命令跳转到需要上传的文件夹目录:然后依次输入一下命令。

 

以我当前目录所有文件上传到ARvision组织下的ARball数据仓库中为例:

git init

git add .(小数点,还有空格哟)

git commit -m "first commit"

git remote add origin git@github.com:ARvision/ARball.git

git push -u origin master

 

 

 

解释下输入的命令:

1)touch README.md文件是关于工程代码的介绍,类似与使用说明书

2)git init  初始化一个本地的 git仓库,生成隐藏的.git目录(隐藏的.git目录可使用ls -aF命令可以查看到)

3)git add  README.md  把README.md文件添加到仓库中

4)git commit -m "first commit"  执行提交说明,在Gitz中这个属于强制性的

5)git remote add origin git@github.com:ARvision/ARball.git   添加本地仓库origin和指定远程仓库地址

6)git push origin master  推送本地仓库到远程指定的master分支上

 

 

 那么就完成了整个上传过程了。

 

 

(六)Git ignore文件

   gitignore顾名思义就是告诉git需要忽略的文件,这是一个很重要并且很实用的文件。一般我们写完代码后会执行编译、调试等操作,这期间会产生很多中间文件和可执行文件,这些都不是代码文件,是不需要git来管理的。我们在git status的时候会看到很多这样的文件,如果用git add -A来添加的话会把他们都加进去,而手动一个个添加的话也太麻烦了。这时我们就需要.gitignore了。比如一般c#的项目我的.gitignore是这样写的:

 
bin
*.suo
obj

bin和obj是编译目录,里面都不是源代码,忽略;suo文件是vs2010的配置文件,不需要。这样你在git status的时候就只会看到源代码文件了,就可以放心的git add -A了。

 

 

(七)tag标签

   我们可以创建一个tag来指向软件开发中的一个关键时期,比如版本号更新的时候可以建一个“v2.0”、“v3.1”之类的标签,这样在以后回顾的时候会比较方便。tag的使用很简单,主要操作有:查看tag、创建tag、验证tag以及共享tag。

7.1查看tag

列出所有tag:

 
git tag

这样列出的tag是按字母排序的,和创建时间没关系。如果只是想查看某些tag的话,可以加限定:

 
git tag -l v1.*

这样就只会列出1.几的版本。

7.2创建tag

创建轻量级tag:

 
git tag v1.0

这样创建的tag没有附带其他信息,与之相应的是带信息的tag:

 
git tag -a v1.0 -m 'first version'

-m后面带的就是注释信息,这样在日后查看的时候会很有用,这种是普通tag,还有一种有签名的tag:

 
git tag -s v1.0 -m 'first version'

前提是你有GPG私钥,把上面的a换成s就行了。除了可以为当前的进度添加tag,我们还可以为以前的commit添加tag:

 
#首先查看以前的commit
git log --oneline
#假如有这样一个commit:8a5cbc2 updated readme
#这样为他添加tag
git tag -a v1.1 8a5cbc2

7.3删除tag

很简单,知道tag名称后:

 
git tag -d v1.0

7.4验证tag

如果你有GPG私钥的话就可以验证tag:  

 
git tag -v v1.0

7.5共享tag

我们在执行git push的时候,tag是不会上传到服务器的,比如现在的github,创建tag后git push,在github网页上是看不到tag的,为了共享这些tag,你必须这样: 

 
git push origin --tags

 

 

 

参考资料:http://blog.csdn.net/chun799/article/details/8679212

http://wuyuans.com/2012/05/github-simple-tutorial/

 

 

 

1
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics