版本管理 - Git 使用入门

Git 是一个分布式的版本管理系统,而 SVN 是一个集中式管理系统。

版本控制

  • Git与SVN的对比
    |对比|SVN|Git|
    |----|----|----|
    |工作方式|集中式|分布式|
    |文件管理|增量式|系统快照|
    |权限控制|对团队中参与开发的人员进行权限控制|可接受团队外开发者贡献的代码并审核|
  • 版本控制工具分类
    • 集中式版本控制工具(SVN、CVS)

      缺点:服务器故障将产生单点故障

    • 分布式版本控制工具(Git、Mercurial、Bazaar...)

      优点:本地具有完整版本历史

Git 简介

  • Git 资源
  • Git 优势
    • 大部分操作在本地完成不需要联网
    • 完整性保证
    • 尽可能添加数据而不是删除或修改数据
    • 分支操作非常快捷流畅
    • 与 Linux 命令全面兼容
  • Git 结构
    • 本地结构
  • GitHub(代码托管中心)
  • 本地库和远程库
    • 团队内协作

    • 团队外协作

命令行操作

  • 本地库操作
    • 本地库初始化
      • 命令
        bash git init
      • 效果

      • 注意:.git 目录中存放的是本地库相关的子目录和文件,不要删除和修改。

    • 设置签名
      • 形式
        用户名:clxye Email: [email protected]
      • 作用:区分不同开发人员的身份
      • 辨析:这里设置的签名和登陆远程库(代码托管中心)的账号、密码没有任何关系
      • 命令
        • 项目级别/仓库级别:仅在当前本地库范围内有效
          ```
          // 设置本地账号信息
          git config user.name clxye
          git config user.emal [email protected]

          // 查看保存的信息
          cat .git/config
          ```
        • 系统用户级别:登陆当前操作系统的用户范围
          ```
          // 设置系统账号信息
          git config --global user.name clxye
          git config --global user.emal [email protected]

          // 查看保存的信息
          cat ~/.gitconfig
          ```
        • 级别优先级
          • 就近原则:项目级别优先于系统用户级别,二者都有时采用项目级别的签名
          • 如果只有系统用户级别的签名,就以系统用户级别的签名为准
          • 二者都没有不允许
    • 状态查看操作
      git status
      查看工作区、暂存区状态

    • 添加操作
      git add [file name]
      将工作区的 “新建/修改” 添加到暂存区

      扫描二维码关注公众号,回复: 5152050 查看本文章
    • 提交操作
      git commit -m "commit message" [file name]
      将暂存区的内容提交到本地库

    • 查看历史记录
      ```
      // 详细日志信息
      git log

      // 简洁日志信息
      git log --pretty=oneline

      // 最简洁日志信息(只显示当前及以前版本日志)
      git log --oneline

      // 移动到当前版本需要多少步(显示所有日志)
      git reflog
      ```

    • 前进后退


      // 基于索引值(只需包含 git log --oneline 中的hash值)
      git reset --hard 9a9ebe0
      
      // 使用^符号(只能后退,一个^后退一步,N个后退N步)
      git reset --hard HEAD^
      
      // 使用~符号(只能后退,后退n步)
      git reset --hard HEAD~3
    • 删除文件并找回
      git git


    • 比较文件差异
      git git


    • 命令帮助
      git git


  • 远程库操作

Git 图形化界面操作

Gitlab 服务器环境搭建

猜你喜欢

转载自www.cnblogs.com/clxye/p/10354874.html