转自http://www.cnblogs.com/idche/archive/2011/07/05/2098165.htmlGIT 

学习笔记

集中化的版本控制系统
CVCS(Centralized Version Control System)
分布式版本控制系统 DVCS(Decentralized Version Control System) Git 基础要点 http://progit.org/book/zh/ch1-3.html
1:直接快照,而非比较差异
2:近乎所有操作都可本地执行
3:时刻保持数据完整性 (Git 使用 SHA-1 算法计算数据的校验 ,40 个十六进制字符(0-9 及 a-f)组成)
4:多数操作仅添加数据
5:三种状态(已提交(committed),已修改(modified)和已暂存(staged)) GIT安装 http://progit.org/book/zh/ch1-4.html 配置GIT http://progit.org/book/zh/ch1-5.html
$ git config --global user.name "John Doe"  //global对所有的repo都有效
$ git config --global user.email johndoe@example.com 查看配置
git config --list 1. GIT 基础
初始化仓库
$ git init
$ git add *.c
$ git add README
$ git commit -m 'initial project version' 从现有仓库克隆
$ git clone git://github.com/schacon/grit.git 仓库状态
$ git status 跟踪新文件
$ git add fileName 忽略某些文件
$ cat .gitignore
*.[oa] //忽略以 .o 或 .a 结尾的文件
*~ //忽略所有以波浪符(~)结尾的文件 查看已暂存和未暂存的更新
$ git diff
$ git diff --cached //已经暂存起来的文件和上次提交时的快照之间的差异 提交更新
$ git commit -m "message" // 简单的提交方式
$ git commit -a -m "message" // 跳过add 步骤 把已经跟踪的文件全部提交 移除文件
$git rm fileName
$ git rm --cached readme.txt //移除跟踪但不删除文件 移动文件
$ git mv file_from file_to 日志
$ git log
$ git log –p -2 // -p 提交内容的差异 -2最近两次
$ git log --stat//显示简要的增改行数统计 修改最后一次提交
$ git commit --amend
//---第2次提交修改了第一次提交
$ git commit -m 'initial commit'
$ git add forgotten_file
$ git commit --amend 取消已经暂存的文件
$ git reset HEAD fileName 取消对文件的修改(回退到以前未修改的状态) //很有用 也很危险
$ git checkout -- fileName 2. 远程仓库的使用   查看当前的远程库
$ git remote -v // -v 列出远程地址 添加远程仓库
$ git remote add Name git://github.com/paulboone/ticgit.git 从远程仓库抓取数据
$ git fetch [remote-name]
$ git pull// 合并远程的全部分支到本地(不确定) 推送数据到远程仓库
$ git push origin master //推送 origin 到 master 查看远程仓库信息
$ git remote show origin 远程仓库的删除和重命名
$ git remote rename pb paul// pb 改成 paul 分支对应前缀也会发生变化
$ git remote rm paul// 貌似删除
    
     本地分支重命名
     $ git branch -m <old_branch> <new_branch> 3. 打标签 http://progit.org/book/zh/ch2-6.html
列显已有的标签
$ git tag
$ git tag -l 'v1.4.2.*'//搜索标签 新建标签
$ git tag -a v1.4 -m 'my version 1.4' //新建v1.4标签 消息是 my version 1.4 分享标签
$ git push origin [tagname] //提交 一个标签
$ git push origin --tags // 推送所有本地标签 删除
$ git tag -d [tagname] //删除标签
$ git push origin :refs/tags/tagname //删除远程标签 4. 技巧和窍门
提示 // 敲两次tab
Git 命令别名
     
$ git config --global alias.co checkout // git co 代替了 git checkout
     $ git config --global alias.st status
     $ git config --global alias.ci commit
     $ git config --global alias.br branch
     $ git config --global alias.unstage reset HEAD --
     $ git config --global alias.last log -1 HEAD
     当然这里最好是通过修改 vi ~/.gitconfig文件,格式如
     [alias]
      st = status
       ..... 5. 分支
创建分支
$ git branch testing // 创建testing
$ git checkout testing// 切换到testing
$ git checkout -b iss53 //创建并切换到iss53
$ git merge hotfix //把hotfix 分支合并到当前分支 查看分支
$ git branch -v//最后一次commit信息
$ git branch --merged | --no-merged//筛选出你已经(或尚未)与当前分支合并的分支 删除
$ git branch -D testing 推送
     $ git push origin serverfix//把当前推送到 serverfix分支,省略远程分支名,表明当前分支和远程分支存在追踪关系,同样本地分支名也是可以省略的
   $ git push <远程主机名> <本地分支名>:<远程分支名>  //和pull相反, git pull <远程主机> <来源地_远程分支名>:<目的地_本地分支名>
     更新同步 $ git fetch 

     删除远程分支 git push origin :branchname git branch –r //查看所有分支信息 //获取远端分支 $ git checkout -b sf origin/serverfix 

6. 服务器上的GIT ---http://progit.org/book/zh/ch4-3.html 

生成 SSH 公钥 ---http://github.com/guides/providing-your-ssh-key。 $ cd ~/.ssh //公钥的位置 $ ls authorized_keys2 id_dsa known_hosts config id_dsa.pub $ ssh-keygen //如果上面看不到公钥 可以用次来创建 会要求输入存放位置 和密码 

7. 储藏 $ git status //储藏 $ git stash list//储藏列表 $ git stash apply//应用储藏 
参考资料 http://zh.wikipedia.org/wiki/Git http://progit.org/book/zh/

[git]Git常用命令的更多相关文章

  1. GIT 版本控制常用命令学习汇总

    GIT 版本控制常用命令汇总 git version 查看当前git版本信息 git help 获取全部命令帮助信息 git help <command> 获取指定命令帮助信息 git c ...

  2. git log 常用命令及技巧

    git log常用命令以及技巧 1.git log 如果不带任何参数,它会列出所有历史记录,最近的排在最上方,显示提交对象的哈希值,作者.提交日期.和提交说明.如果记录过多,则按Page Up.Pag ...

  3. Git基本常用命令

    Git基本常用命令如下: mkdir: XX (创建一个空目录 XX指目录名) pwd: 显示当前目录的路径. git init 把当前的目录变成可以管理的git仓库,生成隐藏.git文件. git ...

  4. Git是什么、Git的功能、为什么versioncontrol用Git、Git的常用命令、Git的优缺点

    Git是什么 git是目前世界上最先进的分布式版本控制系统(没有之一). Git是用于 Linux内核开发的版本控制工具.与常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版 ...

  5. Git stash 常用命令

    参考: Git: How to look at the stash Git学习笔记05--git stash Git stash 常用命令 1.git stash: 保存当前的工作进度: 2.git ...

  6. Git 基础 —— 常用命令

    Git 基础学习系列 Git 基础 -- 安装 配置 别名 对象 Git 基础 -- 常用命令 Git 基础 -- 常见使用场景 Git基础 -- Github 的使用 git init 创建 Git ...

  7. git之常用命令

    git之常用命令 1.下载远程仓库最新代码 $ git pull --rebase origin master 2.上传代码 $ git push origin master 3.退出编辑 ESC + ...

  8. git的常用命令。。

    git的常用命令.. git help <command>  显示command的help git show  显示某次提交的内容 git show $id git co -- <f ...

  9. Git - Git基本常用命令

    Git基本常用命令 mkdir:         XX (创建一个空目录 XX指目录名) pwd:          显示当前目录的路径. git init          把当前的目录变成可以管理 ...

  10. Git的常用命令记录

    Git的常用命令记录 1.与远程仓库建立连接,即关联一个远程库 git remote add origin git@server-name:path/repo-name.git; 2.查看当前分支  ...

随机推荐

  1. Sql优化(一) Merge Join vs. Hash Join vs. Nested Loop

    原创文章,首发自本人个人博客站点,转载请务必注明出自http://www.jasongj.com Nested Loop,Hash Join,Merge Join介绍 Nested Loop: 对于被 ...

  2. 基础套接字的C#网络编程

    1.基于socket创建套接字网络连接服务端1.初始化 步骤 操作 方法 操作类 1. 创建ip ipaddress IPAddress类 2. 创建ip终结点   ipendpoint IpendP ...

  3. HDU 5955 Guessing the Dice Roll

    HDU 5955 Guessing the Dice Roll 2016 ACM/ICPC 亚洲区沈阳站 题意 有\(N\le 10\)个人,每个猜一个长度为\(L \le 10\)的由\(1-6\) ...

  4. GNU C 扩展(转)

    GNU CC 是一个功能非常强大的跨平台 C 编译器,它对 C 语言提供了很多扩展,这些扩展对优化.目标代码布局.更安全的检查等方面提供了很强的支持.这里对支持支持 GNU 扩展的 C 语言成为 GN ...

  5. 黑马程序员——JAVA基础之多线程的线程间通讯等

    ------- android培训.java培训.期待与您交流! ---------- 线程间通讯: 其实就是多个线程在操作同一个资源,但是动作不同. wait(); 在其他线程调用此对象的notif ...

  6. 对于python,一切事物都是对象,对象基于类创建

    新建列表.新建string字符串 li1 = [1, 2, 3, 4] li2 = list([1, 2, 3]) s1 = "abc" s2 = str("abc&qu ...

  7. QueryRunner使用

    在相继学习了JDBC和数据库操作之后,我们明显感到编写JDBC代码并非一件轻松的事儿.为了帮助我们更高效的学习工作,从JDBC的繁重代码中解脱出来,老佟给我们详尽介绍了一个简化JDBC操作的组件——D ...

  8. about java techelogly

    https://docs.oracle.com/javase/tutorial/getStarted/intro/definition.html Differences between Java EE ...

  9. JSBinding + SharpKit / 安装SharpKit以及添加SharpKit工程

    本文说明如何往 sln 中添加 SharpKit 工程,以及配置. SharpKit 工程用于将 C# 源代码编译成 JS  代码. QQ群 189738580 1. 安装SharpKit 到 sha ...

  10. 纯CSS绘制三角形(各种角度)

    我们的网页因为 CSS 而呈现千变万化的风格.这一看似简单的样式语言在使用中非常灵活,只要你发挥创意就能实现很多比人想象不到的效果.特别是随着 CSS3 的广泛使用,更多新奇的 CSS 作品涌现出来. ...