首页 文章 正文

Git实用笔记

2023.8.2 文章 165

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管理
    1. cd 项目代码所在文件夹
    2. git init,进行本地初始化
  2. 新建项目直接用Git管理
    1. cd 某个文件夹
    2. git init your_project,会在当前路径下创建和项目名称同名的文件夹
    3. 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实用笔记 文章-第1张

回滚

# 回滚至之前版本
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选项即--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
  1. 转载请保留原文链接:Git实用笔记 https://aboss.top/post/174/
  2. 本站所有资源文章出自互联网收集整理,本站不参与制作,如果侵犯了您的合法权益,请联系本站我们会及时删除。
  3. 本站发布资源来源于互联网,可能存在水印或者引流等信息,请用户擦亮眼睛自行鉴别,做一个有主见和判断力的用户。
  4. 本站资源仅供研究、学习交流之用,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担。
  5. 联系方式(#替换成@):mail#aboss.top
相关推荐Git

    评论

    热门搜索