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 这个命令可以帮你同步最新的远程分支,并删掉本地被删了的远程分支