我自己用Git时常用的操作
1.git安装后填写自己的信息:姓名和邮箱
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
2.由于Git clone时太慢了 所以做以下操作,亲测有效
首先打开代理,其次给Git设置全局代理:
git config --global http.proxy http://127.0.0.1:1080
git config --global https.proxy https://127.0.0.1:1080
注意自己的端口号是不是1080,然后就可以开始clone了,这种方法仅对https协议有效,对于ssh协议是无效的,以后每次clone都需要开代理,但真的很快。
3.初始化仓库
//显示当前所在目录
$ pwd
//在一个目录文件下初始化该目录为仓库
$ git init
4.上传文件
语法:$ git push <远程主机名> <本地分支名>:<远程分支名> 若省略远程分支,代表将本地当前分支推送到远端对应分支
//要先add
$ git add readme.txt
// 然后commit,-m 是对本次提交的描述
$ git commit -m "create readme.txt"
//最后推上去,第一次向远程仓库提交加 -u参数
$ git push -u origin master
5.添加远程仓库
// 添加远程仓库,一般给远程仓库命名为origin
$ git remote add origin git@github.com:jasondong-1/gitpractice.git
//我一般都是现在本地准备好文件然后推到github上去,或者直接从github上clone下来,
//都不用连接远程仓库
//clone 项目, 后面也可再跟一个名字,即重命名git库
$ git clone git@github.com:jasondong-1/gitpractice.git
6.分支管理
//新建分支,每当我们开始工作时,首先先从服务器上pull下来工程,然后新建分支,
//在分支上工作,工作完成后,在合并分支到主分支上;
//创建分支
$ git branch dev
//查看git下所有分支 ,*表示当前分支
$ git branch
//切换分支
$ git checkout dev
//创建并切换分支
$ git checkout -b dev
合并分支
//在新分支上修改文件并提交
$ git add readme.txt
//首先切换回master分支
$ git checkout master
// 合并分支到当前分支
$ git merge dev
//采用非fast-forward方式合并分支
git merge --no-ff -m "merge with no-ff" dev
//删除分支
$ git branch -d dev
//查看分支合并图
$ git log --graph
7.冲突解决
假如在一个新的分支上修改了readme并进行提交,master上也对readme进行了修改,而且修改的是同一行,也commit了,那么合并新分支到master时会报错
//自动合并失败,手动解决冲突后,重新提交
$ git merge feature1
Auto-merging readme.txt
CONFLICT (content): Merge conflict in readme.txt
Automatic merge failed; fix conflicts and then commit the result.
//手动解决冲突然后重新提交
$ git add readme.txt
$ git commit -m "fixed conflict"
一般当你修改本地的工程,别人也修改并且上传到服务器之后,你上传之前要先pull一下,然后会提示你还有一些修改的文件没有上传,怎么办?先隐藏自己修改的东西,Git stash,然后pull下来之后,回退隐藏栈,将修改的东西取出来并覆盖。
//添加文件到栈
$ git stash
//查看栈中的list
$ git stash list
//回退一个版本,也就是出栈
$ git stash pop
8.上传时忽略一些文件
要修改.gitignore文件中的方法
首先创建一个.gitignore文件,然后这个文件放在和.git这个隐藏文件夹同级的位置
内容语法如下:
# 此为注释 – 将被 Git 忽略
*.a # 忽略所有 .a 结尾的文件
!lib.a # 但 lib.a 除外
/TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/ # 忽略 build/ 目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
注意:.gitignore只能忽略那些原来没有被追踪的文件,即没有被push上去过得文件,当然,你可以先清楚本地的缓存,将这些文件纳入未被追踪的状态,然后在提交;
git清除本地缓存命令如下:
$ git rm -r --cached .
$ git add .
$ git commit -m 'update .gitignore'
下面有些人会遇到加上这个文件,发现忽略的文件还是有上传。
原因:
在git库中已存在了这个文件,之前push提交过该文件。
.gitignore文件只对还没有加入版本管理的文件起作用,如果之前已经用git把这些文件纳入了版本库,就不起作用了
解决:
需要在git库中删除该文件,并更新。
然后再次git status查看状态,文件不再显示状态。
10.强制覆盖本地代码(最好不要用)
$ git fetch --all
$ git reset --hard origin/master
$ git pull