git和github的相关知识

git和github的相关知识

  • 版本控制工具应该具备的功能
    • 协同修改
    • 数据备份
    • 版本管理
    • 权限控制
    • 历史记录
    • 分支管理
  • 跟集中式的管理工具相比最重要的功能就是解决单点故障。
  • git的优势
    • 大部分在本地完成不需要联网
    • 完整性的保证
    • 尽可能添加数据而不是修改数据或删除数据
    • 分支操作非常快捷流畅
    • 与linux命令全面兼容
  • git在本地的三大区域
    • 本地库
    • 暂存区
    • 工作区
  • git的代码托管中心
    • 局域网gitlab
    • 外网github,码云
  • 本地库和远程库
    • 团队内部协作
    • 跨团队协作
  • 本地库初始化
    • 切换到你所要上传的目录 初始化 git init
    • ./git 里面存放的就是本地库相关的子目录和文件,不要删除和修改
  • 设置签名
    • 形式 用户名: email:
    • 作用区分不同的开发人员的身份
    • 命令:
      • 项目级别和仓库级别:仅在当前本地库范围内有效。

      • 系统用户级别:登录当前系统用户的范围。

      • 优先级:就近原则项目级别优先于项目级别。

      • git config 设置的就是项目级别的

          git config user.name ice-mountain
          git config user.email 132925162@qq.com
          存储位置在.git/config
        
      • git config --global设置的 就是系统用户级别

          git config --global user.name ice-mountain
          git config --global user.email 132925162@qq.com
          存储位置在cd ~/.gitconfig
        
  • git status 工作缓存区的状态
  • git add 添加文件到缓存区
  • git rm -cached 把文件从缓存区删除
  • git commit -m “” 暂存区的文件提交到本地仓库
  • git log 查看历史git log --pretty=oneline 显示一行 git log --oneline只显示过去 git reflog显示移动到指定版本需要几步
  • 版本的前进后退
    • 基于索引操作模式 git reset --hard 索引值(95c60b0)
    • 基于^操作的模式只能返后退 git reset --hard head^ 有几个^符号就退几步
    • 基于~操作的模式 也是只能后退 git reset --hard head~2 表示后退2步
  • git的reset的三个命令参数的对比
    • –hard 重置本地库暂存区,移动本地库指针
    • –soft 仅仅在本地仓库移动HEAD指针
    • –mixed 本地库移动HEAD指针重置暂存区
  • 删除文件并找回
    • 前提是文件删除之前已经提交到了本地库
    • 操作git reset --hard head回到有文件的那个版本。
  • 比较文件 git diff 或者Git diff --hard head(文件名)的某个历史版本 不带文件名则比较多个文件
  • 分支
    • 分支就是在版本控制中,使用多条线同时推进多个任务。提高开发效率,某个分支开发失败不会对其他分支有任何影响。
    • 查看所有的分支 git branch -v
    • 创建分支 git branch hot_fix
    • 切换分支 git checkout hot_fix
    • 合并分支:1.切换到接受修改的分支上 git checkout(分支名)2.执行一个 git merge(分支名)
  • 解决冲突
    • 如果分支和主干在同一个文件同一个地方修改了之后就会产生冲突。
    • 产生冲突之后需要手动修改文件
    • 修改完成之后需要去执行git add
    • 添加到暂存区之后需要进行提交 git commit -m “注释” 一定不能加文件的名字
    • 删除分支 git brach -d 分支名
  • git的基本原理
    • 哈希加密 明文----->密文 利用sha1 算法来检验文件是否一致
    • 增量式的版本控制 不会保留重复的数据 重复的数据利用指针指向历史版本
  • github的使用
    • 把提价到本地仓库的代码提交到github远程仓库
    • git remote -v 查看已经有的远程仓库
    • git remote add origin 你的远程仓库的地址 给你的远程仓库器起别名并且添加
    • git remote remove 删除远程仓库
    • git push 你的远程仓库的别名 你的分支名称 ----->推送的你的代码到远程仓库
    • 克隆远程仓库 git clone 你的远程仓库地址 有三个效果
      • 把完整的远程库下载到本地
      • 创建origin远程仓库别名
      • 初始化本地仓库
    • 抓取操作 git fetch origin master:master 把你的数据下载到本地仓库但是暂时还没有合并项目
    • 合并项目 git merge origin/master
    • 拉取pull 就等于fetch+merge git pull origin master
    • 解决冲突 如果不是基于github最新版则需要先拉取下来进行提交,进入冲突后进行修改并提交。
  • github的fork功能 用于跨团队协作
    • 就是把比人的代码复制到自己的远程仓库 自己就可以随意的上传修改,完成之后交给对方审核。
    • 发起pull resquest
  • 配置ssh 免密登录 ssh-keygen -t rsa -C(C必须大写)你的邮箱地址
  • eclipse 进行git
    • eclipse 自带的git

    • 项目右键点team—> share projects ----> git----->next---->勾选 use----->选择项目----->create repository
      ------>finish

    • 配置忽略的文件 https://github.com/github/gitignore/edit/master/Java.gitignore 网址进行复制

    • 在和.gitconfig的同级目录创建文件Java.gitignore

    • 对.gitconfig 进行修改

        [core]
        	excludesfile=C:/Users/Administrator/Java.gitignore
      
    • 提交到本地库 ctrl+#进行提交

    • 提交到远程仓库

  • 远程仓库到eclipse
    • import---->projects from git----->clone url----->next 输出你要导出项目的地址------>next------>选择你的eclipse的工作空间------>next 选择 import as general project---->next---->finish
    • 导出项目后,在项目上点击右键configure----->convent to maven project
    • 完成
  • git解决冲突
    • 使用mergetool 可以修改左边的右边的不能修改可以复制。
    • 修改完之后进行关闭,然后进行提交
  • git的工作流程
    • 集中式 没有分支的工作
    • gitflow工作流
    • 跨团队协作工作流程
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值