当前位置:   article > 正文

Git常用指令使用

Git常用指令使用

摘要:之前代码管理都是借助于fork、sourceTree等图形工具,最近发现直接用命令也好用,就总结Git常用的指令

1、Git的介绍

1.1 git官网

        安装: Git - Downloading Packageicon-default.png?t=N7T8https://git-scm.com/download/mac        Mac上安装,直接使用,并使用查看版本,验证安装成功

  1. czh12@czh12deiMac ~ % brew install git
  2. Running `brew update --auto-update`...
  3. Error: Failed to download https://formulae.brew.sh/api/formula.jws.json!
  4. Failed to download https://formulae.brew.sh/api/cask.jws.json!
  5. ==> Downloading https://formulae.brew.sh/api/formula.jws.json
  6. ######################################################################## 100.0%
  7. ==> Downloading https://formulae.brew.sh/api/cask.jws.json
  8. -=O=- # # # #
  9. curl: (28) Operation too slow. Less than 100 bytes/sec transferred the last 5 seconds
  10. Error: Failure while executing; `/usr/bin/env /opt/homebrew/Library/Homebrew/shims/shared/curl --disable --cookie /dev/null --globoff --user-agent Homebrew/4.0.11-93-g367fe53\ \(Macintosh\;\ arm64\ Mac\ OS\ X\ 11.6\)\ curl/7.64.1 --header Accept-Language:\ en --fail --progress-bar --location --remote-time --output /Users/czh12/Library/Caches/Homebrew/api/cask.jws.json --compressed --speed-limit 100 --speed-time 5 --progress-bar https://formulae.brew.sh/api/cask.jws.json` exited with 28. Here's the output:
  11. -=O=- # # # #
  12. curl: (28) Operation too slow. Less than 100 bytes/sec transferred the last 5 seconds
  13. ==> Downloading https://formulae.brew.sh/api/cask.jws.json
  14. ######################################################################## 100.0%
  15. ==> Fetching dependencies for git: gettext and pcre2
  16. ==> Fetching gettext
  17. ==> Downloading https://raw.githubusercontent.com/Homebrew/homebrew-core/6b9f22a
  18. -=O=- # # # #
  19. curl: (22) The requested URL returned error: 404
  20. Error: git: Failed to download resource "gettext--ruby-source"
  21. Download failed: https://raw.githubusercontent.com/Homebrew/homebrew-core/6b9f22abafb887533d9dc5dd06f604b52ba7c24e/Formula/gettext.rb
  22. czh12@czh12deiMac ~ % git -v
  23. unknown option: -v
  24. usage: git [--version] [--help] [-C <path>] [-c <name>=<value>]
  25. [--exec-path[=<path>]] [--html-path] [--man-path] [--info-path]
  26. [-p | --paginate | -P | --no-pager] [--no-replace-objects] [--bare]
  27. [--git-dir=<path>] [--work-tree=<path>] [--namespace=<name>]
  28. <command> [<args>]
  29. czh12@czh12deiMac ~ % git --version
  30. git version 2.30.1 (Apple Git-130)

1.2 重要概念

        Git、GitHub 和 GitLab 的区别

  1. Git

    Git 是一个分布式版本控制系统,用于跟踪文件的变化并协助多人协作开发项目。开发者可以通过 Git 轻松地创建分支、提交更改、合并代码等操作,从而有效地管理代码版本。Git 允许每个开发者在本地拷贝完整的代码仓库,并且可以独立工作,无需依赖中央服务器。

  2. GitHub

    GitHub 是一个基于 Git 的代码托管平台,提供了代码仓库托管、团队协作、问题追踪、持续集成等功能。开发者可以在 GitHub 上创建公开或私有的代码仓库,与团队成员共享代码,进行代码审查,管理项目等。GitHub 是一个社交化的平台,开发者可以在上面交流、学习和分享代码。

  3. GitLab

    GitLab 也是一个基于 Git 的代码托管平台,类似于 GitHub,但提供了更多的功能和服务。除了代码托管外,GitLab 还包括持续集成、部署管道、代码审查、事务管理等功能。GitLab 可以作为自托管的解决方案,企业可以在自己的服务器上搭建 GitLab 实例,更好地控制数据和安全性

        四个区域

        工作区→暂存区→本地仓库→远端仓库

  1. 工作区(Working Directory)

    工作区是指存放项目源文件的目录,是开发者直接编辑和修改代码的地方。在工作区中进行的修改不会被 Git 跟踪或记录。

  2. 暂存区(Staging Area)

    暂存区是一个中间区域,用于临时存放已经修改但还未提交到本地仓库的更改。开发者可以通过将工作区的修改内容暂存到暂存区,然后一次性提交到本地仓库。

  3. 本地仓库(Local Repository)

    本地仓库是存放项目完整历史记录和版本信息的地方,包含所有提交的快照和元数据。当开发者提交(commit)更改时,这些更改会被永久保存到本地仓库中。

  4. 远端仓库(Remote Repository)

    远端仓库是分布式版本控制系统中的远程存储库,通常托管在云端或其他服务器上。开发者可以将本地仓库中的更改推送(push)到远端仓库,或者从远端仓库拉取(pull)最新的更改到本地仓库。

        HEAD:当前所在位置 在 Git 中,HEAD 是一个指向当前所在位置的符号引用。它可以指向当前所在的分支(通常是最新提交的快照)或直接指向特定的提交。 HEAD 通常用于表示当前工作目录所基于的提交版本,也可以用来切换分支、查看历史记录等操作。

        master:主分支

        在 Git 中,master 是默认的主分支名称,新建仓库时通常会自动创建这个分支。 开发者可以在 master 分支上进行主要的开发工作,也可以根据需要创建其他分支进行功能开发或修复。

        branch:分支

        分支是 Git 中用于独立开发某个功能或修复某个问题的机制。通过创建分支,可以在不影响主线开发的情况下进行并行开发。 每个分支包含自己的提交历史,可以随时切换不同的分支进行工作。

        origin:远端

        在 Git 中,origin 是默认的远端仓库名称,通常指向项目在远程服务器上的中央仓库。 当克隆一个远程仓库时,Git 会自动为远程仓库创建一个名为 origin 的别名,方便开发者与远程仓库进行交互。

2、单人开发常用Git命令

2.1 git 配置

        配置的生效范围,全局、系统和本地的Git配置文件。例如:

        git config --global:使用全局配置文件(用户层面)

        git config --system:使用系统配置文件(系统层面)

        git config --local:使用仓库配置文件(本地项目)

  1. czh12@czh12deiMac ~ % git config --global user.name 'czh12'
  2. czh12@czh12deiMac ~ % git config --global user.email 'czh12@163.com'
  3. czh12@czh12deiMac ~ % git config --get user.name
  4. czh12
  5. czh12@czh12deiMac ~ % git config --get user.email
  6. czh12@163.com

        2.2 创建仓库实现初次提交

        初始化git仓库

  1. czh12@czh12deiMac ~ % cd /Users/czh12/Desktop/git
  2. czh12@czh12deiMac git % pwd
  3. /Users/czh12/Desktop/git
  4. czh12@czh12deiMac git % ls
  5. imooc_git
  6. czh12@czh12deiMac git % git init imooc_git
  7. hint: Using 'master' as the name for the initial branch. This default branch name
  8. hint: is subject to change. To configure the initial branch name to use in all
  9. hint: of your new repositories, which will suppress this warning, call:
  10. hint:
  11. hint: git config --global init.defaultBranch <name>
  12. hint:
  13. hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
  14. hint: 'development'. The just-created branch can be renamed via this command:
  15. hint:
  16. hint: git branch -m <name>
  17. Initialized empty Git repository in /Users/czh12/Desktop/git/imooc_git/.git/

        注:查看隐藏文件夹 shift +command + .

        git对文件的增删改查

        add添加到暂存区:git add

        commit 提交到本地仓库: git commit

        status 查看状态: git status

  1. czh12@czh12deiMac git % ls
  2. imooc_git
  3. czh12@czh12deiMac git % cd imooc_git
  4. czh12@czh12deiMac imooc_git % ls
  5. month.txt
  6. **## add添加到暂存区:git add 文件名
  7. czh12@czh12deiMac imooc_git % git add month.txt
  8. czh12@czh12deiMac imooc_git % git status
  9. On branch master
  10. No commits yet
  11. Changes to be committed:
  12. (use "git rm --cached <file>..." to unstage)
  13. new file: month.txt
  14. ## commit 提交到本地仓库: git commit
  15. czh12@czh12deiMac imooc_git % git commit
  16. [master (root-commit) 054f99a] first commit
  17. 1 file changed, 4 insertions(+)
  18. create mode 100755 month.txt
  19. czh12@czh12deiMac imooc_git % git status
  20. On branch master
  21. nothing to commit, working tree clean
  22. ## 修改文件后未上传到暂存区, status 查看状态: git status
  23. czh12@czh12deiMac imooc_git % git status
  24. On branch master
  25. Changes not staged for commit:
  26. (use "git add <file>..." to update what will be committed)
  27. (use "git restore <file>..." to discard changes in working directory)
  28. modified: month.txt
  29. no changes added to commit (use "git add" and/or "git commit -a")
  30. czh12@czh12deiMac imooc_git % git add month.txt
  31. czh12@czh12deiMac imooc_git % git status
  32. On branch master
  33. Changes to be committed:
  34. (use "git restore --staged <file>..." to unstage)
  35. modified: month.txt
  36. ## 一步完成提交到暂存区和本地仓库
  37. czh12@czh12deiMac imooc_git % git commit -a
  38. [master cf664e3] commit -a
  39. 1 file changed, 3 insertions(+)

        rm 移除文件:git rm 文件名

        mv 重命名文件:git mv 原名 改后名称

  1. czh12@czh12deiMac imooc_git % git add month2.txt
  2. czh12@czh12deiMac imooc_git % git commit
  3. [master f350d57] month2.txt
  4. 1 file changed, 7 insertions(+)
  5. create mode 100755 month2.txt
  6. **## 移除文件:git rm 文件名**
  7. czh12@czh12deiMac imooc_git % git rm month2.txt
  8. rm 'month2.txt'
  9. czh12@czh12deiMac imooc_git % git status
  10. On branch master
  11. Changes to be committed:
  12. (use "git restore --staged <file>..." to unstage)
  13. deleted: month2.txt
  14. czh12@czh12deiMac imooc_git % git commit
  15. [master d6080b7] remove month2.txt
  16. 1 file changed, 7 deletions(-)
  17. delete mode 100755 month2.txt
  18. czh12@czh12deiMac imooc_git % git status
  19. On branch master
  20. nothing to commit, working tree clean
  21. ## 重命名文件:git mv 原名 改后名称
  22. czh12@czh12deiMac imooc_git % git mv month.txt monthname.txt
  23. czh12@czh12deiMac imooc_git % git commit
  24. [master 524d2ce] rename month.txt
  25. 1 file changed, 0 insertions(+), 0 deletions(-)
  26. rename month.txt => monthname.txt (100%)

        git log help 看所有选项

        git log -n 限定log个数

        git log —oneline 单行简洁模式

        git log —stat 查看提交历史以及每次提交所引入的更改的统计信息

        git log --author='提交者' 按提交者查询

        git log --grep='关键字' 按照关键字搜索提交记录

  1. czh12@czh12deiMac imooc_git % git log --help
  2. ## git log -n
  3. czh12@czh12deiMac imooc_git % git log -1
  4. commit 524d2ce4e9757710202e5d8b117eb7dc52212fd3 (HEAD -> master)
  5. Author: czh12 <czh12@163.com>
  6. Date: Mon Mar 25 15:35:28 2024 +0800
  7. rename month.txt
  8. czh12@czh12deiMac imooc_git % git log --oneline
  9. 524d2ce (HEAD -> master) rename month.txt
  10. d6080b7 remove month2.txt
  11. f350d57 month2.txt
  12. cf664e3 commit -a
  13. 054f99a first commit
  14. czh12@zh12deiMac imooc_git % git log --stat
  15. commit 524d2ce4e9757710202e5d8b117eb7dc52212fd3 (HEAD -> master)
  16. Author: czh12 <czh12@163.com>
  17. Date: Mon Mar 25 15:35:28 2024 +0800
  18. rename month.txt
  19. month.txt => monthname.txt | 0
  20. 1 file changed, 0 insertions(+), 0 deletions(-)
  21. czh12@czh12deiMac imooc_git % git log --author='czh12'
  22. commit 524d2ce4e9757710202e5d8b117eb7dc52212fd3 (HEAD -> master)
  23. Author: czh12 <czh12@163.com>
  24. Date: Mon Mar 25 15:35:28 2024 +0800
  25. rename month.txt
  26. czh12@czh12deiMac imooc_git % git log --grep='month'
  27. commit 524d2ce4e9757710202e5d8b117eb7dc52212fd3 (HEAD -> master)
  28. Author: czh12 <czh12@163.com>
  29. Date: Mon Mar 25 15:35:28 2024 +0800
  30. rename month.txt
  31. commit d6080b76aeadba837132ac6ccee67cfc129b4d45
  32. Author: czh12 <czh12@163.com>
  33. Date: Mon Mar 25 15:33:15 2024 +0800
  34. remove month2.txt
  35. commit f350d57a52c64cc6467b8c6841f494e441711541
  36. Author: czh12 <czh12@163.com>
  37. Date: Mon Mar 25 15:31:15 2024 +0800
  38. month2.txt

2.3 git的图形化界面

learnGitBranching

Learn Git Branchingicon-default.png?t=N7T8https://learngitbranching.js.org/?locale=zh_CN&NODEMO=

gitk安装:brew install git

2.4 分支Branch

        创建分支:git branch 分支名

        切换分支:git checkout 分支名

  1. czh12@czh12deiMac imooc_git % git branch imoocbranch1
  2. czh12@czh12deiMac imooc_git % git checkout imoocbranch1
  3. Switched to branch 'imoocbranch1'
  4. ## 创建分支并切换
  5. czh12@czh12deiMac imooc_git % git checkout -b imoocbranch2
  6. Switched to a new branch 'imoocbranch2'

2.5 其他使用场景

        git reset 撤销工作目录中的更改、回退到之前的提交或者修改提交历史

        git reset --hard <commit-hash> :撤销所有从指定提交之后的更改,包括暂存区的更改

        git reset --hard HEAD^ : ^号的个数为回退步数

        git reset --hard HEAD~n :n为回退步数

        场景:撤销最近的提交,可使用偏移符号:^和~

  1. ## 回退时使用:^的个数表示回退的提交数,~n中n表示回退的提交数
  2. czh12@czh12deiMac imooc_git % git reset --hard HEAD^
  3. HEAD is now at d6080b7 remove month2.txt
  4. czh12@czh12deiMac imooc_git % git reset --hard HEAD~2
  5. HEAD is now at cf664e3 commit -a

        git rebase: 变基,会改变原有分支的路径,将一系列提交到一个新的基础提交上

        git rebase main :将imooc分支上原有提交,重新提交到main分支(下图中'表示变基过)

        合并commit

        git reset --soft <commit-hash> : 当前分支的 HEAD 指针移动到指定的提交(commit-hash),同时保留工作目录(working directory)和暂存区(staging area)中的更改。再重新提交,将多次commit合并提交。

        场景: 清理提交历史,移除不必要的提交或者合并提交;也可以撤销最近的提交再重新提(git reset --soft HEAD^)

  1. czh12@czh12deiMac imooc_git % git log -4
  2. commit 9cd46ac5fa118a83ef86365eb1a394086e692442 (HEAD -> master)
  3. Author: czh12 <czh12@163.com>
  4. Date: Mon Mar 25 17:20:23 2024 +0800
  5. jul
  6. commit 985a67b124381309110b526d355ec4465172823d
  7. Author: czh12 <czh12@163.com>
  8. Date: Mon Mar 25 17:17:57 2024 +0800
  9. jun
  10. commit fa6d3d1bdd85dd5961d7392612ef9e5bd0b437aa
  11. Author: czh12 <czh12@163.com>
  12. Date: Mon Mar 25 17:16:51 2024 +0800
  13. may
  14. commit **cf664e39f3bf1**fe7347e2c30ce3662171f395510
  15. Author: czh12 <czh12@163.com>
  16. Date: Mon Mar 25 11:37:27 2024 +0800
  17. commit -a
  18. czh12@czh12deiMac imooc_git % **git reset --soft ****cf664e39f3bf1fe**
  19. czh12@czh12deiMac imooc_git % git status
  20. On branch master
  21. Changes to be committed:
  22. (use "git restore --staged <file>..." to unstage)
  23. modified: month.txt
  24. czh12@czh12deiMac imooc_git % git add monthname.txt
  25. fatal: pathspec 'monthname.txt' did not match any files
  26. czh12@czh12deiMac imooc_git % git add month.txt
  27. czh12@czh12deiMac imooc_git % git commit
  28. [master 2c71f6e] may june july
  29. 1 file changed, 6 insertions(+)
  30. czh12@czh12deiMac imooc_git % git log -3
  31. commit 2c71f6e8b83f2b25c7c3f41437ad4876e77f325d (HEAD -> master)
  32. Author: czh12 <czh12@163.com>
  33. Date: Mon Mar 25 17:34:01 2024 +0800
  34. **may june july**
  35. commit cf664e39f3bf1fe7347e2c30ce3662171f395510
  36. Author: czh12 <czh12@163.com>
  37. Date: Mon Mar 25 11:37:27 2024 +0800
  38. commit -a
  39. commit 054f99a8e676a6727d49e31270e05e4e8c2c9fc7
  40. Author: czh12 <czh12@163.com>
  41. Date: Mon Mar 25 11:29:59 2024 +0800
  42. first commit

        修改commit

        git commit --amend 修复的意思,但只能修改最新的一次提交

  1. czh12@czh12deiMac imooc_git % git add month.txt
  2. czh12@czh12deiMac imooc_git % git commit --amend
  3. [master 5f84ec5] may june july Augest
  4. Date: Mon Mar 25 17:34:01 2024 +0800
  5. 1 file changed, 6 insertions(+)
  6. czh12@czh12deiMac imooc_git % git log -1
  7. commit 5f84ec5c1c59f87983753fc492a86d6e0c91d2fc (HEAD -> master)
  8. Author: czh12 <czh12@163.com>
  9. Date: Mon Mar 25 17:34:01 2024 +0800
  10. **may june july Augest**

        修改之前某次指定的提交

        git rebase -i <commit-hash>

        然后选择edit, 编辑指定的提交

  1. czh12@czh12deiMac imooc_git % git rebase -i cf664e39f3bf1fe734
  2. Stopped at 5f84ec5... may june july Augest
  3. You can amend the commit now, with
  4. git commit --amend ## 提示后续步骤
  5. Once you are satisfied with your changes, run
  6. git rebase --continue ## 提示后续步骤
  7. ## 此处选择edit
  8. edit 5f84ec5 may june july Augest
  9. pick 2c7995d Sep
  10. pick 7e7ba3a Oct
  11. # Rebase cf664e3..7e7ba3a onto cf664e3 (3 commands)
  12. #
  13. # Commands:
  14. # p, pick <commit> = use commit
  15. # r, reword <commit> = use commit, but edit the commit message
  16. # e, edit <commit> = use commit, but stop for amending
  17. # s, squash <commit> = use commit, but meld into previous commit
  18. # f, fixup <commit> = like "squash", but discard this commit's log message
  19. # x, exec <command> = run command (the rest of the line) using shell
  20. # b, break = stop here (continue rebase later with 'git rebase --continue')
  21. # d, drop <commit> = remove commit
  22. # l, label <label> = label current HEAD with a name
  23. # t, reset <label> = reset HEAD to a label
  24. # m, merge [-C <commit> | -c <commit>] <label> [# <oneline>]
  25. # . create a merge commit using the original merge commit's
  26. # . message (or the oneline, if no original merge commit was
  27. # . specified). Use -c <commit> to reword the commit message.
  28. #
  29. # These lines can be re-ordered; they are executed from top to bottom.
  30. #
  31. # If you remove a line here THAT COMMIT WILL BE LOST.
  32. #
  33. # However, if you remove everything, the rebase will be aborted.
  34. #
  35. ~
  36. ~
  37. czh12@czh12deiMac imooc_git % git add month.txt
  38. czh12@czh12deiMac imooc_git % git commit --amend
  39. [detached HEAD 4d9c942] may June july Augest
  40. Date: Mon Mar 25 17:34:01 2024 +0800
  41. 1 file changed, 6 insertions(+)
  42. czh12@zh12deiMac imooc_git % git rebase --continue
  43. Successfully rebased and updated refs/heads/master.

        撤销操作

        撤销当前分支的变化

        场景:切换到错误的分支,并提交了多次,但提交的代码是依然需要的

        git reset --soft commitID 回退代码,但依然保存提交内容

        git stash 储藏代码

        git commit 提交代码

        上述操作会将多次提交合并为一次提交

3. 团队开发中常用Git命令

未完待续……

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/343553
推荐阅读
相关标签
  

闽ICP备14008679号