Git使用

一、安装

OSX版本下载
Windows版本下载
Linux版本下载

二、创建新创库

md <文件夹名称>,cd <文件夹名称>
git init
创建新的git仓库。

三、检出仓库

  • 远程服务器仓库地址:
    git clone <远程服务器仓库地址>
  • 本地仓库克隆版本:
    git clone /path/repository

如果想让本地clone仓库连接到远程服务器上,可使用
git remote add origin <地址>
此时如果出现错误信息:fatal: remote origin already exists.解决办法如下:

  1. 先输入git remote rm origin
  2. 再输入git remote add origin <地址>就不会报错了!
  3. 如果输入$ git remote rm origin 还是报错的话,error: Could not remove config section 'remote.origin'. 我们需要修改gitconfig文件的内容
  4. 找到你的github的安装路径,我的是C:\Users\ASUS\AppData\Local\GitHub\PortableGit_ca477551eeb4aea0e4ae9fcd3358bd96720bb5c8\etc
  5. 找到一个名为gitconfig的文件,打开它把里面的[remote "origin"]那一行删掉就好了!

添加删除文件及提交

  1. 首先创建一个README文件
  2. git add <README>或者git add *
  3. 如果想删除库中的文件,使用git rm <文件名>
  4. git commit -m "提交信息"此时只是提交了HEAD,还需要下一步将改动提交至远程仓库.
    当我们修改了很多文件,而不想每一个都add,想commit自动来提交本地修改,我们可以使用-a标识 git commit -a -m "提交信息"。注意,-a不会造成新文件被提交,只能修改。
  5. git push origin mastermaster为需要提交的任何分支(首次提交使用git push -u origin master

提示:在第4步中,如果使用git commit而没有添加-m,则显示Vim编辑器。按下小写字母i,进入编辑模式,此模式下输入你想要的commit message,输入完成后按下ESC退出编辑,进入命令模式,这时按下英文输入法下的冒号,再输入wq,就可以保存退出了。w是write,q是quit。也可以在按esc退出编辑模式以后,切换到大写模式,连按两下Z(shirft+zz)。
如果用不惯这个编辑器的话,可以通过配置git config --global core.editor <其它文本编辑器的执行文件的路径>,这样需要调用文本编辑器时,就不会用默认的vi了。譬如设置成notepad++,sublimetext等等。如果是ubuntu等*nix系统,可以换用gedit或者nano等简单操作的编辑器,git config --global core.editor nano。gedit有gui,通过xshell等工具远程访问的话,需要配置xming这样的工具,把远程机器上的ui内容显示到当前本地机器的显示器上。

分支

创建一个叫做“feature”的分支,并切换过去:
git checkout -b feature -b表示分支不存在创建
切换回主分支:
git checkout master
再把新建的分支删掉:
git branch -d feature
将分支推送到远端仓库,该分支才能为他人所见的:
git push origin <branch名>

更新与合并

更新仓库最新的改动
git pull
要合并其他分支到你的当前分支(例如 master),执行:
git merge <branch>
以上两种情况,git 都会尝试去自动合并改动。遗憾的是,这可能并非每次都成功,并可能出现冲突(conflicts)。 这时候就需要你修改这些文件来手动合并这些冲突(conflicts)。改完之后,你需要执行如下命令以将它们标记为合并成功:
git add <filename>
在合并改动之前,你可以使用如下命令预览差异:
git diff <source_branch> <target_branch>

  • 第二种方式:
git checkout master
git pull
git pull origin feature
git push

无论谁来做合并,首先要检出master分支并确认是它是最新的。然后执行git pull origin feature合并feature分支到和已经和远程一致的本地master分支。
你可以使用简单git merge feature命令,但前面的命令可以保证总是最新的新功能分支。
最后更新的master分支要重新push回到origin。

rebase

  • 远程仓库master做了修改,已经不是local的master的原始拉取处,会认为我们这个local分支too old了,所以我们往往需要使用git rebase命令来在master的tip上重新运行我们local分支上的commit以便保持一个线性的历史。但是如果master分支在我们创建local分支之后一直没有改变,那么一个fast-forward merge就是足够的了。

git pull --rebase origin master
rebase操作过程是把本地提交一次一个的迁移到更新了的中央仓库master分支之上。

  • 若出现冲突,可以使用git status查看冲突文件加以修改,然后使用
git add <file_name>
git rebase --continue
  • 如碰到冲突无法解决 使用git rebase --abort回到git pull --rebase命令之前的状态。

Git会继续一个一个地合并后面的提交,如其它的提交有冲突就重复这个过程。

标签

git tag 1.0.0 1b2e1d63ff
1b2e1d63ff 是你想要标记的提交 ID 的前 10 位字符。可以使用下列命令获取提交 ID:
git log
你也可以使用少一点的提交 ID 前几位,只要它的指向具有唯一性。
最后 有必要的的话
git push origin <tab名>

替换本地改动

假如你操作失误,你可以使用如下命令替换掉本地改动:
`git checkout -- <filename>
此命令会使用 HEAD 中的最新内容替换掉你的工作目录中的文件。已添加到暂存区的改动以及新文件都不会受到影响。

假如你想丢弃你在本地的所有改动与提交,可以到服务器上获取最新的版本历史,并将你本地主分支指向它:
git fetch origin获取远程版本库的提交
git reset --hard origin/master

git stash

当我们想切换分支时,需要先将当前分支进行commit。如果当前没有开发完或不需要commit该怎么办!可以使用stash暂存。
git stash 或 git stash save “msg方便查找”
git checkout [其他branch]
...
git checkout [开始的branch]
git stash list查看暂存列表
git stash pop 恢复并删除
git stash apply 恢复不删除
git stash apply stash@{num} 指定哪个stash
git stash drop stash@{num}指定删除
git stash clear 删除全部
git show -p stash@{xx} 查看diff

其它命令

git_big_jb51.jpg

记录

1. git无法pull仓库refusing to merge unrelated histories

想把一个写完的项目放到github上,在Github新建一个仓库,写了License,然后把本地一个写了很久仓库上传。

先pull,因为两个仓库不同,发现refusing to merge unrelated histories,无法pull。

因为它们是两个不同的项目,要把两个不同的项目合并。
假如我们的源是origin,分支是master,那么我们 需要这样写git pull origin master --allow-unrelated-histories成功后再push。需要知道,我们的源可以是本地的路径

2.clone时出现The remote end hung up unexpectedly错误

fatal: The remote end hung up unexpectedly 
fatal: early EOF 
fatal: index-pack failed

我是在clone时出现的问题,不是push。
clone的文件过大会出现该问题

  1. 先检查一下硬盘内存是否充足;
  2. git config --global core.compression 0
  3. git clone --depth 1 <ssh or http>
  4. git fetch --unshallow 同步提交记录`。
  5. git fetch --depth=2147483647
  6. git pull --all
  7. 这时候只能显示master分支,可通过git branch -a查看。
    进入项目对应的.git文件夹找到config将
    fetch = +refs/heads/master:refs/remotes/origin/master修改为
    fetch = +refs/heads/*:refs/remotes/origin/*
    最后️的一点是 下载过程中可能会中断,多试几次。

stackoverflow上也有以下三种解决方法,未尝试:

  • 压缩方式:git config --add core.compression -1
  • 提交缓存大小:git config http.postBuffer 524288000
  • 配置网速限制:git config --global http.lowSpeedLimit 0
    git config --global http.lowSpeedTime 999999

3.git查看和修改用户名和邮箱

查看:

git config user.name
git config user.email

修改:

git config --global user.name "xxx"
git config --global user.email "xxx@xxx.com"

4.本地分支切换关联的远程分支

git push --set-upstream origin branch_name

来在远程创建一个与本地branch_name同名的分支并跟踪;

git checkout --track origin/branch_name

来在本地创建一个与branch_name同名分支跟踪远程分支。

4.commit --amend及修改commit时间

git commit --amend会把本次commit追加到上次commit中,达到本次与上次合并效果,前提是上次commit未push到origin。
git commit --amend的时间为上一次时间,可以通过git commit --amend --date="$(date -R)"修改为当前时间。也可通过date -R获取时间格式,再通过
git commit --amend --date="Mon, 12 Jun 2023 14:44:44 +0800"设置我们想要的任意时间。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容