一、安装
二、创建新创库
md <文件夹名称>,cd <文件夹名称>
git init
创建新的git仓库。
三、检出仓库
- 远程服务器仓库地址:
git clone <远程服务器仓库地址>
- 本地仓库克隆版本:
git clone /path/repository
如果想让本地clone仓库连接到远程服务器上,可使用
git remote add origin <地址>
此时如果出现错误信息:fatal: remote origin already exists.解决办法如下:
- 先输入
git remote rm origin
- 再输入
git remote add origin <地址>
就不会报错了! - 如果输入$ git remote rm origin 还是报错的话,error: Could not remove config section 'remote.origin'. 我们需要修改gitconfig文件的内容
- 找到你的github的安装路径,我的是C:\Users\ASUS\AppData\Local\GitHub\PortableGit_ca477551eeb4aea0e4ae9fcd3358bd96720bb5c8\etc
- 找到一个名为gitconfig的文件,打开它把里面的[remote "origin"]那一行删掉就好了!
添加删除文件及提交
- 首先创建一个README文件
-
git add <README>
或者git add *
- 如果想删除库中的文件,使用
git rm <文件名>
-
git commit -m "提交信息"
此时只是提交了HEAD,还需要下一步将改动提交至远程仓库.
当我们修改了很多文件,而不想每一个都add,想commit自动来提交本地修改,我们可以使用-a标识git commit -a -m "提交信息"
。注意,-a不会造成新文件被提交,只能修改。 -
git push origin master
master为需要提交的任何分支(首次提交使用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
其它命令
记录
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的文件过大会出现该问题
- 先检查一下硬盘内存是否充足;
git config --global core.compression 0
git clone --depth 1 <ssh or http>
-
git fetch --unshallow
同步提交记录`。 git fetch --depth=2147483647
git pull --all
- 这时候只能显示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"
设置我们想要的任意时间。