Git的简介与使用

举报
AlbertYang 发表于 2021/02/03 01:42:51 2021/02/03
【摘要】 目录   Git简介 Windows下Git的安装 Git的使用 配置Git 检出仓库 工作流 推送改动 分支 更新与合并 标签 替换本地改动 实用小贴士   Git简介 Git 是用于 Linux内核开发的版本控制工具。与常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本库的方式,不必服务器端软件支持(winge...

目录

 

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都会记录他们。


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

 

检出仓库

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

git clone /path/to/repository 
 

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

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

工作流

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

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


  
  1. git add <filename>
  2. 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 中的最新内容替换掉你的工作目录中的文件。已添加到暂存区的改动以及新文件都不会受到影响。

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


  
  1. git fetch origin
  2. git reset --hard origin/master

实用小贴士

内建的图形化 git:
 

gitk
 


彩色的 git 输出:
 

git config color.ui true
 


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

git config format.pretty oneline
 


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

git add -i
 

 

文章来源: albertyang.blog.csdn.net,作者:Albert Yang,版权归原作者所有,如需转载,请联系作者。

原文链接:albertyang.blog.csdn.net/article/details/85343460

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。