zoukankan      html  css  js  c++  java
  • Git的简介与使用

    目录

     

    Git简介

    Windows下Git的安装

    Git的使用

    配置Git

    检出仓库

    工作流

    推送改动

    分支

    更新与合并

    标签

    替换本地改动

    实用小贴士


     

    Git简介

    Git 是用于 Linux内核开发的版本控制工具。与常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本库的方式,不必服务器端软件支持(wingeddevil注:这得分是用什么样的服务端,使用http协议或者git协议等不太一样。并且在push和pull的时候和服务器端还是有交互的。),使源代码的发布和交流极其方便。 Git 的速度很快,这对于诸如 Linux kernel 这样的大项目来说自然很重要。 Git 最为出色的是它的合并跟踪(merge tracing)能力。

    实际上内核开发团队决定开始开发和使用 Git 来作为内核开发的版本控制系统的时候,世界开源社群的反对声音不少,最大的理由是 Git 太艰涩难懂,从 Git 的内部工作机制来说,的确是这样。但是随着开发的深入,Git 的正常使用都由一些友好的脚本命令来执行,使 Git 变得非常好用,即使是用来管理我们自己的开发项目,Git 都是一个友好,有力的工具。现在,越来越多的著名项目采用 Git 来管理项目开发.

    作为开源自由原教旨主义项目,Git 没有对版本库的浏览和修改做任何的权限限制。

    目前GIT已经可以在windows下使用,主要方法有二:msysgit和Cygwin。Cygwin和Linux使用方法类似,Windows版本的GIT提供了友好的GUI(图形界面),安装后很快可以上手,不在此做大篇幅介绍。

     

    Windows下Git的安装

    1.msysgit是windows版的Git,提供了命令操作,下载地址:https://gitforwindows.org/

    2.安装

     

    Git的使用

    配置Git

    首先在本地创建ssh key;

    $ ssh-keygen -t rsa -C "yangxianyang@hotmail.com"     

                             

    后面的yangxianyang@hotmail.com改为你在github上注册的邮箱,之后会要求确认路径和输入密码,我们这使用默认的一路回车就行。成功的话会在~/下生成.ssh文件夹,进去,打开id_rsa.pub,复制里面的key

    回到github上,进入 Account Settings(账户配置),左边选择SSH and GPG Keys,New SSH Key,title随便填,粘贴在你电脑上生成的key。

    为了验证是否成功,在git bash下输入:

    $ ssh -T git@github.com

    如果是第一次的会提示是否continue,输入yes就会看到:You've successfully authenticated, but GitHub does not provide shell access 。这就表示已成功连上github。

    接下来我们要做的就是把本地仓库传到github上去,在此之前还需要设置username和email,因为github每次commit都会记录他们。

    $ git config --global user.name "AlbertYang666"
    $ git config --global user.email "yangxianyang@hotmail.com"

     

    检出仓库

    执行如下命令以创建一个本地仓库的克隆版本:

    git clone /path/to/repository 

    如果是远端服务器上的仓库,你的命令会是这个样子:

    git clone username@host:/path/to/repository

    工作流

    你的本地仓库由 git 维护的三棵"树"组成。第一个是你的 工作目录,它持有实际文件;第二个是 暂存区(Index),它像个缓存区域,临时保存你的改动;最后是 HEAD,它指向你最后一次提交的结果。

    你可以提出更改(把它们添加到暂存区),使用如下命令:
     

    git add <filename>
    git add *


    这是 git 基本工作流程的第一步;使用如下命令以实际提交改动:
     

    git commit -m "代码提交信息"


    现在,你的改动已经提交到了 HEAD,但是还没到你的远端仓库。

    推送改动

    你的改动现在已经在本地仓库的 HEAD 中了。执行如下命令以将这些改动提交到远端仓库:
     

    git push origin master


    可以把 master 换成你想要推送的任何分支。

    如果你还没有克隆现有仓库,并欲将你的仓库连接到某个远程服务器,你可以使用如下命令添加:
     

    git remote add origin <server>


    如此你就能够将你的改动推送到所添加的服务器上去了。

    分支

    分支是用来将特性开发绝缘开来的。在你创建仓库的时候,master 是"默认的"分支。在其他分支上进行开发,完成后再将它们合并到主分支上。

    创建一个叫做"feature_x"的分支,并切换过去:
     

    git checkout -b feature_x


    切换回主分支:
     

    git checkout master


    再把新建的分支删掉:
     

    git branch -d feature_x


    除非你将分支推送到远端仓库,不然该分支就是 不为他人所见的

    git push origin <branch>

    更新与合并

    要更新你的本地仓库至最新改动,执行:
     

    git pull


    以在你的工作目录中 获取(fetch)合并(merge) 远端的改动。
    要合并其他分支到你的当前分支(例如 master),执行:
     

    git merge <branch>


    在这两种情况下,git 都会尝试去自动合并改动。遗憾的是,这可能并非每次都成功,并可能出现冲突(conflicts)。 这时候就需要你修改这些文件来手动合并这些冲突(conflicts)。改完之后,你需要执行如下命令以将它们标记为合并成功:
     

    git add <filename>


    在合并改动之前,你可以使用如下命令预览差异:

    git diff <source_branch> <target_branch>

    标签

    为软件发布创建标签是推荐的。这个概念早已存在,在 SVN 中也有。你可以执行如下命令创建一个叫做 1.0.0 的标签:
     

    git tag 1.0.0 1b2e1d63ff


    1b2e1d63ff 是你想要标记的提交 ID 的前 10 位字符。可以使用下列命令获取提交 ID:
     

    git log


    你也可以使用少一点的提交 ID 前几位,只要它的指向具有唯一性。

    替换本地改动

    假如你操作失误(当然,这最好永远不要发生),你可以使用如下命令替换掉本地改动:
     

    git checkout -- <filename>


    此命令会使用 HEAD 中的最新内容替换掉你的工作目录中的文件。已添加到暂存区的改动以及新文件都不会受到影响。

    假如你想丢弃你在本地的所有改动与提交,可以到服务器上获取最新的版本历史,并将你本地主分支指向它:

    git fetch origin
    git reset --hard origin/master

    实用小贴士

    内建的图形化 git:
     

    gitk


    彩色的 git 输出:
     

    git config color.ui true


    显示历史记录时,每个提交的信息只显示一行:
     

    git config format.pretty oneline


    交互式添加文件到暂存区:

    git add -i
  • 相关阅读:
    原生Js自适应浏览器宽度的瀑布流布局
    Fixed Gear DIY整车配色 JavaScript版制作过程
    DOM结构——两个节点之间可能存在哪些关系以及如何在节点之间任意移动
    盒模型 块级元素与行内元素 浮动元素
    Js 页面元素 简单震动效果
    CSS引入的方式有哪些? link和@import的区别?
    一道Web前端面试题 DIV放大
    js在IE和Firefox下不同之处
    Doctype? 严格模式与混杂模式如何触发这两种模式,区分它们有何意义?
    JavaScript document属性和方法
  • 原文地址:https://www.cnblogs.com/yangxianyang/p/13675631.html
Copyright © 2011-2022 走看看