【初识Github】
Git是一个分布式的版本控制系统,最初由Linus Torvalds编写,用作Linux内核代码的管理。在推出后,Git在其它项目中也取得了很大成功,尤其是在Ruby社区中。目前,包括Rubinius和Merb在内的很多知名项目都使用了Git。Git同样可以被诸如Capistrano和Vlad the Deployer这样的部署工具所使用。同样,eoe.cn客户端的源码也托管在github上。
GitHub可以托管各种git库,并提供一个web界面,但与其它像 SourceForge或Google Code这样的服务不同,GitHub的独特卖点在于从另外一个项目进行分支的简易性。为一个项目贡献代码非常简单:首先点击项目站点的“fork”的按钮,然后将代码检出并将修改加入到刚才分出的代码库中,最后通过内建的“pull request”机制向项目负责人申请代码合并。已经有人将GitHub称为代码玩家的MySpace。
在GitHub进行分支就像在Myspace(或Facebook…)进行交友一样,在社会关系图的节点中不断的连线。
GitHub 使用 git 分布式版本控制系统,而 git 最初是 Linus Torvalds 为帮助Linux开发而创造的,它针对的是 Linux 平台,因此 git 和 Windows 从来不是最好的朋友,因为它一点也不像 Windows。GitHub 发布了GitHub for Windows,为 Windows 平台开发者提供了一个易于使用的 Git 图形客户端。
GitHub For Windows
GitHub for Windows 是一个 Metro 风格应用程序,集成了自包含版本的 Git,bash 命令行 shell,PowerShell 的 posh-git 扩展。GitHub 为 Windows 用户提供了一个基本的图形前端去处理大部分常用版本控制任务,可以创建版本库,向本地版本库递交补丁,在本地和远程版本库之间同步。微软也通过CodePlex向开发者提供 git 版本控制系统,而 GitHub 创造了一个更具有吸引力的 Windows 版本。
GitHub上已自动配置的Mac笔记本电脑,一个工具,可以转换设置Linux或Windows机器。
BOXEN是GitHub的自动化工具,设置和配置的Mac笔记本电脑软件开发[3]或其他类型的工作,正在使用他们的开发人员,律师,设计师,付货人,等。我们的想法是准备系统以自动方式和作为无差错尽可能用最少的干预工作。根据GitHub上,与一个新的开发机器上,他的Mac系统成立,并准备在30分钟内提交代码。
BOXEN的基础上收集了大量的几十个木偶模块,使设置的各种软件,如卡桑德拉,MongoDB中,Java软件中,Python和Ruby开发中,节点,JS,nginx的,Skype公司,甚至MINECRAFT。虽然机器上配备了一个预配置,每个用户都可以调整它的配置应有的作用。
【如何使用】
1.注册账户以及创建仓库
要想使用github第一步当然是注册github账号了。之后就可以创建仓库了(免费用户只能建公共仓库),Create a New Repository,填好名称后Create,之后会出现一些仓库的配置信息,这也是一个git的简单教程。
2.安装客户端msysgit
github是服务端,要想在自己电脑上使用git我们还需要一个git客户端,我这里选用msysgit,这个只是提供了git的核心功能,而且是基于命令行的。如果想要图形界面的话只要在msysgit的基础上安装TortoiseGit即可。
装完msysgit后右键鼠标会多出一些选项来,在本地仓库里右键选择Git Init Here,会多出来一个.git文件夹,这就表示本地git创建成功。右键Git Bash进入git命令行,为了把本地的仓库传到github,还需要配置ssh key。
3.配置Git
首先在本地创建ssh key;
ssh-keygen -t rsa -C "[email protected]"
后面的[email protected]改为你的邮箱,之后会要求确认路径和输入密码,我们这使用默认的一路回车就行。成功的话会在~/下生成.ssh文件夹,进去,打开id_rsa.pub,复制里面的key。
回到github,进入Account Settings,左边选择SSH Keys,Add SSH Key,title随便填,粘贴key。为了验证是否成功,在Git bash下输入:
$ ssh -T [email protected]
如果是第一次的会提示是否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 "[email protected]"
新建本地仓库:
在想要存放仓库的根目录下创建本地仓库:
git init [仓库的名字]
或者:
新建一个存放.git(仓库)的文件如(github目录下面的firstday目录):
git init //就会在firstday目录下生成.git仓库文件
进入要上传的仓库(firstday文件),右键git bash,添加远程地址:
$ git remote add origin [email protected]:yourName/yourRepo.git
后面的yourName和yourRepo表示你在github的用户名 和 刚才新建的仓库,加完之后进入.git,打开config,这里会多出一个remote “origin”内容,这就是刚才添加的远程地址,也可以直接修改config来配置远程地址。
-----------------以上就是在git上配置本地仓库的全部步骤-----------------
4.提交、上传
接下来在本地仓库里(firstday目录下)添加一些文件,比如README文件,在原来的firstday目录下Git Bash Here:
$ git touch README
$ git add README
$ git commit -m "first commit"
上传到github:
$ git push -u origin master (这里可能会有报错:请查看git的报错以及解决方法)
如果这里报错:
ERROR: Repository not found.
fatal: Could not read from remote repository.
Please make sure you have the correct access rights
and the repository exists.
说明你的github上找不到helloworld的同名仓库,需创建一个线上的仓库(上面有教程)
切记:如果我们在创建远程仓库的时候添加了README和.ignore等文件(默认在github上创建时自动帮我们创建这两个文件),我们在后面关联仓库后,(上传push前)需要先执行pull操作:
关联仓库命令:$ git remote add origin [email protected]:yourName/yourRepo.git
pull命令:$ git pull -u origin master
再接着上面的操作:
$ git push -u origin master
(这时刷新你的github的helloworld仓库就会看到我们刚刚添加的README文件和 first commit的提交说明了)
git push命令会将本地仓库推送到远程服务器。
git pull命令则相反。
-----------------以上就是Git本地仓库与Github远程仓库关联的全部步骤-----------------
tips:
当本地仓库的文件和线上文件都有修改的时候很容易起代码冲突,问题来了,就是要决解冲突,我在这里就简单的提一下:
在我们在README文件中添加一句话"这是我的本地README文件”保存,
$git add README (添加到暂存区)
$ git commit -m '添加了 这是我的本地README文件 这句话'
如果下面直接执行$ git push origin master (在没有修改远程github上的同名文件时是可提交的,但如果也有修改就要执行下面pull操作再合并本地的代码,否则就会报代码冲突)
假设在github中的README文件中添加了一句话“这是我的github的README文件”保存,
首先我们先pull修改后git远程文件:
$git pull origin master
这时候在打开本地的README文件应该有我们线上和线下修改后的代码,取舍其中需要的代码如把它们合并为“这是我的github的README文件,这是我的本地README文件”,并保存。
$git add README (重新添加到暂存区)
$ git commit -m '添加了 这是我的本地README文件' (重新提交)
最后push到远程仓库上
$ git push origin master
这时候刷新github页面就能看到我们合并后的README文件了。
(修改完代码后,使用git status可以查看文件的差别,使用git add 添加要commit的文件,也可以用git add -i来智能添加文件。)
花了2个晚上学习git,感谢这几位的博主的文章让我受益良多!
常用的git命令传送门:http://www.songyawei.cn/?s=git
学习git图文教程:http://www.jianshu.com/p/dcbb8baa6e36
github入门:http://blog.csdn.net/hcbbt/article/details/11651229
代码冲突:http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/001375840202368c74be33fbd884e71b570f2cc3c0d1dcf000
git我还是新手,根据自己学习过程中遇到的问题和大家分享,避免走这些弯路,如果文章有什么问题还望您指出,我会虚心求教的(●'◡'●)。希望我们共同进步!