git基本操作
2016-04-25 11:04
274 查看
本文暂时不会涉及到团队如何使用Git的内容,而是从个人的角度探讨如何用好Git。
git cat-file -p,查看Git对象的内容
git log --oneline,可以显示更加短小的提交ID.
git log --graph,显示何时出现了分支和合并等信息.
git log --pretty=raw,显示提交对象的parent属性.
git config -e --global
git config -e --system
Git的三个配置文件分别是版本库级别的配置文件(/.git/config)、全局配置文件(用户主目录下)和系统级配置文件(/etc目录下)。这个命令的作用是打开相应的配置文件,并且进行编辑。其中版本库级别的配置文件的优先级最高,全局配置文件次之,系统级别配置文件最低。Git配置文件采用的是INI文件格式。
git config <section>.<key>,读取和更改INI配置文件的内容。
git config <section>.<key> <value>,修改INI配置文件中某个配置的键值
在全局空间中添加新的用户
git config --global user.name "harvey liu"
git config --global user.email harvey_liu@163.com
设置git命令的别名
git config --global alias.ci commit
git config --global alias.co checkout
删除git全局配置文件中的用户名
git config --unset --global user.name
git config --unset --global user.email
git diff,显示工作区和暂存区的差异
git diff HEAD,显示工作区和HEAD之间的差异
git diff --cached,显示暂存区和HEAD之间的差异
git diff id1 id2,显示两次提交之间的差异
git status -s,将结果以简短的形式输出
git add . ,Git会递归地将你执行命令时所在的目录中的所有文件添加上去,所以如果你将当前的工作目录作为参数,它就会追踪那儿的所有文件
git add -u,使用-u参数调用了git add命令,会将本地有改动(包括删除和修改)的已经追踪的文件标记到暂存区中。
git add -A,使用-A参数会将添加所有改动的已跟踪文件和未跟踪文件。
git add -i,交互式的方式进行添加。
git commit --a,对本地所有变更的文件执行提交操作,包括对本地修改的文件和删除的文件,但是不包括未被版本库跟踪的文件。但是这个命令最好不要使用,这样会丢掉Git暂存区带给用户的最大好处:对提交内容进行控制的能力
把当前分支指向另一个位置,并且有选择的变动工作目录和索引
git reset --hard <commit>,替换引用的指向,替换暂存区,替换工作区
git reset --soft <commit>,只更改引用的指向,不改变暂存区和工作区
git reset,用HEAD指向的目录树重置暂存区
git reset -- filename,将文件filename的改动撤出暂存区,暂存区其他文件不变
git branch <branchname>,创建新的分支branchname
git branch -d <branchname> ,删除名称为branchname的分支
git checkout branchname,会改变HEAD头指针,主要用于切换分支
git checkout -b branchname,用于创建一个新的分支,并且切换到创建的新的分支上
git checkout --filename,用暂存区中的filename文件来覆盖工作区中的filename文件
git checkout <commit> --filename,用指定提交中的文件覆盖暂存区和工作区中对应的文件
git checkout -- .或者git checkout .,用暂存区的所有文件直接覆盖本地文件,取消所有的本地的修改,是一条危险的操作
git rm命令会将删除动作加入暂存区,这是执行提交动作,就从真正意义上执行了文件删除。
git archive -o latest.zip HEAD,基于最新提交建立归档文件latest.zip
git archive -o partial.tar HEAD src doc,只将目录src和doc建立到归档文件partial.tar中
git archive --format=tar --prefix=1.0/ v1.0 | gzip > foo-1.0.tar.gz,基于里程碑v1.0建立归档,并且为归档中的文件添加目录前缀1.0
git clone --bare <repository> <directory.git>
git clone --mirror <repository> <directory.git>
上面的两种克隆版本都不包含工作区,直接就是版本库的内容,这样的版本库称为裸版本库。
约定
绿色的5位字符表示提交的ID,分别指向父节点。分支用橘色显示,分别指向特定的提交。当前分支由附在其上的标识。 这张图片里显示最后5次提交,是最新提交。分支指向此次提交,另一个分支指向祖父提交节点。git cat-file
git cat-file -t,查看Git对象的类型,主要的git对象包括tree,commit,parent,和blob等。git cat-file -p,查看Git对象的内容
git log
git log主要用来显示分支中提交更改的记录。当执行git commit以存储一个快照的时候,文件详单、提交消息和提交者的信息、此次提交所基于的快照都会被保存。git log --oneline,可以显示更加短小的提交ID.
git log --graph,显示何时出现了分支和合并等信息.
git log --pretty=raw,显示提交对象的parent属性.
git config
git config -egit config -e --global
git config -e --system
Git的三个配置文件分别是版本库级别的配置文件(/.git/config)、全局配置文件(用户主目录下)和系统级配置文件(/etc目录下)。这个命令的作用是打开相应的配置文件,并且进行编辑。其中版本库级别的配置文件的优先级最高,全局配置文件次之,系统级别配置文件最低。Git配置文件采用的是INI文件格式。
git config <section>.<key>,读取和更改INI配置文件的内容。
git config <section>.<key> <value>,修改INI配置文件中某个配置的键值
在全局空间中添加新的用户
git config --global user.name "harvey liu"
git config --global user.email harvey_liu@163.com
设置git命令的别名
git config --global alias.ci commit
git config --global alias.co checkout
删除git全局配置文件中的用户名
git config --unset --global user.name
git config --unset --global user.email
git diff
git diff,显示工作区和暂存区的差异
git diff HEAD,显示工作区和HEAD之间的差异
git diff --cached,显示暂存区和HEAD之间的差异
git diff id1 id2,显示两次提交之间的差异
git status
git status,查看你的代码在缓存与当前工作目录的状态git status -s,将结果以简短的形式输出
git add
git add,在提交你修改的文件之前,你需要把它们添加到暂存区。如果该文件是新创建的,你可以执行将该文件添加到暂存区git add . ,Git会递归地将你执行命令时所在的目录中的所有文件添加上去,所以如果你将当前的工作目录作为参数,它就会追踪那儿的所有文件
git add -u,使用-u参数调用了git add命令,会将本地有改动(包括删除和修改)的已经追踪的文件标记到暂存区中。
git add -A,使用-A参数会将添加所有改动的已跟踪文件和未跟踪文件。
git add -i,交互式的方式进行添加。
git commit
git commit --amend,修补式提交。git commit --a,对本地所有变更的文件执行提交操作,包括对本地修改的文件和删除的文件,但是不包括未被版本库跟踪的文件。但是这个命令最好不要使用,这样会丢掉Git暂存区带给用户的最大好处:对提交内容进行控制的能力
git reset
把当前分支指向另一个位置,并且有选择的变动工作目录和索引
git reset --hard <commit>,替换引用的指向,替换暂存区,替换工作区
git reset --soft <commit>,只更改引用的指向,不改变暂存区和工作区
git reset,用HEAD指向的目录树重置暂存区
git reset -- filename,将文件filename的改动撤出暂存区,暂存区其他文件不变
git branch
git branch,显示当前所在的分支git branch <branchname>,创建新的分支branchname
git branch -d <branchname> ,删除名称为branchname的分支
git checkout
git checkout,检出命令。git checkout branchname,会改变HEAD头指针,主要用于切换分支
git checkout -b branchname,用于创建一个新的分支,并且切换到创建的新的分支上
git checkout --filename,用暂存区中的filename文件来覆盖工作区中的filename文件
git checkout <commit> --filename,用指定提交中的文件覆盖暂存区和工作区中对应的文件
git checkout -- .或者git checkout .,用暂存区的所有文件直接覆盖本地文件,取消所有的本地的修改,是一条危险的操作
git rm
rm命令删除的文件只是在本地进行了删除,尚未添加到暂存区,也就是说,直接在工作区删除,对暂存区和版本库没有任何影响。git rm命令会将删除动作加入暂存区,这是执行提交动作,就从真正意义上执行了文件删除。
git mv
git mv,移动文件,git中以git rm和git add两条命令取而代之。git archive
git archive,对任意提交对应的目录树建立归档。git archive -o latest.zip HEAD,基于最新提交建立归档文件latest.zip
git archive -o partial.tar HEAD src doc,只将目录src和doc建立到归档文件partial.tar中
git archive --format=tar --prefix=1.0/ v1.0 | gzip > foo-1.0.tar.gz,基于里程碑v1.0建立归档,并且为归档中的文件添加目录前缀1.0
git clone
git clone <repository> <directory>,将repository指向的版本库创建一个克隆到directory目录中。目录directory相当于克隆版本库的工作区,文件都会检出,版本库位于工作区下得.git目录中。git clone --bare <repository> <directory.git>
git clone --mirror <repository> <directory.git>
上面的两种克隆版本都不包含工作区,直接就是版本库的内容,这样的版本库称为裸版本库。
git push
git push <remote> [branch],就会将你的 [branch] 分支推送成为 [alias] 远端上的 [branch] 分支,要推送的远程版本号的URL地址由remote.<remote>.pushurl给出,如果没有配置,则使用remote.<remote>.url配置的URL地址。git pull
git pull,从远端的服务器上下载数据,从而实现同步更新。要获取的远程版本库的URL地址由remote.<remote>.url提供。相关文章推荐
- matlab 稀疏张量的HOSVD 推荐系统
- 基于哈夫曼编码完成的文件压缩及解压
- mac 环境下 Quantlib 使用Swig 转换到java
- GitLab CE 9-3-stable源码安装手册(Centos6/REHL6)
- zepto.js入门到精通(一)
- Servlet类基础详解
- SOLR缓存调优
- 第一章之初识Bootstrap
- Solr常用命令
- 获取本机Ip地址
- DOM之重新介绍CSS的定位
- QT基础(四)----信号和槽
- Android ViewDragHelper完全解析 自定义ViewGroup神器
- 解决StoryBoard上cell上定义的view的背景点击后不显示的问题(其中用uiview 当作线的时候最多遇到,会不显示线 而出现不流畅问题)
- 加速计(小球dem)
- iOS如何跳到系统设置里的各种设置界面
- Solr Schema.xml和solrconfig.xml分析
- Sed 地址和模式匹配的问题
- 支付宝木马安卓短信窃取者分析
- 初学python二:数据类型