转自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. python矩阵运算 不断收集整理

    python矩阵运算 转自:http://blog.sina.com.cn/s/blog_5f234d4701012p64.html Python使用NumPy包完成了对N-维数组的快速便捷操作.使用 ...

  2. Java-->List&Set

    一.List集合 特点:有序可重复 List集合的猜想: 1.每个元素是不是应该有序号 index 2.addFirst.addLast.set(intdex, 对象) 3.get(index)... ...

  3. HTML5 3D动画效果

    对以前来讲,3D动画拿到网页上展示是一件非常奢侈的事情,第一是浏览器不够先进,第二是大部分只能用flash实现伪3D.HTML5的出现,让实现网页3D动画变得非常简单,当然前提是你不要再使用像IE67 ...

  4. 标准盒模型与ie盒模型

    ff(标准的盒模型) Box的宽高包括 padding .border.margin.content区域 ie Box的宽度包括  margin  content区域(content区域包含paddi ...

  5. php部分---人员表和民族表的显示、修改、删除

    1.连接数据库 进行网页的显示 <table width="100%" border="1" cellpadding="0" cell ...

  6. POJ-2886 Who Gets the Most Candies?(线段树+模拟)

    题目大意:n个小孩按顺时针站成一圈,每次会有一个小孩出队(第一个出队的小孩已知),在他出队时会指定下一个出队的小孩,直到所有的小孩全部出队游戏结束.第p个出队的小孩会得到f(p)个糖果,f(p)为p的 ...

  7. POJ-2481 Cows (线段树单点更新)

    题目大意:给n个区间,对于任意一个区间,求出能完全包含它并且长度比它长的区间的个数. 题目分析:将一个区间视为二位坐标系中的一个点,左端点视作横坐标,右端点视作纵坐标.则题目变成了求每个点的左上方.正 ...

  8. SUID,SGID,Sticky Bit详解(转)

    SUID属性 passwd命令可以用于更改用户的密码,一般用户可以使用这个命令修改自己的密码.但是保存用户密码的/etc/shadow文件的权限是400,也就是说只有文件的所有者root用户可以写入, ...

  9. Unix 入门

    说明:转自以为大神的笔记. 首先,我们一起看看UNIX的目录,因为清楚了目录,才能对UNIX的框架有个大概的印象!当然这里讲的是系统正常运转所必须的,并且一定不能删除或者修改.  / 是系统的根目录: ...

  10. error LNK2026: 模块对于 SAFESEH 映像是不安全的

    解决方法: 1.打开该项目的“属性页”对话框. 2.单击“链接器”文件夹. 3.单击“命令行”属性页. 4.将 /SAFESEH:NO 键入“附加选项”框中,然后点击应用.