一、常见的形式
二、本地仓库常用命令
2.1 提交版本
git add 文件名 #工作区 => 暂存区
git commit -m "提交说明信息" #暂存区 => 版本区
2.2 版本回退
git reset --mixed 版本号 #版本区 => 暂存区
git reset --soft 版本号 #暂存区 => 工作区
#直接回退版本到工作区
git reset --hard 版本号 #版本区 => 暂存区 => 工作区
2.3 状态和日志
git log #显示提交历史记录,包括每个提交的作者、日期和提交信息。
git reflog #操作记录
git status #查看当前工作目录和暂存区的状态。它会显示有关文件的更改和未跟踪文件的信息
git diff #查看文件的改动内容,包括与上一次提交的差异
2.4 针对仓库命令
2.4.1 初始化/创建仓库
git init
git init [project-name] # 新建一个目录,将其初始化为Git代码库
2.4.2 克隆远程仓库
git clone 仓库ssh/http地址 本地路径 #将远程仓库的内容克隆到本地
git clone -b 分支名 仓库地址 #克隆分支
2.4.3 拉取和推送
git fetch和git pull都可以更新本地库。
git fetch origin本地库并没有变化,git fetch只会将本地库所关联的远程库的commit id更新至最新,HEAD没有变化很容易理解,因为本地库并没有变化。
git pull origin master:master
本地库更新至最新,git pull会将本地库更新至远程库的最新状态,由于本地库进行了更新,HEAD也会相应的指向最新的commit id,所以虽然从结果上来看,git pull = git fetch + git merge,但是从文件中保存的commit id来看,实现上不是这样实现的。
#git pull 远程库地址别名 远程分支名:将远程仓库对于分支最新内容拉下来后与当前本地分支直接合并
git pull origin master # 拉取 远程仓库别名 origin ,本地仓库分支 master
git fetch origin
#git push 别名 分支:推送本地分支上的内容到远程仓库
git push origin master # 推送 远程仓库别名 origin ,本地仓库分支 master
git remote -v #查看别名
git remote add 别名 git远程库的详细地址 #增加远程库别名
# 如git remote add git-demo https://github.com/testeryueyue/git-demo.git
git push 别名 master #利用别名,推送本地库文件到远程库
2.5 针对分支命令
#查
git branch #列出所有分支
git branch -a #列出所有本地分支和远程分支
#增
git branch [branch-name] #创建分支
#切
git checkout -b [branch] #切换分支
git checkout [branch-name] #切换到指定分支,并更新工作区
#合
git merge [branch] #合并指定分支到当前分支
#删
git branch -d [branch-name] #删除本地分支
git push origin --delete [branch-name] # 删除远程分支
git branch -dr [remote/branch] # 删除远程分支
2.6 标签
git tag #列出所有tag
git show [tag] #查看tag信息
git tag [tag] #新建一个tag在当前commit
git tag [tag] [commit] # 新建一个tag在指定commit
git tag -d [tag] #删除本地tag
git push origin :refs/tags/[tagName] #删除远程tag
git push [remote] [tag] #提交指定tag
git push [remote] --tags # 提交所有tag
git checkout -b [branch] [tag] #新建一个分支,指向某个tag
三、git无法推送问题
但是在执行git push的时候又遇到问题了,总提示remote: error: refusing to update checked out branch: refs/heads/master 拒绝更新 后来又经一番搜索,得知,git默认拒绝push操作,我们需要修改配置,需要git的config配置,增加如下配置: [receive] denyCurrentBranch = ignore 于是乎,问题解决,可以正常使用git了。