共计 2378 个字符,预计需要花费 6 分钟才能阅读完成。
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 仓库,有两种场景:
- 把已有项目代码纳入 Git 管理
- cd 项目代码所在文件夹
- git init,进行本地初始化
- 新建项目直接用 Git 管理
- cd 某个文件夹
- git init your_project,会在当前路径下创建和项目名称同名的文件夹
- 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: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
Git 自动管理凭证
正文完