操作系统是Ubuntu 16.04 LTS 64bit

1 安装git

  (1)安装

sudo apt-get install git-core

  (2)一些全局变量的初始化

  在本地建立一个文件夹,然后做一些全局变量的初始化

git config --global user.name 用户名或者用户ID

git config --global user.email 你邮箱

  这两个选项会在以后你提交代码至本地仓库时自动填写到你的提交记录中去。

2 使用git版本管理器本地管理你的项目

  (1)进入你项目的目录,进行git初始化,创建.git文件夹

git init

  执行后,你发现你的项目中多了一个.git隐藏文件夹。这样,你的本地仓库就已经建立好了。

  (2)管理哪此文件将被提交至中

  

  如上,git status命令显示了哪些文件将被提交至git中(绿色),哪此文件将会被untracked(红色)。我们可以能过git add和git rm来管理这些文件。

  (3)提交你的代码至git版本管理器

git commit -m 'first commit'

  使用git show命令可以查看到你的提交记录:

  

3 配置github SSH

  SSH是什么?SSH是Secure Shell,是一种认证方式,github可以采用两种认证方式:SSH和https。两种的区别是SSH需要进行SSH key配置,但是每次Pull的时候是不需要输入用户名密码的,而https每次都要输入用户名密码的。

  (1)检测是否能连接到github

ssh -T git@github.com

如果看到:
          Warning: Permanently added ‘github.com,204.232.175.90’ (RSA) to the list of known hosts.
          Permission denied (publickey).
则说明可以连接。

(2)创建本地SSH Key

ssh-keygen -t rsa -C "your_email"

  ~/.ssh目录下生成id_rsa(私钥)和id_rsa.pub(公钥)文件。

  (3)将此密钥(public key)上传至github

  同志。一定要有自己的github账户呀。没有的话就去官网注册一个。在网页版github中,依次点击Account settings(右上角倒数第二个图标) -> SSH Keys -> Add SSH Key,将id_rsa.pub文件中的字符串复制进去,注意字符串中没有换行和空格。

  (4)测试密钥是否成功

  与第一步相同:

ssh -T git@github.com

  如果看到:Hi xxx! You’ve successfully authenticated, but GitHub does not provide shell access,则密钥上传成功。

4  push本地git仓库至github仓库

  (1)首先,我们要在github中建造一个public仓库。去网页版傻瓜式操作。

  (2)本地git中设置远程github的仓库的url。如上节所讲,有两种方式:

    1)Https方式  

git remote add origin https://github.com/AndyQiao/makefile_test.git

    2)SSH方式

git remote add origin git@github.com:AndyQiao/makefile_test.git

  注意,这里的origin是远程仓库的一个别名,是任意的。我们之后向远程仓库里同步时,就使用这个别名。推荐origin作为所有项目的远程仓库的别名,这样就不会忘记了。不过。我们也可以使用git remote -v来查看:

  (3)push本地git至github远程仓库

git push origin master

  注意:(1)master指的是分支(branch)名字。一个仓库中默认的分支名字就是master,以后,你可以有别的branch;(2)如果上一步使用的是SSH方式,那么命令就直接执行,如果使用Https方式,则每次push都需要输入密码

5 pull、fetch与clone

  pull与push相反,是将代码从远程仓库同步至本地仓库并merge的命令

git pull origin master

  而fetch是单纯将代码从远程仓库同步至本地仓库,并不作merge。

git fetch
git diff origin/master
git merge origin

三个步骤分别代表:取远程仓库至本地,保存版本号至.git/FETCH_HEAD;比较远程origin/master分支与本地差别;将远程origin/master merge至本地仓库。与直接pull相比,fetch后可以直观看到远程仓库的不同,再决定是否要merge,更加安全。

  clone不是同步,而类似于下载。我们不仅可以clone自己的仓库,还可以clone别人的仓库,只需要知道相应的URL即可  

git clone git@github.com:AndyQiao/makefile_test.git code1

  注:code1是目标文件夹。

  git还是很牛逼的。不过有些项目用SVN更方便一些。以前在Window下编程我都用SVN的。要好好学习一下git!下午查各种资料,各种试验,再写博客,收获很多。加油。

6 log

  git log命令展示远程仓库的提交历史,-p选项展示每次提交的修改情况,-2选项展示最近两次提交历史

7 stash与stash pop

  git stash命令可以次工作区设置为上次提交后的情况,方便中途处理重要情况,之后通过stash pop将工作区恢复至之前的状况。

git与github安装、配置、pull、push的更多相关文章

  1. GitHub安装配置

    GitHub安装配置1.安装Git-1.9.5-preview20141217 2.配置config文件Windows(在命令行下)cd /d %userprofile%if not exist &q ...

  2. Git介绍及安装配置

    一.概述 1.1git概念 Git是一个开源的分布式版本控制系统,用于敏捷高效处理任意规模的项目,其作者为Linux创造者Linus Torvalds为管理Linux内核而开放的一个开源的版本控制柔软 ...

  3. CentOS6.4下Git服务器Gitosis安装配置

    1.安装GIt: #yum install git 2.增加一个git用户 #useradd git #passwd git 3.创建git仓库存储目录,设置权限 #mkdir /home/git/r ...

  4. git 连接github的配置

    这段时间要先在git上开发,上传代码到github上,所以首先需配置本地的git和github. 这几篇文章都不错,可以参考一下,大体的配置都很清楚. 1:https://blog.csdn.net/ ...

  5. GitHub 安装配置

    1:到 Github 注册 页面中注册,填写用户名.邮箱和密码 选择免费服务 步骤三可以根据自身喜好勾选或者直接跳过 2.1.2 创建远程仓库 创建完账号后,可以开始创建仓库 但是这里我们还没有验证邮 ...

  6. 【学习总结】Git学习-本地仓库覆盖式更新对于Git仓库的影响以及pull/push到GitHub

    < 许久不用Git之后的探索 > 准备日常更新自己的GitHub了.但是编写的文件平时不放在Git仓库路径下. 故测试覆盖式更新对于仓库是否有影响 直接说结论: 通过对已有库的测试发现覆盖 ...

  7. Git 学习之--安装配置GitHub

    楼主今天学习了一下Git的使用,而且Androdi studio 下加入了Git插件,成功提交项目到自己Github个人主页 watermark/2/text/aHR0cDovL2Jsb2cuY3Nk ...

  8. Git教程之安装配置(1)

    1.Git是什么? Git是目前世界上最先进的分布式版本控制系统. 2.SVN与Git的最主要的区别? SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而干活的时候,用的都是自己的电脑,所以 ...

  9. git简介及安装配置

    Git是一种分布式版本控制系统.它和集中式版本控制系统的区别有如下几点: 1).分布式版本控制没有中央服务器,每个人的电脑上都有完整的版本库: 2).分布式管理系统的安全性要高,如果某一台电脑的坏了, ...

随机推荐

  1. Visual Studio Code,完美的编辑器

    今日凌晨,微软的文本(代码)编辑器 Visual Studio Code(简称 VS Code),发布了首个正式版,距离首个 beta 版上线时间刚好一年. 在十多年的编程经历中,我使用过非常多的的代 ...

  2. 在ABP中创建Person实体类

    经过之前的准备目前我们的项目,终于可以搞正式的开发工作了. 创建实体Person 在Core类库中添加Person类 /// <summary> /// 联系人 /// </summ ...

  3. WCF学习之旅—第三个示例之一(二十七)

    一.前言 通过前面二十几个章节的学习,我们知道了什么是WCF:WCF中的A.B.C:WCF的传输模式:WCF的寄宿方式:WCF的异常处理.本文综合应用以上知识点,一步一步写一个小的WCF应用程序——书 ...

  4. 【Win10 应用开发】集成文件打开选择器

    有朋友给老周提出建议:老周,能不能在写博客时讲一下有深度的小故事?技术文章谁不会写.讲一下对人生有启发性的故事会更好. 哎呀,这要求真是越来越高了.好吧,尽量吧,如果有小故事的话,老周在就每次写博客时 ...

  5. 解决js动态改变dom元素属性后页面及时渲染问题

    今天实现一个进度条加载过程,dom结构其实就是两个div <div class="pbar"> <div class="ui-widget-header ...

  6. ASP.NET MVC5+EF6+EasyUI 后台管理系统(53)-工作流设计-我的批阅

    系列目录 前言:由于工作原因工作流一直没时间更新,虽然没有更新,但是批阅和申请差不多,改变一下数据的状态字段就行,有几个园友已经率先完成了 说句实话,一个工作流用文章表达很难,我起初以为这是一个很简单 ...

  7. setTimeout那些事儿

    一.setTimeout那些事儿之单线程 一直以来,大家都在说Javascript是单线程,浏览器无论在什么时候,都且只有一个线程在运行JavaScript程序. 但是,不知道大家有疑问没——就是我们 ...

  8. C# 合并及拆分Word文档

    本文简要分析一下如何如何使用C#简单实现合并和拆分word文档.平时我们在处理多个word文档时,可能会想要将两个文档合并为一个,或者是将某个文档的一部分添加到另一个文档中,有的时候也会想要将文档拆分 ...

  9. js模块定义——支持CMD&AMD&直接加载

    /* animate */ //直接加载 (function() { var animate = {} //balabala window.animate = animate; })(); //AMD ...

  10. Http压测工具wrk使用指南

    用过了很多压测工具,却一直没找到中意的那款.最近试了wrk感觉不错,写下这份使用指南给自己备忘用,如果能帮到你,那也很好. 安装 wrk支持大多数类UNIX系统,不支持windows.需要操作系统支持 ...