---
`Git`
# Git管理 #
- 创建仓库
git init
在本地目录下建立新git仓库,该仓库可以为空也可以是重新初始化的仓库。该命令将创建一个名为 .git 的子目录,这个子目录含有初始化的 Git 仓库中所有的必须文件,仅仅是做了一个初始化的操作,项目里的文件还没有被跟踪。此时可通过 git add 命令来实现对指定文件的跟踪,然后执行 git commit 提交。
git clone [path] [name]
克隆仓库至当前目录,path可以为本地也可以是远程,name为仓库的命名。
- 添加和提交
git add [file]
workdir->index->head
将修改的文件添加入缓存流(index)
git commit -m "代码提交信息" /git commit -a /git commit --initial
将修改后的index提交至head
- 推送至仓库
git push orgin [branch(default:master)]
若你之前未使用clone那么需要
使用:
git remote add origin <server>
- 分支概念

分支是用来将特性开发绝缘开来的。在你创建仓库的时候,master 是“默认的”分支。在其他分支上进行开发,完成后再将它们合并到主分支上。
git checkout -b newfeature #建立并切换分支
or
git branch newfeature #建立分支
git checkout newfeature #切换分支

git branch # 查看分支
并非每次都成功,并可能出现冲突(conflicts)。
这时候就需要你修改这些文件来手动合并这些冲突(conflicts)。
改完之后,你需要执行如下命令以将它们标记为合并成功:
git add <filename>
git merge <name> # 合并分支到master
git branch -d <name> # 删除分支
git diff <source_branch> <target_branch>
git log --graph #查看分支合并图
- 日志
git log #显示本地仓库日志
git tag 1.0.0 1b2e1d63ff #为各个提交记录设置标签
- 恢复

git checkout -- <file> #取消对文件的修改。还原到最近的版本,废弃本地做的修改。
git reset HEAD <file>... #取消已经暂存的文件。即,撤销先前"git add"的操作
git commit --amend #修改最后一次提交。用于修改上一次的提交信息,或漏提交文件等情况。
git reset HEAD^ #回退所有内容到上一个版本
git reset HEAD^ a.py #回退a.py这个文件的版本到上一个版本
git reset –soft HEAD~3 #向前回退到第3个版本
git reset –hard origin/master #将本地的状态回退到和远程的一样
git reset 057d #回退到某个版本
git revert HEAD #回退到上一次提交的状态,按照某一次的commit完全反向的进行一次commit.(代码回滚到上个版本,并提交git)
git fetch
git reset --hard origin/master #丢弃本地版本恢复为远程版本

文件删除恢复分为4种情况:
1. 使用系统的删除或者对文件进行了修改. 可以使用git checkout -- <file>来恢复.
2. 使用git rm 删除的,即是将记录写入了index,必须采用 HEAD 来恢复index.
git reset HEAD <file> , 之后按照1来恢复
3. 使用git commit 修改了 HEAD 同理 git reflog查看操作日志 修改 git reset HEAD{x} 来恢复HEAD.
4. 使用git push修改了远端仓库 使用 git log 查看版本改动 ,git reset --hard <commit_id> 还原到位.使用git push -f 强制恢复远程仓库.

- SSH方式链接

Git 可以使用四种主要的协议来传输资料:本地协议(Local),HTTP 协议,SSH(Secure Shell)协议及 Git 协议。
HTTPS:不管是谁,拿到url随便clone,但是在push的时候需要验证用户名和密码;
SSH:clone的项目你必须是拥有者或者管理员,而且需要在clone前添加SSH Key。SSH 在push的时候,是不需要输入用户名的,如果配置SSH key的时候设置了密码,则需要输入密码的,否则直接是不需要输入密码的。

1. 生成SSH-key

ssh-keygen -t rsa -C youremail@email.com rsa加密生成SSH秘钥
生成的秘钥分为私钥id_rsa 和 公钥 id_rsa.pub 保存在 ~/.ssh/ 目录下。
2. 添加SSH-key

打开github账户的profile 设置 SSH-key
复制id_rsa.pub内容至key区域
3. 测试SSH链接
SSH -T git@github.com

4. 仓库设置SSH关联

由于remote方式可能不是ssh,使用
git remote -v #查看remote方式
若无ssh-url则进行
git remote set-url origin <ssh-url>
SSH-URL可从github repository 的clone or download处复制获取.
格式类似于:git@github.com:account/project.git
---

Git使用笔记 (github为例)的更多相关文章

  1. git使用笔记(六)github

    By francis_hao    Nov 20,2016 github介绍 github是一个网站https://github.com/,可以实现基于git(当然,svn也是可以的)的代码托管工作. ...

  2. Git学习笔记(三)远程库(GitHub)协同开发,fork和忽略特殊文件

    远程库 远程库,通俗的讲就是不再本地的git仓库!他的工作方式和我们本地的一样,但是要使用他就需要先建立连接! 远程库有两种,一个是自己搭建的git服务器:另一种就是使用GitHub,这个网站就是提供 ...

  3. 【转帖】Git学习笔记 记录一下

    本文内容参考了廖雪峰老师的博文,并做了适当整理,方便大家查阅. 原帖地址 https://wangfanggang.com/Git/git/ 常用命令 仓库初始化 - git init 1 git i ...

  4. Git学习笔记(二) 远程仓库及分支

    添加远程仓库(以GitHub为例) 所谓的远程仓库,其实就和本地仓库一样,只是我们本地电脑可能会关机什么的.远程仓库的目的就是保证7*24小时开启状态.GitHub是一个很好的公共Git远程仓库(后面 ...

  5. Git学习笔记(二) · 非典型性程序猿

    远程库的使用 前面说到的都是git在本地的操作,那么实际协作开发过程中我们肯定是要有一个远程版本库作为项目的核心版本库,也就是投入生产使用的版本.这里我们以 Github为例.Github是一个开放的 ...

  6. Git学习笔记与IntelliJ IDEA整合

    Git学习笔记与IntelliJ IDEA整合 一.Git学习笔记(基于Github) 1.安装和配置Git 下载地址:http://git-scm.com/downloads Git简要使用说明:h ...

  7. 版本控制简介,git使用----使用GitHub托管代码

    关于版本控制: 很久以前,人们苦于对写过的代码进行版本的管理,经常过了一段时间想恢复原来写过的代码却又忘了不知道丢到哪儿去了,有的人用加上时间后缀来命名文件的方法,便于后期维护,但是这样做的麻烦也很大 ...

  8. Git学习笔记(10)——搭建Git服务器

    本文主要记录了Git服务器的搭建,以及一些其他的配置,和最后的小总结. Git远程仓库服务器 其实远程仓库和本地仓库没啥不同,远程仓库只是每天24小时开机为大家服务,所以叫做服务器.我们完全可以把自己 ...

  9. Git学习笔记(四)

    一.忽略特殊文件 在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件. 不需要从头写.gitignore文件,GitHub已经为我们 ...

随机推荐

  1. android 线程的开启和停止(借鉴java的技术)

    在onclick()点击事件中的 // 上传地理位置 case R.id.person_up_locat: System.out.println("====输出了.. .. ====&quo ...

  2. 【JavaScript】JS读取XML文件并进行搜索

    需求效果 点击链接.当前页面载入xml文件并展示相应内容 通过搜索框.搜索xml文件内节点数据.展示包括内容的节点数据 功能实现 Demo终于实现效果 http://loadxmldemo.coder ...

  3. android5.1 Recovery添加从U盘升级功能【转】

    本文转载自:http://blog.csdn.net/tfslovexizi/article/details/73835594 之前看到过一个人写了4.4上添加U盘升级功能的博客http://blog ...

  4. 使用git命令 (git reset --hard HEAD) 回退版本信息

    Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100 ...

  5. highcharts注意事项

    var json = [ {"id":"1","tagName":"apple"}, {"id":& ...

  6. JavaGraphics类的绘图方法

    Graphics类提供基本绘图方法,Graphics类提供基本的几何图形绘制方法,主要有:画线段.画矩形.画圆.画带颜色的图形.画椭圆.画圆弧.画多边形.画字符串等. 1. 画线段:在窗口中画一条线段 ...

  7. E20170629-hm

    enqueue  [计] 入队,排队; dequeue  [计]  出列; rear  n. 后部,背面,背后; 臀部; (舰队或军队的) 后方,后尾,殿后部队; 〈英口〉厕所; ring buffe ...

  8. 使用Visual Studio Code + Node.js搭建TypeScript开发环境

    Visual Studio Code搭建Typescript开发环境 —— 相关文章: http://www.cnblogs.com/sunjie9606/p/5945540.html [注意:这里仅 ...

  9. ACM_Repeating Characters

    Repeating Characters Time Limit: 2000/1000ms (Java/Others) Problem Description: For this problem, yo ...

  10. 参加2016华为codecraft编程精英挑战赛后感

    2016年4月参加了华为的软件比赛. 关于比赛:给了一道图论的np-hard问题.刚开始完全不知道怎么入手,请教过师兄,自己也琢磨过,没有什么万全的解决方法.注意,这里说的是万全的办法.本科搞算法时候 ...