git最常用的操作命令

0.一无所有。

1.先下载一个git安装包,全局安装。安装好了以后,cmd  -> git  --version ,查看版本得到:“git version 2.14.1.windows.1”。

2.公司或者个人都会先在服务器上建好一个代码仓库,如:gitLab,码云或者在自己租的服务器上搭一个代码仓库。

3.进入d盘,右键鼠标选中git bash here即可打开git shell窗口,在里面就可以写cmd or git 命令。

先来克隆远程服务器的代码执行:git clone http://git.ccdd.com/aabb/xxxx.git , 打开代码所在的文件夹,里面自动产生的.git文件是本地git和远程服务器代码仓库git的纽带,不可缺少或更改。

4.cd xxprojectName,进入项目后,默认是master分支。可以用git branch 查看所有分支。

5. 查看分支命令:

git branch -r  // 查看所有远程分支   r(remotes 远程的adj.)

git branch -a // 查看所有分支

6.切换分支

git checkout develop // 切换到develop分支

git checkout -b localBranchA origin/remotesBranchA   // -b是参数,新建本地分支localBranchA且与远程分支remotesBranchA建立track关系,localBranchA的内容等于remotesBranchA 

7.新建分支

git branch xxNewBranchName  // 创建了xxNewBranchName新分支

8.查看分支状态,有无新增或修改的文件

git status  // 查看当前分支的文件状态,哪些是修改的,哪些是新增的还未被git 跟踪过

9.使新增的文件和git 建立track跟踪关系

git add . // add 后面有个小圆点(英文点),代表把当前目录所有文件add到本地的git上

10.提交新增和修改的文件到本地git

git commit -m "这里写上改动的注释"

11.拉取远程的文件,因为当前操作的分支可能有别的人push过文件

git pull // 拉取远程服务器中git文件

12.推送本地git管理的已经commit的文件到远程服务器的git代码仓库中去

   git push  // 推送后,再执行git status  会提示 nothing need commit ,这种推送只能用于本地分支已经和远程分支早就建立过关系


    git push <远程主机名一般是origin>  <本地分支名>:<远程分支名> 
// 注意,分支推送顺序的写法是<来源地>:<目的地>,所以git pull是<远程分支>:<本地分支>,而git push是<本地分支>:<远程分支>。

    e.g.:git push origin localBranchNameA:originBranchNameB // 假设远程不存在originBranchNameB分支,但我又想把本地分支localBranchNameA推送到远程去,就可以这样写。

    git push origin xxBranchName // 将本地分支xxBranchName 推送到origin主机的xxBranchName分支,如果后者不存在,则会被新建。

13.查看提交记录

git log // 查看所有操作日志。

git reflog  //查看操作命令历史记录 比git log 更详细

14.合并分支

        git merge develop // 将develop合并到当前分支去

15.删除分支

         git branch -d  xxBranchName   // 不论当前打开的分支是哪条,操作都是删除xxBranchName

         git push origin --delete xxBranchName  // 删除远程git仓库的分支
         git push origin :master   // 如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支。

 

解答疑虑:

1:git add 

git add * git会自动把你当前目录所有修改过的文件添加
git add . Git会递归地将你执行命令时所在的目录中的所有文件添加上去,所以如果你将当前的工作目录作为参数,它就会追踪那儿的所有文件

2: 拉取或者合并时,git如果弹出vi编辑器
      a.按i写完注释后,按esc
      b.再按 :wq (write and quit)

3:git push 的更深层使用
git push命令用于将本地分支的更新,推送到远程主机。它的格式与git pull命令相仿。

$ git push <远程主机名> <本地分支名>:<远程分支名>
注意,分支推送顺序的写法是<来源地>:<目的地>,所以git pull是<远程分支>:<本地分支>,而git push是<本地分支>:<远程分支>。

如果省略远程分支名,则表示将本地分支推送与之存在”追踪关系”的远程分支(通常两者同名),如果该远程分支不存在,则会被新建。

$ git push origin master
上面命令表示,将本地的master分支推送到origin主机的master分支。如果后者不存在,则会被新建。

如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支。

$ git push origin :master
# 等同于
$ git push origin --delete master
上面命令表示删除origin主机的master分支。

如果当前分支与远程分支之间存在追踪关系,则本地分支和远程分支都可以省略。

$ git push origin
上面命令表示,将当前分支推送到origin主机的对应分支。

如果当前分支只有一个追踪分支,那么主机名都可以省略。

$ git push
如果当前分支与多个主机存在追踪关系,则可以使用-u选项指定一个默认主机,这样后面就可以不加任何参数使用git push。

$ git push -u origin master
上面命令将本地的master分支推送到origin主机,同时指定origin为默认主机,后面就可以不加任何参数使用git push了。

不带任何参数的git push,默认只推送当前分支,这叫做simple方式。此外,还有一种matching方式,会推送所有有对应的远程分支的本地分支。Git 2.0版本之前,默认采用matching方法,现在改为默认采用simple方式。如果要修改这个设置,可以采用git config命令。

$ git config --global push.default matching
# 或者
$ git config --global push.default simple
还有一种情况,就是不管是否存在对应的远程分支,将本地的所有分支都推送到远程主机,这时需要使用–all选项。

$ git push --all origin
上面命令表示,将所有本地分支都推送到origin主机。

如果远程主机的版本比本地版本更新,推送时Git会报错,要求先在本地做git pull合并差异,然后再推送到远程主机。这时,如果你一定要推送,可以使用–force选项。


$ git push --force origin
上面命令使用–force选项,结果导致在远程主机产生一个”非直进式”的合并(non-fast-forward merge)。除非你很确定要这样做,否则应该尽量避免使用–force选项。

最后,git push不会推送标签(tag),除非使用–tags选项。

$ git push origin --tags

有时候当远程xxx分支被删掉了后,用git branch -a 你还可以看到本地还有remote/origin/xxx这个分支,那么你可以使用git fetch -p 这个命令可以帮你同步最新的远程分支,并删掉本地被删了的远程分支

你可能感兴趣的:(git)