关于Git的常用操作

我自己用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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值