Git 实战

托管中心维护远程库

  • 内网:可以自己搭建一个GitLab服务器
  • 外网:可以使用码云、Github

版本控制工具

  • 集中式:CSV ,SVN,VSS
  • 分布式Git,Darcs,...

Git命令行操作

1.1本地库初始化

进入文件夹

git init
注意:生成的 .git 目录中存放的是本地库相关文件,不要删除

1.2设置签名

  • 项目(仓库)级别仅在当前本地库有效 git config user.name tom #设置用户名tom git config user.email liu@qq.com #设置用户邮箱
  • 系统用户级别仅在当前登录的操作系统用户有效 git config --global user.name tom git config --global user.email liu@qq.com

仅仅加了一个 --global 优先级别:项目级别 > 系统级别 信息保存位置:~/.gitconfig 文件

1.3基本操作

1.3.1 状态查看

git status   #查看工作区、暂存区状态

1.3.2 添加

git add fileName  #指定文件
git add . #所有
说明:将工作区的文件添加到暂存区

1.3.3 提交

git commit -m 'commit message' fileName
说明:将暂存区内容提交到本地库

1.3.4 查看历史记录

git log 
git reflog  #常用
git log --greph #图形显示,更直观
git log --pretty=oneline #漂亮一行显示
git log --oneline #简洁显示
说明:HEAD@{移动到当前版本需要多少步}

1.3.5 前进后退

  • 基于索引值推荐 git reset --hard 指针位置 例子:git reset --hard a6ace91 #回到这个状态
  • 使用 ^ 符号只能后退 git reset --hard HEAD^ 例子:git reset --hard HEAD^^ 注意:几个 ^ 表示后退几步
  • 使用 ~ 符号只能后退 git reset --hard HEAD~n 例子:git reset --hard HEAD~3

1.3.6 reset的三个参数比较

soft: 
  - 仅本地库移动HEAD 指针
mixed:
  - 在本地库移动HEAD指针
  - 重置暂存区
hard:
  - 在本地库移动HEAD指针
  - 重置暂存区
  - 重置工作区

1.3.7 删除文件并找回

  • 相当于建立一个快照,虽然删除了,但只要添加到暂存区,就能找回
git reset --hard 指针位置

1.3.8 文件差异比较

git diff 文件名
git diff 哈希值 文件名  #和历史中的一个版本比较
git diff  #不带文件名,则比较多个文件

2.2 分支管理

hot_fix master feature_x feature_y

2.2.1 什么是分支管理

  • 在版本控制中,使用推进多个任务

2.2.2 分支的好处

  • 同时并行推进多个功能开发,提高开发效率
  • 某一分支开发失败,不会对其它分支有任何影响

2.2.3 分支操作

  • 创建分支
git branch 分支名
  • 查看分支
git branch
git branch -v 
  • 切换分支
git checkout 分支名
git checkout -b 分支名   #创建分支并直接切换到该分支
  • 合并分支相当于把修改了的文件拉过来
git merge xxx
注意:合并分支的时候要明确谁谁合并
    我在a分支里面修改了。要合并到master,就先切换到master,然后合并b
  • 删除分支
git branch -d 分支名

2.2.4 解决冲突

  • 冲突的表现
  • 冲突的解决
    • 第一步:编辑,删除特殊标记<<< ===
    • 第二步:修改到满意位置,保存退出
    • 第三步:添加到缓存区 git add 文件名
    • 第四步:提交到本地库git commit -m '日志信息' 注意:后面一定不能带文件名

Git 结合Github

别分手 别名 分支名

1.1 创建远程库地址别名

git remote -v  #查看远程地址别名
git remote add 别名 远程地址 
例子:git remote add origin https://xx

1.2 推送

开发修改完把本地库的文件推送到远程仓库 前提是提交到了本地库才可以推送

git push 别名 分支名
git push -u 别名 分支名    #-u指定默认主机
例子:git push origin master

1.3 克隆

完整的把远程库克隆到本地 克隆下来后不要在主分支里面做开发 clone进行一次,从无到有的过程,更新用pull

git clone  远程地址
例子:git clone https://xx

1.4 拉取

本地存在clone下来的文件 就用pull更新

pull = fetch + merge
    git fetch 别名 分支名
    git merge 别名 分支名
git pull 别名 分支名

1.5 解决冲突

注意:解决冲突后的提交是不能带文件名的

如果不是基于远程库最新版做的修改不能推送,必须先pull下来安装冲突办法解决

1.6 rebase

rebase和merge区别

git rebase -i 索引号
git rebase -i HEAD~3  #合并最近三条记录
说明:在vim编辑里面改成s

1.7 beyond compare

用软件解决冲突

1.安装 :
   beyond compare 
2.配置:
   git config --local merge.tool bc3  #合并名称
   git config --local mergetool.path '/usr/local/bin/bcomp' #软件路径
   git config --local mergetool.keepBackup false  #False不用保存备份
3.应用:
   git mergetool
说明:--local指只在当前操作系统有效

1.8 跨团队合作

代码review之后合并

  • 适用于个人 邀请成员:Settings --> Collaborators -->填写用户名 -->打开链接接受邀请
  • 企业 创建一个组织 方便管理
  • review 组织做review 通过Pull request
  • 给开源社区共享代码 点击别人仓库的fork 到自己的仓库 -- > 然后clone下来 修改后推送到远程库 --> 点击Pull Request请求 --> Create pull request发消息

1.9 Tag标签

为了清晰的版本管理,公司一般不会直接使用commit提交

git tag -a v1.0 -m '版本介绍'   #创建本地tag信息
git tag -d v1.0         #删除tag
git push origin --tags   #将本地tag信息推送到远程库
git pull origin --tags    #拉取到本地

git checkout v.10    #切换tag
git clone -b v0.1 地址   #指定tag下载代码

1.10 SSH 免密登录

  • 输入:ssh-keygen -t rsa -C GitHub邮箱地址
  • 进入.ssh目录,复制id_rsa.pub文件内容
  • 登录GitHub。Settings --> SSH and GPG keys --> New SSH Key
  • 回到git通过ssh地址创建。git remote add 别名 SSH地址

Git工作流

1.1 概念

在项目开发过程中使用Git的方式

1.2 分类

1.2.1 集中式工作流
像SVN一样,集中式工作流有一个中央仓库,所有的修改都提交到了Master分支上
1.2.2 GitFlow工作流 *

主干分支master 开发分支develop 修复分支hotfix 预发布分支release 功能分支feature

GitFlow 有独立的分支,让发布迭代过程更流畅。
1.2.3 Forking 工作流
在 GitFlow 基础上, 充分利用了 Git 的 Fork 和 pull request 的功能以达到代码审核的目的。 
安全可靠地管理大团队的开发者 

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Git实战

    学习Git有一段时间了,一路上也一直在写有关于Git方面的文章,但总觉得不是我想要的,就是感觉有点肉肉的,不够直接,不够马上出效果,所以才有了这篇文章,当然这文...

    迹_Jason
  • Git实战

    声明:本文为原创,作者为 对弈,转载时请保留本声明及附带文章链接:http://www.duiyi.xyz/git%e5%ae%9e%e6%88%98/

    对弈
  • 超详细的 Git 实战教程,傻瓜一看也会!

    作者:涂根华 来自:cnblogs.com/tugenhua0707/p/4050072.html

    Java技术栈
  • Git实战(四)| Git分支管理实操,搞定在线合并和本地合并

    类似于SVN这种集中式版本管理,三年前刚来上海工作时候,在华为驻场上班,华为用的就是SVN,印象最深的就是那个小乌龟的图标;后来到外面工作,渐渐发现用Git的非...

    霍格沃兹测试学院
  • Git实战(五)| 让工作更高效,搞定Git的分支管理

    上一篇讲到Git的分支管理实操,在线合并和本地合并都进行了实操。毕竟:光说不练是假把式。而只练不整理,只能是傻把式了。分支管理到底如何进行管理呢?

    霍格沃兹测试学院
  • Git 实战(三) | Github 必会高频基础命令与 IDE 的 Git 集成

    GitHub 上我们可以 fork 别人的项目,为了与别人产生一种协作关系,将他人的项目在自己本地创建也一个,这里以霍格沃兹测试学院(Hogwarts)的演练环...

    霍格沃兹测试学院
  • 【Git实战技巧】恢复被强制推送push失踪的代码

    Git是一个易学难精的分布式版本控制系统,被我们码农常用于代码的管理。如果你还不了解Git,建议先通过廖雪峰的Git教程进行了解,再来看本文,因为本文以使用技巧...

    Rude3Knife的公众号
  • 【Git实战技巧】恢复被强制推送push失踪的代码

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

    蛮三刀酱
  • Docker+Jenkins+GIT+Tomcat实战持续化集成

    | Docker-server | 172.20.6.20 |Docker宿主机

    KaliArch
  • Git 操作实战示例(四)

    Git 进行代码版本管理时,有两种操作方式:图形界面GUI 和 命令行Command

    阳光岛主
  • git 入门教程之实战 git 原

    git 是一款分布式版本控制系统,可以简单概括: 不要把鸡蛋放在一个篮子里,你的一举一动都在监视中.

    雪之梦技术驿站
  • 5分钟搭建git-maven-ssm项目实战(一)

    一般来说crm模块包括(客户管理、销售管理、客户服务管理、市场营销管理、综合管理、客户自助查询、知识库管理、系统权限管理

    用户5224393
  • 化繁为简的企业级 Git 管理实战(四):多 Gitlab 数据同步

    HaHack
  • 化繁为简的企业级Git管理实战(三):分支管理策略

    HaHack
  • 化繁为简的企业级 Git 管理实战(二):多分支子模块持续集成

    HaHack
  • 化繁为简的企业级 Git 管理实战(五):二进制大文件的版本控制

    HaHack
  • 08. SpringCloud实战项目-配置Git

    如果遇到Fatal: HttpRequestException encountered问题

    悟空聊架构
  • 【Git】GitLab CI/CD 的执行流程及实战

    GitLab CI/CD 是一个简洁好用的的持续集成/持续交付的框架。通过为你的项目配置一个或者多个 GitLab Runner,然后撰写一个 .gitlab-...

    瑞新
  • GitHub实战系列~4.把github里面的库克隆到指定目录+日常使用 2015-12-11

    GitHub实战系列汇总:http://www.cnblogs.com/dunitian/p/5038719.html ————————————————————...

    逸鹏

扫码关注云+社区

领取腾讯云代金券