天天看点

Git / GitHub 再学习_记录总结 下载安装Git / 注册GitHub配置Git 并 设置GitHub ssh密钥 Git初步实现本地与远程同步 Git 进阶一. 工作区 与 版本库( 暂缓区, 主分支 )二. 时光穿梭机三. 远程仓库四. 分支管理五. 标签管理六. 自定义Git其他 Git 命令

文章目录

  • 下载安装Git / 注册GitHub
  • 配置Git 并 设置GitHub ssh密钥
  • Git初步
  • 实现本地与远程同步
    • < 0 > 初始化本地工作区仓库 并 关联GitHub仓库
    • < 1 > 保存到本地版本库的暂缓区
    • < 2 > 提交 本地版本库暂缓区 到 本地版本库当前分支
    • < 3 > 将 本地仓库 推送到 远程仓库
  • Git 进阶
  • 一. 工作区 与 版本库( 暂缓区, 主分支 )
  • 二. 时光穿梭机
    • 版本回退
    • 查看修改
    • 撤销修改
    • 删除文件
  • 三. 远程仓库
    • 添加远程仓库
    • 从远程仓库克隆
  • 四. 分支管理
    • 创建与合并分支
    • 解决冲突
    • 分支管理策略
    • Bug 分支
    • Feature 分支
    • 多人协作
    • Rebase
  • 五. 标签管理
    • 使用 GitHub
    • 使用码云
  • 六. 自定义Git
    • 忽略特殊文件
    • 配置别名
    • 搭建 Git 服务器
  • 其他 Git 命令
    • 拉取 远程仓库 的修改到本地
    • 克隆一个项目到本地
    • 查看本地仓库文件状态
    • .gitignore 忽略指定文件
    • warning: LF will be replaced by CRLF in
    • 保留仓库, 删除仓库里的文件
    • 相关 Git 学习文章
    • 其他 Git 命令记录

下载安装Git / 注册GitHub

不详细介绍了, 详情 Google 一下更精彩

配置Git 并 设置GitHub ssh密钥

先设置全局的姓名和邮箱, 让人知道是谁修改的

注意带双引号

git config --global user.name "xxx"
git config --global user.email "[email protected]"
           

生成密钥

按三个回车, 密码为空.

生成成功后,去对应目录 C:\Users\acmaker.ssh里( acmaker 为电脑用户名, 找到自己的用户名 )

用记事本打开id_rsa.pub,复制ssh key公钥

Git / GitHub 再学习_记录总结 下载安装Git / 注册GitHub配置Git 并 设置GitHub ssh密钥 Git初步实现本地与远程同步 Git 进阶一. 工作区 与 版本库( 暂缓区, 主分支 )二. 时光穿梭机三. 远程仓库四. 分支管理五. 标签管理六. 自定义Git其他 Git 命令

然后到 GitHub 上, Settings, SSH and GPK keys, 添加一个 ssh

这样本地 Git 就关联到 GitHub 了

Git初步

实现本地与远程同步

< 0 > 初始化本地工作区仓库 并 关联GitHub仓库

首先进入工作区目录, 初始化本地仓库

git init
           

关联远程仓库

git remote add origin 仓库url
           

取消关联

git remote rm origin
           

< 1 > 保存到本地版本库的暂缓区

注意把工作区所有文件修改的文件加入到暂缓区, 这个命令有个点

把工作区所有的文件加入到暂缓区

git add --all
           

添加一个文件

git add test.cpp
           

< 2 > 提交 本地版本库暂缓区 到 本地版本库当前分支

< 3 > 将 本地仓库 推送到 远程仓库

git push -u origin master
           

此时可能会产生本地仓库和远程仓库内容不同的错误

fatal: refusing to merge unrelated histories

远程仓库GitHub 初始化的时候一般是选择生成一个 README.md , 而本地项目是没有这个的, 所以导致本地仓库和远程仓库不符

这个时候或者手动删除远程仓库的 README.md 或者 强行拉下来, 如下

git pull origin master --allow-unrelated-histories
           

或者强行 推上去, 如下

git push -u origin master -f 
           

使得两个仓库同步起来,

Git 进阶

一. 工作区 与 版本库( 暂缓区, 主分支 )

Git / GitHub 再学习_记录总结 下载安装Git / 注册GitHub配置Git 并 设置GitHub ssh密钥 Git初步实现本地与远程同步 Git 进阶一. 工作区 与 版本库( 暂缓区, 主分支 )二. 时光穿梭机三. 远程仓库四. 分支管理五. 标签管理六. 自定义Git其他 Git 命令

二. 时光穿梭机

版本回退

查看版本提交日志

完整日志

git log
           

精简日志

git log --pretty=oenline
           

回退到上一个版本

git reset --hard HEAD^
           

回退到上上个版本

git reset --hard HEAD^^
           

回退到一百个之前的版本…

git reset --hard HEAD~100
           

回退到指定版本, 1933a是版本号id前几位

git reset --hard 1933a
           

查看发送过的命令日志

git reflog
           

查看修改

查看工作区有哪些文件改动

git status
           

查看工作区某文件的改动内容

git diff HEAD -- readme.txt
           

撤销修改

丢弃工作区所有更改, 从暂缓区恢复( 前提是没有添加到 暂存区 )

丢弃暂缓区里的更改, 从主分支恢复 ( 前提是没有提交到 主分支 )

丢弃主分支里的更改, 看版本回退那一节

这是删除 暂存区 所有更改

** 介绍一种 一二命令的糅合, 直接从 主分支 恢复 上次提交到主分支的内容

删除文件

在被 git 管理的目录中删除文件时,可以选择如下两种方式来记录删除动作:

rm + git commit -am "abc"
           
git rm + git commit -m "abc"
           

另外,git add . 仅能记录添加、改动的动作,删除的动作需靠 git rm 来完成。

最后,rm 删除的文件是处于 not staged 状态的,

也就是一种介于 “未改动” 和 “已提交过” 之间的状态。

删除文件夹

git rm -r mydir
           

三. 远程仓库

添加远程仓库

关联仓库

git remote add origin [email protected]:path/repo-name.git
           

第一次关联以后, 推送所有内容, 一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令

git push -u origin master
           

以后推送

git push origin master
           

从远程仓库克隆

git clone [email protected]:yourName/yourRepository.git
           

四. 分支管理

创建与合并分支

查看分支

git branch
           

创建分支

切换分支

git checkout <name>
或者
git switch <name>
           

创建 并 切换分支

git checkout -b <name>
或者
git switch -c <name>
           

合并某分支到当前分支

删除分支

点击传送廖老师的详细讲解

解决冲突

分支管理策略

Bug 分支

git stash用于保存和恢复工作进度
git stash

保存当前的工作进度。会分别对暂存区和工作区的状态进行保存

git stash save "message..."

这条命令实际上是第一条 git stash 命令的完整版

git stash list

显示进度列表。此命令显然暗示了git stash 可以多次保存工作进度,并用在恢复时候进行选择

git stash pop [--index] [<stash>]

如果不使用任何参数,会恢复最新保存的工作进度,并将恢复的工作进度从存储的工作进度列表中清除。

如果提供参数(来自 git stash list 显示的列表),则从该 <stash> 中恢复。恢复完毕也将从进度列表中删除 <stash>。

选项--index 除了恢复工作区的文件外,还尝试恢复暂存区。

git stash apply [--index] [<stash>]

除了不删除恢复的进度之外,其余和 git stash pop 命令一样

git stash clear

删除所有存储的进度
           

Feature 分支

多人协作

Rebase

五. 标签管理

如果关联报错, 可以如下命令查看指向的远程库信息

git remote -v
           

然后删除之前关联的远程库

git remote rm origin
           

如果要关联多个远程库, 需要自定义命名远程分支

git remote add github GitHubRepository
git remote add gitee GiteeRespository
---------
推送的时候就需要
git push github master
git push gitee master
           

使用 GitHub

使用码云

六. 自定义Git

忽略特殊文件

.gitignore

检查 某文件 被哪个命令忽略了

git check-ignore
           

具体忽略指定文件的语法看文章底部, 其他 Git 命令

配置别名

局部配置文件是在当前仓库 .git/config

git config --global alias.st status
git config --global alias.co checkout
git config --global alias.ci commit
git config --global alias.br branch
git config --global alias.unstage 'reset HEAD'
           

搭建 Git 服务器

其他 Git 命令

拉取 远程仓库 的修改到本地

git pull origin master
           

克隆一个项目到本地

查看本地仓库文件状态

git status
           

.gitignore 忽略指定文件

在工作区根目录下, 新建一个 .gitignore

更多语法 Google 一下

*.exe
*.ini
/Temporary

# 忽略 .a 文件
*.a
# 但否定忽略 lib.a, 尽管已经在前面忽略了 .a 文件
!lib.a
# 仅在当前目录下忽略 TODO 文件, 但不包括子目录下的 subdir/TODO
/TODO
# 忽略 build/ 文件夹下的所有文件
build/
# 忽略 doc/notes.txt, 不包括 doc/server/arch.txt
doc/*.txt
# 忽略所有的 .pdf 文件 在 doc/ directory 下的
doc/**/*.pdf
           

warning: LF will be replaced by CRLF in

CRLF : windows 环境下的换行符

LF : linux 环境下的换行符

就是说文件中存在两种环境的换行符, git 会自动替换 CRLF 为 LF, 所以提示警告

解决方案:

保留仓库, 删除仓库里的文件

GitHub 可以删除仓库, 但是不能删除某一个文件或者文件夹

但是我们可以在本地建一个仓库, 把他拉下来, 然后全删了, 再提交

emm, 虽然是有点笨, 但是对于菜鸟来说简单易用就就行 hhh

相关 Git 学习文章

CSDN Git 科普文

配置密钥 及 上传本地仓库

其他 Git 命令记录

修改、提交、删除

git add index.php
# 添加index.php文件到缓存区
git add .
# 添加所有改动过的文件到缓存区
git add --all
# 添加所有文件到缓存区

git commit
# 提交缓存区内的文件(回车后需要键入描述:wq保存退出)
git commit -m "描述"
# 提交缓存区内的文件,并提供描述

git commit -am '描述'
# 将add和commit合为一步
git commit --amend -m 'xxx'
# 合并最后一次提交(用于反复修改)

git rm index.php
# 删除index.php文件
git rm --cached index.php
# 将index.php文件移出缓存区,但不删除( -r * 递归目录)
git rm -f 1.html
# 将缓存区中的1.html文件移出并删除
查看
git status
# 查看当前版本状态(是否修改)

git diff
# 查看所有添加到缓存区的变更(工作区与版本库的区别)
git diff index.php
# 查看工作区文件和库文件区别
git diff --cached
# 查看所有已添加到缓存区,但还未commit的变更(缓存区与版本库的区别)

git log
# 查看提交历史
git log --oneline
# 以简短的方式查看提交日志

git reflog
# 行为日志,显示所有提交,回滚等..
git ls-files
# 显示缓存区的所有文件
回退 与 撤销
git reset --hard HEAD
# 将当前版本重置为HEAD(通常用于merge失败回退)

git reset --hard HEAD^   # 回退上一个版本
git reset --hard HEAD^^  # 回退上两个版本
git reset --hard HEAD~n  # 回退上n个版本

git reset --hard <commitid>
# 回退指定版本,commitid根据log获取

git checkout --filename
# 在工作区撤销文件的修改
git checkout HEAD [filename]
# 撤回添加至缓存区的修改,不指定filename则撤回所有
分支操作
git pull origin master
# 获取远程分支master并merge到当前分支

git branch
# 显示本地分支
git branch -a
# 显示所有分支
git checkout 分支名/标签名
# 切换到指定分支或标签

git branch 分支名
# 新建分支
git branch -d 分支名
# 删除本地分支 -D 强制删除
远程协作
git remote add <remote> <url>
# 添加远程版本库
git remote -v
# 查看远程版本库信息
git remote show <remote>
# 查看指定远程版本库信息
git remote remove <remote>
# 删除远程remote链接
git remote rename <old> <new>
# 重命名远程链接名

git pull <remote> <branch>
# 下载代码及快速合并

git push <remote> <branch>
# 上传代码及快速合并

git merge origin master
# 将本地的远端库合并

git fetch origin
# 将远端库获取本地但不合并