您的位置:首页 > 技术中心 > PHP教程 >

如何二十分钟搞懂git的基础使用

时间:2022-01-05 17:37

本篇文章给大家带来了git的基本使用相关知识,其中包括git的基本操作,分支操作以及更改提交的操作等等,希望对大家有帮助。

1. 设置SSH Key

设置 SSH Key 使得设备可以有权限访问账户里面的代码仓库

$ ssh-keygen -t rsa -C "your_email@example.com"
  • "your_email@example.com" 设置为自己GitHub账户的注册邮箱
  • id_rsa 文件是私有密钥,id_rsa.pub 是公开密钥。
$ cat ~/.ssh/id_rsa.pub

ssh-rsa 公开密钥的内容 your_email@example.com

  • 然后把公钥拷贝下来,添加到账户里面,注意要把前面的 ssh-rsa 也拷贝下来
  • 头像》Settings》SSH Key》new SSH Key

接下来验证一下,出现successfully字样即为成功

$ ssh -T git@github.com
Enter passphrase for key '/c/Users/MYPC/.ssh/id_rsa':
Hi abc! You've successfully authenticated, but GitHub does not provide shell access.

2. git 基本操作

2.1 git clone 已有仓库

$ git clone git@github.com:hirocastest/Hello-World.git

这里会要求输入 GitHub 上设置的空开密钥的密码,认证成功后,仓库便会被 clone 到当前目录中。

2.2 git add 将文件加入暂存区

代码编写完成之后,将代码添加到系统的暂存区

$ git add 文件夹/文件

2.3 git commit 保存仓库的历史记录

git commit 命令可以将当前暂存区中的文件实际保存到仓库的历史记录中。通过这些记录,我们就可以在工作树中复原文件。

$ git commit -m "记录一行提交信息"
  • m 表示对这个提交的概述,如果想要记录详细信息,就把 - m 去掉

2.4 git push

之后只要执行 push 命令,GitHub 上的仓库就会被更新

$ git push

2.5 git init 初始化仓库

clone 方法建立仓库,不需要执行 init 操作。如果要把本地文件设置为仓库,那么就需要进行 init 操作

$ mkdir git-tutorial

$ cd git-tutorial

$ git init

2.6 git status 查看仓库状态

$ git status
# On branch master
#
# Initial commit
#
nothing to commit (create/copy files and use "git add" to track)

结果现实,我们正处于 masteer 分支下,并且没有可提交的内容

2.7 git log 查看提交日志

git log 命令可以查看以往仓库中提交的日志。包括什么人在什么时候进行了提交或合并

$ git log
commit 5dbbff6e009abb8a6cc44187c93b694f94fbf82a (HEAD -> main, origin/main, origin/HEAD)
Author: ywm <ywm_up@qq.com>
Date:   Sun Feb 28 17:17:00 2021 +0800

只想现实提交信息的第一行,可以在 git log 命令后加上 -- pretty=short

$ git log --pretty=short

2.8 git diff 查看更改前后的差别

执行 git diff 查看当前工作书与暂存区的差别

$ git diff

3. 分支操作

可以创建多个分支,同时进行完全不同的作业。等分支作业完成之后再与 master 分支合并。通过灵活运用分支,可以让多人同时高效的进行并发开发。

3.1 git branch 显示分支一览表

master 分支左侧有 “*”(星号),表示这是我们当前所在的分支。

$ git branch
* master

3.2 git checkout 创建、切换分支

创建并切换到分支 feature-A

$ git checkout -b feature-A

实际上,上面那条命令,等价于下面两条命令

$ git branch feature-A

$ git checkout feature-A

切换回分支 mian

$ git checkout main

切换回上一个分支

$ git checkout -
  • 操作一下:创建一个新的分支 feature,在新的分支上修改 README.md,并且 add、commit

通过实际操作可以证明:只要创建多个分支,就可以在不互相影响的情况下同时进行多个功能的开发

3.3 git merge 合并分支

合并时加上 --no–ff 参数,可以保存之前的分支历史

$ git merge --no-ff feature

随后编辑器会启动,用于录入合并提交的信息

3.4 git log --graph 以图标的形式查看分支

$ git log --graph

4. 更改提交的操作

4.1 git reset 回溯历史版本

$ git reset --hard 目标时间点的hash值

通过 git reflog 查看当前仓库的操作日志,可以找到回溯历史之前的哈希值。只要不进行 git 的 GC(垃圾回收),就可以通过日志随意调取近期的历史状态。即便开发者错误执行了 git 操作,基本也可以用 git reflog 命令恢复到原先的状态。

$ git reflog

上面打印的是最近的操作,下面打印的是最旧的操作

4.2 消除冲突

  • 合并操作的时候,容易出现冲突,这时候需要打开编辑器,来解决冲突
  • 在实际开发中,往往需要删除其中之一,所以务必要仔细分析冲突部分的内容后再进行修改
  • 解决冲突之后,再进行 add 和 commit 操作

如果对上一条提交信息不满意,可以使用 amend 参数进行修改

$ git commit --amend

4.3 git rebase -i 压缩历史

在合并分支之前,如果发现已提交的内容中有些拼写错误,不妨提交一个修改,然后将这个修改包含到前一个提交之中,压缩成一个历史记录。

git rebase -i HEAD~2

可以选定档期按分支中包含 HEAD 在内的两个最新历史记录为对象,并在编辑器中打开

5 推送至远程仓库

5.1 git remote add 添加远程仓库

在创建新仓库的时候,建议不要勾选 README.md 文件,这样会使本地仓库和远程仓库失去整合性。虽然到时候可以强制覆盖,但防止这一情况发生,还是不要勾选,就创建一个空仓库就好。

git remote 在先写代码,后创建仓库的情况下能较好的使用

$ git remote add origin git@github.com:github-book/git-tutorial.git

对于一般先创仓库,后写代码的,需要先 pull 下来仓库,再对文件进行修改

5.2 git push 推送至远程仓库

推送至 master 分支

$ git push -u origin master

-u 参数可以在推送的同时,将 origin 仓库的 master 分支设置为本地仓库当前分支的 upstream(上游),添加这个参数,将来运行 git pull 命令从远程仓库获取内容的时候,本地仓库的这个分支就可以直接从 origin 的 masteer 分支获取内容,省去了另外添加参数的麻烦

除了 master 分支之外,还可以推送到其他分支

$ git checkout -b feature-D

$ git push -u origin feature-D

6 从远程仓库中获取

6.1 git clone 获取远程仓库

$ git clone git仓库地址

将本地的 feature-D 分支更新到最新状态

$ git pull origin feature-D
  • 多名开发者在同一个分支中进行作业时,为减少冲突情况的发生,建议更频繁的进行 push 和 pull 操作

推荐学习:《Git教程》

以上就是如何二十分钟搞懂git的基础使用的详细内容,更多请关注gxlsystem.com其它相关文章!

热门排行

今日推荐

热门手游