【初识Github】
首先让我们大家一起喊一句“Hello Github”。YEAH!就是这样。

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 "your_email@youremail.com"

后面的[your_email@youremail.com](mailto:your_email@youremail.com)改为你的邮箱,之后会要求确认路径和输入密码,我们这使用默认的一路回车就行。成功的话会在~/下生成.ssh文件夹,进去,打开id_rsa.pub,复制里面的key。
回到github,进入Account Settings,左边选择SSH Keys,Add SSH Key,title随便填,粘贴key。为了验证是否成功,在[Git](http://lib.csdn.net/base/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 init [仓库的名字]
或者:
新建一个存放.git(仓库)的文件如(github目录下面的firstday目录):
git init //就会在firstday目录下生成.git仓库文件
进入要上传的仓库(firstday文件),右键[git](http://lib.csdn.net/base/git) bash,添加远程地址:
$ git remote add origin git@github.com: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 git@github.com: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](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我还是新手,根据自己学习过程中遇到的问题和大家分享,避免走这些弯路,如果文章有什么问题还望您指出,我会虚心求教的(●'◡'●)。希望我们共同进步!

转载于:https://www.cnblogs.com/qq240115928/p/7102236.html

github新手入门相关推荐

  1. 【001】GitHub新手入门

    我不明白我这题目怎么标题党了.服了官方. 叨叨在前:这半年应该是开启双线任务.小网站走一步看一步,新的方向也提上日程啦. 01 GitHub学习 首先,需要代理. 其次,需要注册一个账号,可以用Goo ...

  2. github 删除分支_Github新手入门指南

    这篇文章是我入门Github时期记录的笔记,当时主要是参考GitHub入门与实践 (豆瓣)一书,文中有部分内容也来源于此. 个人感觉比较适合新手入门的,感兴趣的朋友可以自行阅读. 前面的简介和Gith ...

  3. GitHub标星2.6万!Python算法新手入门大全

    今天推荐一个Python学习的干货. 几个印度小哥,在GitHub上建了一个各种Python算法的新手入门大全,现在标星已经超过2.6万.这个项目主要包括两部分内容:一是各种算法的基本原理讲解,二是各 ...

  4. GitHub新手用法详解【适合新手入门-建议收藏!!!】

    目录 什么是Github,为什么使用它? 一.GitHub账号的注册与登录 二. gitbash安装详解 1.git bash的下载与安装 2.git常用命令 3. Git 和 GitHub 的绑定 ...

  5. Github新手简单入门图文详解

    Github简单入门使用说明 1 前期准备 1.1 注册GitHub账号 1.2 下载安装Git 1.2.1 下载 1.2.2 安装 2 正式使用 2.1 下载开源的项目 2.2 创建自己的项目 2. ...

  6. Docker新手入门:基本用法

    Docker新手入门:基本用法 1.Docker简介 1.1 第一本Docker书 工作中不断碰到Docker,今天终于算是正式开始学习了.在挑选系统学习Docker以及虚拟化技术的书籍时还碰到了不少 ...

  7. 新手入门指导:Vue 2.0 的建议学习顺序

    起步 1. 扎实的 JavaScript / HTML / CSS 基本功.这是前置条件. 2. 通读官方教程 (guide) 的基础篇.不要用任何构建工具,就只用最简单的 <script> ...

  8. python算法入门_GitHub标星2.6万!Python算法新手入门大全

    问耕 发自 凹非寺 量子位 出品 | 公众号 QbitAI 今天推荐一个Python学习的干货. 几个印度小哥,在GitHub上建了一个各种Python算法的新手入门大全,现在标星已经超过2.6万.这 ...

  9. 【Node】新手入门 基于Express,Sequelize、IIS的MVC项目

    Github项目地址 项目简洁精悍,基本使用功能全部实现,很适合新手入门 功能应用 基于Express开发 token登录验证 数据库模块Sequelize使用 windows server iis部 ...

最新文章

  1. 大学python选择题题库及答案_大学慕课用Python玩转数据题库及答案
  2. 随机算法python_梅森算法生成随机数的Python实现
  3. 喜报!中华万年历签约神策数据
  4. Python学习笔记:I/O编程
  5. sqlserver的技术规格
  6. Access-Control-Allow- 设置跨域资源共享CORS详解
  7. 关于spring mvc时间类型绑定失败解决方法
  8. Tomcat如何配置整个磁盘的映射呢?
  9. 在JavaScript中定义枚举的首选语法是什么? [关闭]
  10. 分布式系统理论(二):一致性协议Paxos
  11. python使用多线程(二)
  12. ARM指令集与Thumb指令集
  13. XP/WIN7系统中删除已结束进程托盘图标的方法
  14. CCS编译错误:error #10099-D和error#10234-D unresolved symbols remain解决方法
  15. SAP用户研讨会嘉宾发言稿——SAP中国产品技术平台咨询经理丁晓枫
  16. 基于Arduino UNO的光驱写字机制作
  17. 什么是云效 Projex,云效Projex企业级高效研发项目管理平台
  18. 福州大学计算机类分专业排名,福州大学a类学科名单-福州大学第四轮学科评估情况...
  19. 解决办法:360压缩解压出现空白文件创建失败,但压缩包文件无损坏显示有十几个文件
  20. python卷积神经网络多元分类_CV4-卷积神经网络之多元分类(剪刀石头布)

热门文章

  1. 老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问。当然,老师有时候需要更新某位同学的成绩. 输入描述:
  2. 贴纸UI效果如何制作,4个做贴纸效果的小技巧
  3. 项目初始化及文件配置-黑马头条PC
  4. 计算机毕业设计基于Android平台的公交线路查询系统app
  5. 【Devc++】战斗1.0.1
  6. 二分搜索的时间复杂度分析
  7. LVGL官方文档-7.11.0-5-Porting-Input device interface
  8. 计算机科学 vs 计算机技术
  9. Unity3D学习 ③ 摄像机视角跟随
  10. java 读取 解析微软Project .mpp 文件到甘特图