Git

一、安装与配置

1、下载地址:https://git-for-windows.github.io

2、配置个人信息(名字与邮箱) 使用Git的第一件事就是设置你的名字和email,这些就是你在提交commit时的签名

git config --global user.name "Your Name"
git config --global user.email "email@example.com"

查看是否配置成功,用命名git config -l

二、git的使用(命令行)

1、创建本地仓库

git init:把当前目录变成一个git仓库,并自动创建master分支

以上命令会在当前目录下创建了一个.git 隐藏目录,它就是所谓的Git 仓库。生成仓库后的目录就不是普通的文档目录了,我们将其称为工作区,所以工作区中都包含一个git仓库,而一个git仓库中又包含一个暂存区和一个版本库

2、工作区与版本库概念
  • 工作区(Working Directory):电脑中的目录
  • 仓库:工作区有一个隐藏目录.git,这个不算工作区,而是Git仓库。
    • 暂存区(stage/index):一个临时的存储区域
    • 版本库 (Repository)
3、添加文件到版本库的步骤(重点)
  1. 创建(修改)文件

    1. 往工作区中添加/修改文件
  2. 添加到暂存区:git add <file>

    1. 把修改存放到暂存区

      1. git add 文件夹:把文件夹下的所有修改添加到暂存区
      2. git add .:添加所有修改到暂存区

      如果想过滤部分文件,请查看 过滤清单

  3. 提交到版本库:git commit -m "备注"

    1. 使用git commit 命令可将暂存区的内容提交至版本库中,这个过程称为提交,每一次提交都意味着版本在进行一次更新(会自动生成一个commit id)
    2. 如果不写-m回车会进入vim编辑界面,退出方法:
      1. 进入编辑状态:i
      2. 退出编辑状态:ESC
      3. 同时按下Shift和冒号(:),接着输入输入:q(退出不保存),wq(保存并退出)
4、其他辅助命令
  1. 查看仓库变更状态:git status
    1. 用status查看仓库会有几种状态:untracked、unstaged、uncommitted

三、git远程仓库

  1. 注册登录
    1. github(国外):https://github.com/
    2. coding(国内):https://coding.net
  2. 关联本地仓库与远程仓库

    有两种方式关联:ssh和https两种协议,https比较简单,但提交时每次都分输入用户名和密码,如使用https协议,直接跳过以下第1、第2步

    1. 创建SSH Key:ssh-keygen -t rsa -C 'email地址'
      以上命令会在当前window用户的目录里创建.ssh目录,里面有id_rsa(私钥)和id_rsa.pub(公钥)两个文件

      C:\Users\Administrator.ssh

      将公钥写到github的ssh keys 上,头像-setting-sshkey

    2. 添加SSH Key到Git服务器 添加完成后测试线路是否连通:ssh -T git@github.com

    3. 建立本地仓库与远程仓库的连接

      1. 方式1:适用于先有本地仓库,后有远程仓库的情况

        格式:git remote add 远程仓库名 远程仓库地址

        git remote add origin git@github.com:xxx/view.git
        

      测试是否成功git remote -v

      PS:删除远程仓库连接:git remote remove 远程仓库名

      2.方式2:克隆(适用于先有远程库,后有本地仓库的情况)

      ​ 格式:git clone 远程仓库地址

      当你从远程仓库克隆时,实际上Git自动把本地的master分支和远程的master分支对应起来了,并且,远程仓库的默认名称是origin

  3. 推送到远程仓库(重点)
    1. git push
      1. 格式:git push 远程仓库名 本地分支名:远程分支名
      2. 把本地分支内容推送到远程分支(远程分支名省略表示推送到与本地分支相同的分支)
      git push origin master
      
  4. 拉取与合并(重点)
    同步本地与远程仓库
    1. git pull
      1. 格式:git pull 远程仓库名 远程分支名:本地分支名
        拉取远程分支内容到本地并与本地分支进行合并(本地分支名省略表示合并到与远程分支名相同的分支)
      git pull origin master
      
    2. git pull的时候,
      1. 提示:
        fatal: refusing to merge unrelated histories  
        
      2. 解决方法 :
      git pull origin master --allow-unrelated-histories
      
    3. git fetch

      1. 拉取远程分支内容
    4. git merge
      1. 合并分支内容
    git pull origin master
    //以上命令相当与以下命令等效
    git fetch origin master
    git merge origin/master
    
  5. 版本回退
    1. 回退命令:git reset
      1. 回退到上一个版本 :

        git reset --hard HEAD^
        
      2. 回退到指定版本:

        git reset --hard [commit id] 版本号没必要写全,前几位就可以了,Git会自动去找。
        
      3. 回退指定文件 :

        git reset --hard [commit id] <file>
        
      4. 参数说明

        1. –hard:工作区、暂存区、版本库的文件同时回退
        2. –mixed:暂存区、版本库的文件回退(默认)
        3. –soft:仅仅回退版本库中的文件
    2. 当前版本:HEAD
      1. 上一个版本:HEAD^
      2. 上上个版本:HEAD^^
      3. … 依此类推
      4. 前100个版本:HEAD~100
    3. 显示从最近到最远的提交日志:git log
      1. –pretty=oneline(显示简要信息id+备注)
      2. –graph(图形显示版本走向)
      3. –abbrev-commit(显示简写的id)
      4. 一大串类似3628164…882e1e0的是commit id(版本号)
    4. 查看命令历史:git reflog
    5. 撤销文件修改
      1. git checkout -- <file>:放弃工作区的修改
      2. git rm --cache <file>:撤销暂存区的修改
      3. git reset HEAD <file>:撤销暂存区的修改
    6. 对比文件:git diff <file>
  6. git过滤配置(过滤清单)

    一般来说每个Git项目中都需要一个“.gitignore”文件,这个文件的作用就是告诉Git哪些文件不需要添加到版本管理中。

    #过滤node_modules根目录下的文件(不过滤其他目录下的node_modules文件夹)
    /node_modules
    
    #过滤所有mtk文件夹
    mtk/ 
    
    #过滤所有.zip文件
    *.zip 
    *.mp3
    *.mp4
    
    #过滤某个具体文件
    /mtk/do.c 
    
    1. #为注释
    2. 很简单吧,被过滤掉的文件就不会出现在你的GitHub库中了,当然本地库中还有,只是push的时候不会上传。
    3. 演示sass遗留的依赖包问题:npm init创建package.js,npm install根据package.js下载包
  7. 分支操作(了解)
    1. 创建分支:git branch 分支名
    2. 切换分支:git checkout 分支名
    3. 查看分支:git branch
      1. 列出所有分支,当前分支前面会标一个*号
    4. 合并分支:git merge 分支名
      1. git merge dev:把dev分支合并到当前分支
      2. Fast-forward:快速合并
      3. 禁用快速合并: –no-ff (保持分支信息)
    5. 删除分支:git branch -d 分支名

      1. 强行删除,需要使用命令git branch -D feature-vulcan
    6. 获取远程分支

      1. 先获取(git fetch)
      2. 然后在本地创建一个同名分支,并将远程分支映射到此分支(git branch dev origin/dev)
    7. 打tag

        ```
        git add .
        git commit -m “fixed some bugs”
        git tag -a 0.1.3 -m “Release version 0.1.3″
        //git tag 是命令 ,-a 0.1.3是增加 名为0.1.3的标签, -m 后面跟着的是标签的注释
        git push origin 0.1.3 # 将0.1.3标签提交到git服务器
        git push origin –tags # 将本地所有标签一次性提交到git服务器
        ```
      
    8. 在实际开发中,我们应该按照几个基本原则进行分支管理:
      1. 首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;
      2. 那在哪干活呢?干活都在dev分支上,也就是说,dev分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本;
      3. 你和你的小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值