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 或者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

更新与合并

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

  • 第二种方式:
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 
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

替换本地改动

假如你操作失误,你可以使用如下命令替换掉本地改动:
`git checkout --
此命令会使用 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
  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 "[email protected]"

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"设置我们想要的任意时间。

你可能感兴趣的:(Git使用)