Git实用笔记
Git的作用是版本控制,即管理文件夹。
下载Git
Git官网下载地址:https://git-scm.com/downloads
本地管理步骤
# 1 进入要管理的文件夹,进行本地初始化
git init
# 查看当前文件状态(新增和修改过的文件都是红色)
git status
# 2 添加一个或多个文件到暂存区
git add [file1] [file2]
# 添加指定目录到暂存区
git add [dir]
# 添加当前目录下的所有文件到暂存区
git add .
# 将文件移出暂存区
git rm --cached [file1]
# 配置个人信息:用户名、邮箱(可选)
git config --global user.name '李小龙'
git config --global user.email '1@qq.com'
# 3 生成版本
git commit -m "描述信息"
# 查看版本记录
git log
# 版本记录图形展示(h是哈希值,s是提交记录)
git log --graph --pretty=format:"%h %s"
# 4 创建分支,使用 -M 强制重命名
git branch -M main
回滚
# 回滚至之前版本
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:abc/learn-go.git)
git remote add origin 远程仓库地址
# 向远程仓库推送代码(-u选项可以不写,例如把本地dev推送到远程dev:git push origin dev)
# 加 -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实现
- 生成公钥和私钥,默认放在~/.ssh目录下,id_rsa.pub公钥、id_rsa私钥:
ssh-keygen
- 拷贝公钥内容,并设置到GitHub中
- 在Git本地中配置ssh地址:git remote add origin git@github.com/abc/hello.git
- 以后使用:git push origin master