编辑
2026-04-01
undefined
00

目录

下载安装Git
配置个人信息:用户名、邮箱 git config --global user.name '李小龙' git config --global user.email '1@qq.com'
创建仓库
1 查看当前文件状态(新增和修改过的文件都是红色) git status
2 添加一个或多个文件到暂存区
添加指定目录到暂存区
添加当前目录下的所有文件到暂存区
将文件移出暂存区
3 生成版本
查看版本记录
版本记录图形展示(h是哈希值,s是提交记录)
4 创建分支,使用 -M 强制重命名
文件重命名
回滚
回滚至之前版本 git reset --hard 版本号
查看所有历史版本信息
回滚至之后版本
四步曲(添,提,拉,推)
分支
变基
GitHub
克隆远程仓库代码(内部已实现 git remote add origin 远程仓库地址)
指定分支,-b选项指定特定分支,比如dev分支或标签v1
切换分支(git branch 查看分支可能看不到,但可以切换分支,如果有分支的话)
分支合并(如在dev上开发,需要把master合并到dev,确保dev代码最新:git merge master)
拉取远程仓库代码
等价于
Git标签
配置
项目配置文件:项目/.git/config git config --local user.name '李小龙' git config --local user.email '1@qq.com'
全局配置文件:~/gitconfig
系统配置文件:/etc/.gitconfig
免密登录
URL中体现
SSH实现

Git的作用是版本控制,即管理文件夹。

下载安装Git

官网下载:https://git-scm.com/downloads

官方文档:https://git-scm.com/book/zh/v2

使用Git之前的最小配置:

配置个人信息:用户名、邮箱 git config --global user.name '李小龙' git config --global user.email '1@qq.com'

global对当前用户所有仓库有效,local只对某个仓库有效,system对系统所有登录的用户有效。

创建仓库

建Git仓库,有两种场景:

  1. 把已有项目代码纳入Git管理

  2. cd 项目代码所在文件夹

  3. git init,进行本地初始化

  4. 新建项目直接用Git管理

  5. cd 某个文件夹

  6. git init your_project,会在当前路径下创建和项目名称同名的文件夹

  7. cd your_project

1 查看当前文件状态(新增和修改过的文件都是红色) git status

2 添加一个或多个文件到暂存区

git add [file1] [file2]

添加指定目录到暂存区

git add [dir]

添加当前目录下的所有文件到暂存区

git add .

将文件移出暂存区

git rm --cached [file1]

3 生成版本

git commit -m "描述信息"

查看版本记录

git log

版本记录图形展示(h是哈希值,s是提交记录)

git log --graph --pretty=format:"%h %s"

4 创建分支,使用 -M 强制重命名

git branch -M main

文件重命名

git mv 旧文件名 新文件名

回滚

回滚至之前版本 git reset --hard 版本号

查看所有历史版本信息

git reflog

回滚至之后版本

git reset --hard 版本号

四步曲(添,提,拉,推)

实际工作开发四步曲:添,提,拉,推,其作用分别是:

  • 添:将修改内容添加到本地暂存区 git add
  • 提:将本地暂存区内容提交到本地代码库 git commit -m 'description'
  • 拉:同步,拉取远程代码库内容 git pull。在多人协同开发中十分重要,因为假如事先没有同步更新到最新版本有可能会覆盖别人修改的东西,假如拉取后有冲突,解决冲突即可
  • 推:将本地代码库内容推送到远程代码仓库 git push

分支

git branch # 查看分支 git branch 分支名称 # 创建分支,如dev、bug分支 git checkout 分支名称 # 切换分支 git merge 要合并的分支 # 分支合并 git branch -d 分支名称 # 删除分支分支合并可能会产生冲突,需要手动解决冲突。快速解决冲突可以使用软件,如Beyond Compare,比较方便直观。

变基

作用是合并提交记录,使代码变得简洁,建议合并记录时不要合并那些已push到远程仓库的记录。

把最近3条提交记录合并成1条:git rebase -i HEAD~3

合并分支:git rebase 分支,在git rebase过程中可能会产生冲突,需要手动解决冲突。解决完冲突后,执行命令:git rebase --continue继续变基。

GitHub

给远程仓库起别名(git@github.com
/learn-go.git) git remote add origin 远程仓库地址 # 向远程仓库推送代码。-u选项即--set-upstream用来设置上游分支,在本地分支和远程分支之间建立一个关联 # 执行一次带-u选项的git push后,以后只需使用git push就可将本地分支推送到对应的远程分支,不需要每次都指定远程仓库和分支 # 加 -f 强制推送 git push -u origin 分支

克隆远程仓库代码(内部已实现 git remote add origin 远程仓库地址)

git clone 远程仓库地址

指定分支,-b选项指定特定分支,比如dev分支或标签v1

git clone -b dev 远程仓库地址

切换分支(git branch 查看分支可能看不到,但可以切换分支,如果有分支的话)

git checkout 分支名称

分支合并(如在dev上开发,需要把master合并到dev,确保dev代码最新:git merge master)

git merge 要合并的分支

拉取远程仓库代码

git pull origin 分支

等价于

git fetch origin 分支 # 远程仓库到版本库 git merge origin/分支 # 版本库到工作区

Git标签

tag通常用于标记项目的特定版本,例如版本 1.0 或 2.0。

创建带有注释的tag:git tag -a v1 -m "第一版"

查看标签详细信息:git show [tagname]

推送所有tag:git push --tags,这将推送所有尚未在远程仓库上的本地标签。

配置

项目配置文件:项目/.git/config git config --local user.name '李小龙' git config --local user.email '1@qq.com'

全局配置文件:~/gitconfig

git config --global user.name '李小龙' git config --global user.email '1@qq.com'

系统配置文件:/etc/.gitconfig

git config --system user.name '李小龙' git config --system user.email '1@qq.com'

免密登录

URL中体现

原来的地址: https://github.com/abc/hello.git

修改后地址: https://用户名:密码@github.com/abc/hello.git

SSH实现

  1. 生成公钥和私钥,默认放在~/.ssh目录下,id_rsa.pub公钥、id_rsa私钥:ssh-keygen
  2. 拷贝公钥内容,并设置到GitHub中
  3. 在Git本地中配置ssh地址:git remote add origin git@github.com/abc/hello.git
  4. 以后使用:git push origin master

本文作者:a

本文链接:

版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!