转自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. 理解 %IOWAIT (%WIO)

    %iowait 是 “sar -u” 等工具检查CPU使用率时显示的一个指标,在Linux上显示为 %iowait,在有的Unix版本上显示为 %wio,含义都是一样的,这个指标常常被误读,很多人把它 ...

  2. 解读vmstat中的ACTIVE/INACTIVE MEMORY

    vmstat 命令能够报告关于内核线程.虚拟内存.磁盘.陷阱和 CPU 活动的统计信息,那么我们又该如何理解其工作原理呢? vmstat -a 命令能看到active memory 和 inactiv ...

  3. springmvc学习笔记--REST API的异常处理

    前言: 最近使用springmvc写了不少rest api, 觉得真是一个好框架. 之前描述的几篇关于rest api的文章, 其实还是不够完善. 比如当遇到参数缺失, 类型不匹配的情况时, 直接抛出 ...

  4. Eclipse中Egit冲突解决

    Eclipse中Egit冲突解决 Git 作为进来最流行的分布式版本控制软件来说应用的十分广泛.EGit就是一款Eclipse上的Git插件.在使用Egit提交项目时,有时会产生冲突,需要对代码进行m ...

  5. Codeforces Round #374 (Div. 2) A B C D 水 模拟 dp+dfs 优先队列

    A. One-dimensional Japanese Crossword time limit per test 1 second memory limit per test 256 megabyt ...

  6. html部分---表单、iframe、frameset及其他字符的用法(以及name、id、value的作用与区别);

    <form action="aa.html" method="post/get"> /action的作用是提交到..,methed是提交方法,用po ...

  7. POJ 3041 Asteroids(最小点覆盖集)

                                                                      Asteroids Time Limit: 1000MS   Mem ...

  8. DDL、DML、

     SQL语言的分类 SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL. 1. 数据查询语言DQL数据查询语言DQL基本结构是由SELECT子句,F ...

  9. linux下的符号链接和硬链接

    一   Linux下链接文件的作用 Linux特别注重用户的权限,而链接文件的作用也正体现了这个方面.对源文件的位置进行了隐藏,用户只对链接文件操作. 二  链接文件的区别 链接文件分为硬链接文件和软 ...

  10. css animation让图标不断旋转

    @keyframes rotating{from{transform:rotate(0)}to{transform:rotate(360deg)}} animation:rotating 1.2s l ...