老郑的博客

木叶飞舞之处,火亦生生不息!

git常用操作命令

====== 查看远程配置 ======

vi .git/config

 

====== SVN介绍 ======

Subversion的特点概括起来主要由以下几条:
每个版本库有唯一的URL(官方地址),每个用户都从这个地址获取代码和数据;
获取代码的更新,也只能连接到这个唯一的版本库,同步以取得最新数据;
提交必须有网络连接(非本地版本库);
提交需要授权,如果没有写权限,提交会失败;
提交并非每次都能够成功。如果有其他人先于你提交,会提示“改动基于过时的版本,先更新再提交”… 诸如此类;
冲突解决是一个提交速度的竞赛:手快者,先提交,平安无事;手慢者,后提交,可能遇到麻烦的冲突解决。

====== Git介绍 ======

1.Git中每个克隆(clone)的版本库都是平等的。你可以从任何一个版本库的克隆来创建属于你自己的版本库,同时你的版本库也可以作为源提供给他人,只要你愿意。
2.Git的每一次提取操作,实际上都是一次对代码仓库的完整备份。
3.提交完全在本地完成,无须别人给你授权,你的版本库你作主,并且提交总是会成功。
4.甚至基于旧版本的改动也可以成功提交,提交会基于旧的版本创建一个新的分支。
5.Git的提交不会被打断,直到你的工作完全满意了,PUSH给他人或者他人PULL你的版本库,合并会发生在PULL和PUSH过程中,不能自动解决 的冲突会提示您手工完成。
6.冲突解决不再像是SVN一样的提交竞赛,而是在需要的时候才进行合并和冲突解决。
7.Git 也可以模拟集中式的工作模式
8.Git版本库统一放在服务器中
9.可以为 Git 版本库进行授权:谁能创建版本库,谁能向版本库PUSH,谁能够读取(克隆)版本库
10.团队的成员先将服务器的版本库克隆到本地;并经常的从服务器的版本库拉(PULL)最新的更新;
11.团队的成员将自己的改动推(PUSH)到服务器的版本库中,当其他人和版本库同步(PULL)时,会自动获取改变
12.Git 的集中式工作模式非常灵活
13.你完全可以在脱离Git服务器所在网络的情况下,如移动办公/出差时,照常使用代码库
14.你只需要在能够接入Git服务器所在网络时,PULL和PUSH即可完成和服务器同步以及提交
15.Git提供 rebase 命令,可以让你的改动看起来是基于最新的代码实现的改动
16.Git 有更多的工作模式可以选择,远非 Subversion可比

====== 设置git用户名/邮箱 ======

git config --global user.name '用户名'
git config --global user.email '邮箱'

 

====== 修改config保存git用户名密码 ======

1.输入一次之后直接保存在config文件
命令:

git config --global credential.helper store

 

====== 创建本地仓库 ======

1.创建命令

git init

 


====== 文件添加到本地仓库(暂存区) ======
1.添加文件test到暂存区

git add test.txt

 

====== 丢弃工作区的修改(add之前) ======

1.丢弃工作区的修改
命令: 

git checkout -- test.txt

 

====== 撤销暂存区的修改 ======

1.撤销属于暂存区的修改
命令:

git reset HEAD test.txt

 

====== 删除文件 ======

1.删除版本库里的文件
命令:

git rm test.txt

 

====== 撤销删除 ======

1.撤销删除工作区的文件(已经提交到了版本库)
命令:

git checkout --test.txt

 


====== 把文件提交到本地仓库(提交到仓库所在分支) ======

1.把暂存区文件提交到本地仓库
命令:

git commit -m '注释'

 

====== 查看仓库当前状态 ======

1.查看暂存区修改了什么内容信息
命令:

git status

 

====== 查看文件修改了什么内容 ======

1.查看test.txt文件修改了什么内容
命令:

git diff test.txt

 

====== 查看提交记录 ======

1.查看提交记录信息列表形式显示
命令:

git log --pretty=oneline

 

====== 回退到上一个版本 ======

1.回退到上次提交的版本

git reset --hard HEAD^

 

====== 回退到指定版本 ======
1.退回到指定的版本 例如前缀是:1a2s
命令:

git reset --hard 前缀

 

====== 历史提交记录 ======

1.查看用户历史提交记录
命令:

git reflog

或者:gitk
注:若打开的gitk界面中的中文注释是乱码,可以执行git config --global gui.encoding utf-8

====== 克隆远程仓库到本地 ======

1.克隆远端仓库到本地仓库
命令:

git remote add origin http://zhengyazhao/root/test.git

====== 推送本地内容到远程仓库 ======

1. 首次推送:

git push -u(把本地分支推送到远程同名分支并且和远程分支关联起来) origin master


2. 正常推送:

git push origin master:master(本地分支)

 

====== 克隆远端分支到本地 ======

1.从远端分支克隆到本地
命令:

git clone http://localhost/test.git

 

====== 获取最新代码并且合并 ======

1.更新远程分支到本地:

git pull origin master:test(本地库)


2.默认不填写更新并且合并到同名分支:

git pull origin master

====== 从远端获取最新版本到本地分支 ======

1.获取远端分支最新代码到本地分支

git fetch origin master

 

====== 创建分支 ======

1.创建分支:

git branch dev

2.创建分支并切换到该分支:

git checkout -b dev

====== 切换分支 ======

1.从master分支切换到dev分支
命令:

git checkout dev

====== 查看当前分支 ======

1.查看当前本地仓库分支信息
命令:

git branch (分支前带*号表示当前工作分支)

====== 分支合并 ======

1.当前分支处于master
2.需求要把dev分支内容合并到master分支当中
3.使用命令

 git merge dev

 

====== 删除分支 ======

1.删除无用的分支(已经合并的分支)
命令:

git branch -d dev

====== 分支合并图 ======

1.查看分支合并的信息
命令:

git log --graph

====== 隐藏工作区内容 ======

1.把工作区修改的内容还未提交到暂存区的代码隐藏起来
命令:

git stash

====== 查看隐藏工作内容 ======

1.查看隐藏区域内容
命令:

git stash list

====== 恢复隐藏区的内容 ======

1.恢复隐藏区内容
命令:

git stash apply

 


2.删除隐藏区信息
命令: 

git stash drop

 


3.恢复隐藏区内容的同时,删除隐藏区stash
命令:

git stash pop

 

====== 删除远端分支 ======

1.命令:

remote/origin/master

 


 

posted @ 2019-07-03 14:41  zyz1  阅读(288)  评论(0编辑  收藏  举报