git常用命令

Git 分支管理指南

本地分支操作

创建分支

使用git branch 分支名可以创建分支,但是不会自动切换到分支。需要手动切换。

使用git checkout -b 分支名可以创建并切换到分支。

$ git checkout -b dev
Switched to a new branch 'dev'

git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:

$ git branch dev
$ git checkout dev
Switched to branch 'dev'

例如在原来的master分支上进行了修改,并不提交,然后使用git checkout -b lab1命令可以创建并切换到lab1分支,然后将修改进行commit,然后执行git push origin lab1就可以看到修改的提交到了lab1分支了,原来的master分支没有修改。

创建并切换分支(现代写法)
git switch -c <分支名>

分支切换

git checkout 已存在分支名

git switch <分支名>

分支重命名

# 重命名当前分支
git branch -m <新分支名>

# 重命名指定分支
git branch -m <旧分支名> <新分支名>

删除分支

安全删除(已合并的分支):git branch -d 分支名称
强制删除(未合并的分支):git branch -D 分支名称

查看本地分支

用git branch命令查看当前分支【本地分支】:

$ git branch
* dev
  master

使用git branch -r 查看对应的【远程分支】:

$ git branch -r
  origin/local-v2.0

这是会看到master和dev,而且dev上会有一个星号,这个时候dev是一个本地分支,远程仓库不知道它的存在。

本地分支可以不同步到远程仓库,我们可以在dev开发,然后merge到master,使用master同步代码。

git branch --all  
# 默认只有master分支,所以会看到如下两个分支
# master[本地主分支] 
# origin/master[远程主分支]
# 新克隆下来的代码默认master和origin/master是关联的,也就是他们的代码保持同步
从远端拉取分支,并切换
$ git checkout -b springboot origin/springboot
Switched to a new branch 'springboot'
Branch 'springboot' set up to track remote branch 'springboot' from 'origin'.
如果出现如果出现fatal: Cannot update paths and switch to branch 'dev2' at the same time. Did you intend to checkout 'origin/dev2' which can not be resolved as commit?

表示拉取不成功。我们需要先执行

git fetch

然后再执行

git checkout -b 本地分支名 origin/远程分支名

即可。

分支比较

例如当前在master分支上,通过命令git diff dev可以比较当前分支与dev分支的差异。

合并本地分支

例如当前所在的分支为dev,需要将test分支合并到dev
git merge test,这样dev分支就与test分支一致了

分支开发工作流

在dev分支开发代码。

git switch -c feature/new-module  # 创建功能分支
# 进行开发...多次提交
git push -u origin feature/new-module  # 首次推送

# 完成开发后:
git switch main
git pull origin main  # 更新主分支
git merge --no-ff feature/new-module  # 合并功能分支
git push origin main

# 清理分支
git branch -d feature/new-module
git push origin --delete feature/new-module

远程分支管理

查看分支信息

# 本地分支(带*号为当前分支)
git branch

# 远程分支
git branch -r

# 所有分支(本地+远程)
git branch -a

推送本地分支

# 首次推送需建立关联
git push -u origin 分支名

# 后续推送可简写
git push

例如我们在dev分支上进行了修改,然后提交了,然后执行git push origin dev就可以将dev分支的代码推送到远程仓库了。

$ git checkout 分支名称
Switched to branch 'master'
发布到远端分支
git push origin dev  # 这样远程仓库也有一个dev分支了
git push origin 远端分支名

发布dev分支指的是同步dev分支的代码到远程服务器

拉取远程分支

# 标准拉取方式(推荐)
git fetch origin
git checkout -b 本地分支名 origin/远程分支名

删除远程分支

我们用git branch -r查看远程分支,查看到有两个分支local-v2.0master,我们想删除master分支。

# origin 表示远程仓库的别名
git push origin --delete master

远程仓库管理

查看远端仓库

$ git remote -v
origin  http://192.168.152.39/duandingyang/shenzhen.git (fetch)
origin  http://192.168.152.39/duandingyang/shenzhen.git (push)

删除远程仓库

使用命令git remote -v可以查看到远程仓库:

old-origin	http://192.168.1.100:81/user1/shenzhen.git (fetch)
old-origin	http://192.168.1.100:81/user1/shenzhen.git (push)
origin	http://192.168.1.101/user1/shenzhen.git (fetch)
origin	http://192.168.1.101/user1/shenzhen.git (push)

我们想删除origin对应的仓库地址,使用命令:

git remote remove origin

这样再通过git remote -v查看仓库:

old-origin	http://192.168.1.100:81/user1/shenzhen.git (fetch)
old-origin	http://192.168.1.100:81/user1/shenzhen.git (push)

添加远端仓库

git remote add origin https://github.com/vincentduan/selfweixin.git

其中origin就是为远端仓库所起的名字,一般叫做origin,其实你也可以叫做jack或者Rose什么的,后面的https://github.com/vincentduan/selfweixin.git就是你的远端仓库的真实地址。

git添加两个远程仓库

由于当前项目已经有一个远端仓库,根据需要需要添加另一个远端仓库。

首先需要在远端创建一个仓库:test-python

需要注意的是,添加一个远端分支名字不能是origin。

git remote add remote_iie4bu http://IP:81/test/test-python.git

然后查看,可以看到有两个远端分支:

$ git remote -v
origin  https://gitee.com/jack/test-python.git (fetch)
origin  https://gitee.com/jack/test-python.git (push)
remote_iie4bu   http://IP:81/jack/test-python.git (fetch)
remote_iie4bu   http://IP:81/jack/test-python.git (push)

使用git push remote_iie4bu 远端分支名就可以推送到远端分支remote_iie4bu
使用git pull remote_iie4bu 远端分支名就可以将远端分支拉取到本地了

设置免密登录

git解决每次拉取代码都需要用户名密码。

在命令行里执行git config --global credential.helper store,这会在gitconfig目录下创建一个文件,用于记录账号和密码;

再执行一次git pull,输入正确的账号密码,以后就不用再输了

git pull

git pull使用说明
git pull命令用于从另一个存储库或本地分支获取并集成(整合)。git pull命令的作用是:取回远程主机某个分支的更新,再与本地的指定分支合并,它的完整格式稍稍有点复杂。
使用语法

git pull [options] [<repository> [<refspec>…]]
描述

将远程存储库中的更改合并到当前分支中。在默认模式下,git pull是git fetch后跟git merge FETCH_HEAD的缩写。

更准确地说,git pull使用给定的参数运行git fetch,并调用git merge将检索到的分支头合并到当前分支中。 使用–rebase,它运行git rebase而不是git merge。
示例
以下是一些示例 -

$ git pull <远程主机名> <远程分支名>:<本地分支名>
比如,要取回origin主机的next分支,与本地的master分支合并,需要写成下面这样 -
$ git pull origin next:master
如果远程分支(next)要与当前分支合并,则冒号后面的部分可以省略。上面命令可以简写为:
$ git pull origin next
上面命令表示,取回origin/next分支,再与当前分支合并。实质上,这等同于先做git fetch,再执行git merge。

$ git fetch origin
$ git merge origin/next

在某些场合,Git会自动在本地分支与远程分支之间,建立一种追踪关系(tracking)。比如,在git clone的时候,所有本地分支默认与远程主机的同名分支,建立追踪关系,也就是说,本地的master分支自动”追踪”origin/master分支。
Git也允许手动建立追踪关系。
$ git branch --set-upstream master origin/next
上面命令指定master分支追踪origin/next分支。
如果当前分支与远程分支存在追踪关系,git pull就可以省略远程分支名。
$ git pull origin
上面命令表示,本地的当前分支自动与对应的origin主机”追踪分支”(remote-tracking branch)进行合并。

如果当前分支只有一个追踪分支,连远程主机名都可以省略。

$ git pull
上面命令表示,当前分支自动与唯一一个追踪分支进行合并。

如果合并需要采用rebase模式,可以使用–rebase选项。

$ git pull --rebase <远程主机名> <远程分支名>:<本地分支名>
git fetch和git pull的区别

git fetch:相当于是从远程获取最新版本到本地,不会自动合并。

$ git fetch origin master
$ git log -p master..origin/master
$ git merge origin/master

以上命令的含义:

首先从远程的origin的master主分支下载最新的版本到origin/master分支上

然后比较本地的master分支和origin/master分支的差别

最后进行合并

上述过程其实可以用以下更清晰的方式来进行:

$ git fetch origin master:tmp
$ git diff tmp 
$ git merge tmp
  1. git pull:相当于是从远程获取最新版本并merge到本地

git pull origin master

上述命令其实相当于git fetch 和 git merge
在实际使用中,git fetch更安全一些,因为在merge前,我们可以查看更新情况,然后再决定是否合并。

git reset
git reset就是当我们提交了错误的内容后进行回退使用的命令。

git reset 版本号,就是回退到该版本号上。

git reset --hard 命令可以把本地的所有修改都进行撤销。慎用!

git只拉取项目中的某个目录

使用 sparse clone 实现部分代码的拉取

假设我的项目目录是:

--my_project
  --proj1
  --proj2
  --proj3
  --proj4

现在我只想在服务器上拉取 proj2 目录下的东西。

$ mkdir my_project
$ cd my_project
$ git init
  Initialized empty Git repository in /home/user1/lib/username/.git/
$ git remote add -f origin http://xxx/user_name/my_project.git  #拉取remote的all objects信息
Updating origin
remote: Counting objects: 1141, done.
remote: Compressing objects: 100% (591/591), done.
remote: Total 1141 (delta 659), reused 871 (delta 491)
Receiving objects: 100% (1141/1141), 2.65 MiB | 10.07 MiB/s, done.
Resolving deltas: 100% (659/659), done.
From http://xxx/user_name/my_project
 * [new branch]      local-v2.0 -> origin/local-v2.0

$ git config core.sparsecheckout true   #开启sparse clone
# 默认没有sparse-checkout文件
$ echo "proj2" >> .git/info/sparse-checkout   #设置需要pull的目录,*表示所有,!表示匹配相反的

$ less .git/info/sparse-checkout
  proj2
$  git pull origin local-v2.0 #拉取
$ ls
 proj2

假如还想要拉取其他文件或者目录的话,可以通过 git sparse-checkout add 命令来添加。
这就实现了,远程仓库和云服务器仓库之间的定制化同步,需要什么目录和文件就同步什么目录和文件,不需要的可以统统不要。

  • git sparse-checkout disable表示禁用 git sparse-checkout
  • git sparse-checkout reapply表示重新启用git sparse-checkout

git 设置origin 默认上传url

当前远程分支情况如下:

$ git remote -v
gitee   https://gitee.com/jack/proj_1.git (fetch)
gitee   https://gitee.com/jack/proj_1.git (push)
origin  http://my_ip/rose/proj_1.git (fetch)
origin  http://my_ip/rose/proj_1.git (push)

我们输入git push时,默认会推送到origin对应的http://my_ip/rose/proj_1.git路径下。我们希望的是,输入git push可以推送到https://gitee.com/jack/proj_1.git下。

  1. 使用命令git remote set-url origin https://gitee.com/jack/proj_1.gitorigin连接到https://gitee.com/jack/proj_1.git下。这样我们输入git remote -v得到:
$ git remote -v
gitee   https://gitee.com/jack/proj_1.git (fetch)
gitee   https://gitee.com/jack/proj_1.git (push)
origin  https://gitee.com/jack/proj_1.git (fetch)
origin  https://gitee.com/jack/proj_1.git (push)

这将更改origin的URL,使其指向我想要提交的远程存储库。现在,当您运行git push命令时,它将默认将更改推送到https://gitee.com/jack/proj_1.git

  1. 使用以下命令将gitee删除:git remote remove gitee。输出如下:
origin  https://gitee.com/jack/proj_1.git (fetch)
origin  https://gitee.com/jack/proj_1.git (push)
  1. 从新添加新的分支:git remote add my_remote http://my_ip/rose/proj_1.git。输入命令git remote -v
my_remote http://my_ip/rose/proj_1.git (fetch)
my_remote http://my_ip/rose/proj_1.git (push)
origin  https://gitee.com/jack/proj_1.git (fetch)
origin  https://gitee.com/jack/proj_1.git (push)

修改origin名称

需求:

目前我们有一个项目从http://192.168.1.100/proj1.git拉取的。
我们想要把这个项目迁移到http://192.168.1.101/proj1.git上。

执行命令:

cd proj1
git remote rename origin old-origin
git remote add origin http://192.168.1.101/proj1.git
git push --set-upstream origin --all
git push --set-upstream origin --tags

git push --set-upstream origin --all 这个命令的含义是将本地的所有分支推送到远程仓库,并且设置这些分支的上游分支(upstream branch)为远程仓库的同名分支。这通常用于首次将本地仓库的分支与远程仓库进行关联,以后可以使用简化的 git push 命令来推送更改而不需要再指定远程分支。

具体解释如下:

  • git push: 这是用于将本地更改推送到远程仓库的 Git 命令。
  • --set-upstream: 这个选项告诉 Git 在推送时设置本地分支与远程分支之间的关联。
  • origin: 这是远程仓库的名称,通常情况下,“origin” 是默认的远程仓库名称,代表了你的代码托管服务(如 GitHub、GitLab、Bitbucket)上的仓库。
  • --all: 这个选项告诉 Git 推送所有本地分支到远程仓库。

因此,当你运行这个命令后,Git 会将所有本地分支的更改推送到远程仓库,并且为每个本地分支设置相应的上游分支,以后你可以使用 git push 来推送更改,Git 将自动知道要将更改推送到哪个远程分支。

git commit

  • 查看最近一次提交中有哪些文件被修改了:git diff --name-only HEAD~1
  • 如果执行了git commit -m "update"命令,但是想撤销某个文件夹的修改,可以使用git restore --source=HEAD~1 ssd/embedding/ 命令将ssd/embedding/下的所有文件重新添加回暂存区。

将分支1上的修改移到分支2上

本来想在分支2上进行代码修改,但由于疏忽,在分支1上进行了修改。想将修改迁移到分支2上,而保持分支1不变。

  1. 首先在分支2上暂存修改:
git checkout dev2
git stash
  1. 切换到分支1并应用暂存:
git checkout dev1
git stash apply stash

将分支1上的某个文件(夹)合并到分支2上

比如有两个分支,分别是devmaster,如果我想将dev分支的某个文件(或者文件夹)合并到master分支。应该如何操作?

  1. 首先切换到master分支。git checkout master
  2. dev检出文件或整个文件夹。
    • git checkout dev -- path/to/folder
    • git checkout dev -- path/to/file
  3. 这样就将dev的文件(夹)合并到了master
### Git 常用命令汇总 #### 本地操作 - **初始化仓库** 使用 `git init` 初始化一个新的 Git 仓库。[^1] - **添加文件到暂存区** 使用 `git add <file>` 将文件添加到暂存区。如果需要添加所有文件,可以使用 `git add .`。 - **提交代码到本地库** 使用 `git commit -m '提交描述'` 提交更改到本地仓库。如果需要同时完成 `add` 和 `commit` 操作,可以使用 `git commit -a -m '提交描述'`。 - **修改最后一次提交** 如果需要将当前的 `add` 操作合并到上一次的提交中,可以使用 `git commit --amend`。 #### 远程操作 - **关联远程仓库** 使用 `git remote add origin <远程仓库地址>` 关联远程仓库。[^3] - **查看远程库信息** 使用 `git remote -v` 查看当前配置的远程仓库信息。 - **上传数据到远程库** 使用 `git push -u origin <分支名>` 将本地分支推送到远程仓库,并设置上游分支。之后可以直接使用 `git push` 推送更改。[^3] - **从远程库拉取代码** 使用 `git pull origin <分支名>` 从远程仓库拉取代码并合并到当前分支。这相当于执行了 `git fetch` 和 `git merge` 两个操作。[^2] - **克隆远程仓库** 使用 `git clone <远程仓库地址>` 克隆一个远程仓库到本地。 #### 分支操作 - **创建新分支** 使用 `git branch <分支名>` 创建一个新的分支。 - **切换分支** 使用 `git checkout <分支名>` 切换到指定分支。如果需要同时创建并切换分支,可以使用 `git checkout -b <分支名>`。[^1] - **合并分支** 使用 `git merge <分支名>` 将指定分支合并到当前分支。 - **删除分支** 使用 `git branch -d <分支名>` 删除指定分支。如果强制删除未合并的分支,可以使用 `git branch -D <分支名>`。 #### 多人协作开发 - **更新本地代码** 在多人协作开发中,使用 `git pull --rebase origin <分支名>` 更新本地代码,避免产生过多的合并提交记录。 - **解决冲突** 当出现代码冲突时,Git 会标记冲突部分。手动编辑解决冲突后,使用 `git add <文件名>` 标记为已解决,然后继续执行 `git rebase --continue` 或者 `git commit`。[^3] ```bash # 示例:解决冲突后继续 rebase git rebase --continue ``` #### 其他常用命令 - **查看状态** 使用 `git status` 查看当前仓库的状态,包括哪些文件被修改或未跟踪。 - **查看提交历史** 使用 `git log` 查看提交历史。如果需要简洁的输出,可以使用 `git log --oneline`。 - **查看差异** 使用 `git diff` 查看工作目录与暂存区之间的差异。如果需要查看暂存区与最近一次提交的差异,可以使用 `git diff --staged`。[^1]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值