git的基本使用

一、Git与Svn的区别

1、,GIT是分布式的,SVN不是:这是GIT和其它非分布式的版本控制系统,例如SVN,CVS等,最核心的区别。

2、GIT把内容按元数据方式存储,而SVN是按文件:所有的资源控制系统都是把文件的元信息隐藏在一个类似.svn,.cvs等的文件夹里。

3、GIT分支和SVN的分支不同:分支在SVN中一点不特别,就是版本库中的另外的一个目录。

4、GIT没有一个全局的版本号,而SVN有:目前为止这是跟SVN相比GIT缺少的最大的一个特征。

5、GIT的内容完整性要优于SVN:GIT的内容存储使用的是SHA-1哈希算法。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。

二、安装git

官方Windows客户端:主要使用Git Bash以命令行模式操作,但也支持GUI(gitk/git GUI),使用方法参见官方使用说明;

1) 安装git客户端,勾选与鼠标右键的关联(该项默认都会勾选)

2) 在桌面任意空白处右键,选择Git Bash Here,打开git的bash界面

Git Bash Here界面

 3)git在提交代码时需要验证你的用户名和邮箱,git不希望有匿名用户去提交代码。输入如下两个命令来配置用户名和邮箱,其中global参数表示为全局配置,也可以为单个用户配置自己独特的用户名和邮箱

git  config  --global  user.name[你的用户名]

git  config  --global  user.email[你的邮箱]

4)生成公钥和私钥:git下拉和推送代码时使用的是ssh协议,因此需要用户配置自己的公钥和私钥,而生成用户公钥和私钥的命令如下:

 ssh-keygen  -t  rsa  -C[你的邮箱地址]

中间会弹出各种提示信息,一路默认即可。默认生成的公钥和私钥的目录为 {home_dir}/.ssh下。公钥为id_rsa.pub文件,私钥为id_rsa文件。其中Windows中的{home_dir}的值为C;\Users\[用户名],或者在git-bash中输入命令

cd


ssh 配置

注意:

本机SSH 私钥id_rsa不能删除。

本机SSH key只需要创建一对,不需要为每个服务器都创建一对。

三、Git的基础

  1、基本工作流程

1)克隆 Git 资源作为工作目录。

2)在克隆的资源上添加或修改文件。

3)如果其他人修改了,你可以更新资源。

4)在提交前查看修改。

5) 提交修改。

6)在修改完成后,如果发现错误,可以撤回提交并再次修改并提交。

7)查看git版本 git --version


Git的工作流程

 2、 Git 工作区、暂存区和版本库概念

工作区:就是你在电脑里能看到的目录,也就是我们的编写目录。

暂存区:英文叫stage, 或index。一般存放在 ".git目录下" 下的index文件(.git/index)中,所以我们把暂存区有时也叫作索引(index),也就是提交上去未到版本库,但是工作去已显示提交的区域。

版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。

3、创建仓库

      初始化仓库 git init   //产生.git文件

    Git 使用 git init 命令来初始化一个 Git 仓库,Git 的很多命令都需要在 Git 的仓库中运行,所以 git init 是使用 Git 的第一个命令。

    在执行完成 git init 命令后,Git 仓库会生成一个 .git 目录,该目录包含了资源的所有元数据,其他的项目目录保持不变(不像 SVN 会在每个子目录生成 .svn 目录,Git 只在仓库的根目录生成 .git 目录)。

      如果当前目录下有几个文件想要纳入版本控制,需要先用 git add 命令告诉 Git 开始对这些文件进行跟踪,然后提交:

    1) git add *.c

    2)  git add README

    3) git commit -m '初始化项目版本'

     我们使用 git clone 从现有 Git 仓库中拷贝项目(类似 svn checkout)。

      克隆仓库的命令格式为:

   git clone <repo>

    如果我们需要克隆到指定的目录,可以使用以下命令格式:

    git clone <repo> <directory>

    参数说明: 

         repo:Git 仓库。

          directory:本地目录。    

四、Git的基本操作

1、git init

     作用:初始化Git仓库

     描述:用 git init 在目录中创建新的 Git 仓库。 你可以在任何时候、任何目录中这么做,完全是本地化的。

命令:git init 仓库名

2、git clone

     作用:拷贝一个Git仓库到本地

     描述:使用 git clone 拷贝一个 Git 仓库到本地,让自己能够查看该项目,或者进行修改

命令:git clone [url]

3、git add

     作用:git add 命令可将该文件添加到缓存(从工作区到暂存区的过程)

命令:git add 文件名/目录名

      将css目录下所有的文件添加到暂存区

命令:git add css

​      将当前目录下所有的js文件添加到暂存区

 命令:git add *.js

      添加当前目录下所有的文件

命令: git add .

            git add -A

            git add --all

注意点:空的文件夹是会被忽略掉的,如果想要提交这个文件夹,一般会在该目录下创建一个.gitkeep文件

4、git status

     作用:git status 以查看在你上次提交之后是否有修改。

命令:git status 或者 git  status -s

      描述:该命令的时候加了 -s 参数,以获得简短的结果输出。如果没加该参数会详细输出内容

5、git diff    

       作用:执行 git diff 来查看执行 git status 的结果的详细信息

 命令:尚未缓存的改动:git diff

           查看已缓存的改动: git diff --cached

           查看已缓存的与未缓存的所有改动:git diff HEAD

           显示摘要而非整个 diff:git diff --stat

 6、git commit

      作用:使用 git add 命令将想要快照的内容写入缓存区, 而执行 git commit 将缓存区内容添加到仓库中。

命令:git commit -m "提交注释"

           如果 Git 在你对它的配置中找不到相关信息,默认会打开 vim。

           如果你觉得 git add 提交缓存的流程太过繁琐,Git 也允许你用 -a 选项跳过这一步

           git commit -a

           修改最近的一次提交说明, 如果提交说明不小心输错了,可以使用这个命令

            git commit --amend -m "提交说明"

7、git log

     作用:查询历史提交节点 

命令:git log

8、git reset 

     作用:版本回退,将版本回退到某个历史节点

命令 : git reset HEAD   //git reset HEAD 命令用于取消已缓存的内容

          git reset --hard 版本号  // 将代码回退到某个指定的版本(版本号只要有前几位即可)

          git reset --hard head~1  //将版本回退到上一次提交

9、 git reflog

     作用:查看历史命令    

命令: git  reflog        

10、git rm  

      作用:如果只是简单地从工作目录中手工删除文件

      描述:要从 Git 中移除某个文件,就必须要从已跟踪文件清单中移除,然后提交。可以用以下命令完成此项工作

命令:git rm <file>

          git rm -f <file>  // 如果删除之前修改过并且已经放到暂存区域的话,则必须要用强制删除选项 -f

          git rm --cached <file>  //如果把文件从暂存区域移除,但仍然希望保留在当前工作目录中,换句话说,仅是从跟踪清单中                                          删除,使用 --cached 选项即可  

          git rm –r *  //进入某个目录中,执行此语句,会删除该目录下的所有文件和子目录。

11、git mv

     作用:git mv 命令用于移动或重命名一个文件、目录、软连接。

命令:git mv 文件名 文件名 

12、git push

      作用:将本地仓库中代码提交到远程仓库

命令:git push [仓库地址] master //在代码提交到远程仓库,注意master分支必须写,不能省略

13、git pull

      作用:将远程的代码下载到本地

命令:git pull  //提交之前一定要更新,避免代码冲突

14、git remote

     作用:要查看当前配置有哪些远程仓库

命令:git remote

           git  remote add [仓库别名] [仓库地址]  //给远程仓库设置一个别名

           git  remote remove [仓库别名]  //删除仓库别名

五、Git分支管理    

1、分支的存在原因:

         我们在一个公司,大多数情况下都是一个项目多个人合作,一起开始同一个项目,这样的话,我们经常会遇到一个问题:自己未写完                的代码提交上去导致影响整个项目的运行或者是别人的代码,但是写完提交,代码丢失的可能性很大,所以这种情况下就需要分支来。                        在工作过程中,经常会碰到多任务并行开发的情况,使用分支就能很好的避免任务之间的影响。

2、创建分支

git branch (branchname)  //git提交的时候就会有一个主分支

3、切换分支 

git checkout (branchname)  //当你切换分支的时候,Git 会用该分支的最后提交的快照替换你的工作目录的内容, 所以多个分支不需要多个目录

4、合并分支命令

git merge   //你可以多次合并到统一分支, 也可以选择在合并之后直接删除被并入的分支。

5、创建并切换分支

git checkout -b (branchname) 创建并切换分支,切换分支会做两件事情:1、创建一个新分支 2、把head指针指向当前的分支

6、 列出分支

git branch  //没有参数时,会列出你在本地的分支

7、删除分支

git branch -d (branchname)  //不能在当前分支删除当前分支,需要切换到其他分支才能删除

8、冲突合并

这个的话只能手动合并之后,再次提交了

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,076评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,658评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,732评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,493评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,591评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,598评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,601评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,348评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,797评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,114评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,278评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,953评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,585评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,202评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,180评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,139评论 2 352

推荐阅读更多精彩内容

  • 一. 掌握 - git 概述 1. git 简介? 什么是git? > git是一款开源的分布式版本控制工具 > ...
    Louis_hey阅读 505评论 1 3
  • (此文作为个人学习、回顾用,如有不足之处,请不吝指出。随理解深入,持续更新。) svn与git的区别 svn是集中...
    勇者闯魔城阅读 358评论 0 0
  • 之前一直用的svn,后来换了之后才发现git的强大功能,是svn不能比的。缺点就是可能上手比较难一点,刚开始自己研...
    八怪不姓丑阅读 7,159评论 16 102
  • Git 的介绍 Git 是一种分布式的版本管理系统。简单来说,它就是一个版本控制软件,而且也是现在世界上最流行最先...
    前端开发养成记阅读 444评论 0 0
  • Git简单概述 1、什么是git- git是一款开源的分布式版本控制工具- 在世界上所有的分布式版本控制工具中,g...
    7dfa9c18c1d1阅读 1,591评论 0 0