百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Git & Github - 5分钟从入门到熟练掌握

wptr33 2024-11-10 13:15 33 浏览

Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。

Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

Git 与常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本库的方式,不必服务器端软件支持。

下面从如下几个方面对Git的具体是用进行介绍:

  • Git 环境安装;
  • 初次运行 Git 前的配置;
  • 创建版本库;
  • 添加文件到版本库;
  • 连接远程仓库;
  • 推送代码到远程仓库;
  • 从远程仓库下载项目到本地;

一、Git 环境安装

以Windows环境为例进行介绍。从官方网站下载Git客户端,安装后在任意地方鼠标右键就会出现如下菜单项,Git Bash Here 就是我们的Git客户端。

二、初次运行 Git 前的配置

当安装完Git应该做的第一件事就是设置你的用户名称与邮件地址。 这样做很重要,因为每一个Git的提交都会使用这些信息,并且它会写入到你的每一次提交中,不可更改:

git config --global user.name "rickie"

git config --global user.email "rickie@bat.com"

再次强调,如果使用了 --global 选项,那么该命令只需要运行一次,因为之后无论你在该系统上做任何事情,Git 都会使用那些信息。 当你想针对特定项目使用不同的用户名称与邮件地址时,可以在那个项目目录下运行没有 --global 选项的命令来配置。

三、创建版本库

指定一个目录作为你的仓库地址,我这里使用D:\GitHub作为我后期所有项目的总空间。

创建我的第一个项目名~起名叫做es-order,这个直接在window新建一个文件夹就行。

然后在es-order目录里面,右键鼠标打开git客户端。

输入创建版本库命令:

git init

瞬间git就把仓库建好了,而且告诉你是一个空的仓库(empty git repository),并且当前目录下多了一个.git的目录,这个目录是Git用来跟踪管理版本库的,没事千万不要手动修改这个目录里面的文件,不然改乱了,就把git仓库给破坏了。如果你没有看到.git目录,那是因为这个目录默认是隐藏的。

四、添加文件到版本库

上面把git仓库搭建好了,现在就来试试添加文件到版本库里面。该目录已经存在了java 项目的不少源文件。

第一步,用命令git add告诉git,把本地代码托送到暂存区。

git add .

. (英文符号点)表示提交当前目录所有文件。使用该命令会把工作时的所有变化提交到暂存区,包括文件内容修改(modified)以及新文件(new),但不包括被删除的文件。

提交后再使用git status命令查看下:

git status 命令用于显示工作目录和暂存区的状态。使用此命令能看到那些修改被暂存到了, 哪些没有, 哪些文件没有被Git tracked到。

git status

你会看到这些文件都变成绿色了,表示添加到暂存区成功了。

第二步,用命令git commit告诉git,把文件提交到仓库。

git commit -m "first release"

-m 参数是用来注释你提交的信息,这样以后才知道这次提交时用来做什么了。

再次使用git status命令来查看当前状态,是否有未提交的文件。

$ git status

On branch master

nothing to commit, working tree clean

git status后提示nothing to commit, working directory clean,说明当前没有需要提交的修改,工作目录是干净。

有时候你想看看之前提交的历史纪录,那么就需要使用到git log命令:

$ git log

commit 88899b4f5de4537509448e0902307062152d6a03 (HEAD -> master)

Author: rickiechina <rickiechina@hotmail.com>

Date: Thu Oct 3 09:08:51 2019 +0800

first release

如果觉得上面显示的信息太多了,可以加个参数:

$ git log --pretty=oneline

88899b4f5de4537509448e0902307062152d6a03 (HEAD -> master) first release

这样,显示的信息就比较简洁了。

现在,我们对前面的git 命令小结一下:

git init 初始化仓库

git add 添加文件到暂存区

git commit 提交文件到仓库

git diff 比对本地和版本库里面的文件

git log 查看历史提交记录

五、连接远程仓库

git本地操作的熟练了后,就可以尝试连接远程仓库了,目前国内外比较出名的提供git仓库远程托管的有国外的github,国内的码云 Gitee。这里我以github为例子介绍如何操作远程仓库。

仍然以本地的es-order 项目为例,想托管到github上面,那么需要先进入github创建一个仓库,如图所示。

按照前面的操作步骤,我们的代码 es-order已经在本地库了,接下来执行如下命令:

git remote add origin https://github.com/rickiechina/elasticsearch-order.git

就连接上了远程的 elasticsearch-order 项目。远程库的名字就是 origin,这是git 默认的称呼。

接下来,可以使用 git remote 列出远程别名,如果没有任何参数,git 会列出远程仓库的别名。

git remote

如果执行的时候,加上参数 -v,还可以看到每个别名的实际链接地址。

六、推送代码到远程仓库

连接上远程仓库之后,就可以推送代码到远程仓库了。

git push -u origin master

由于远程库是空的,我们第一次推送master分支时,加上了-u参数,git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令,直接用git push origin master。

推送完后,可以查看远程仓库上多了很多文件。

七、从远程仓库下载项目到本地

在网上看到别人的项目了,想要下载下来该如何,用git clone 命令。

比如,在本地 d:\github 目录下面下载这个elasticsearch-order远程仓库项目。

直接使用命令:

git clone https://github.com/rickiechina/elasticsearch-order.git

就会下载项目到d:\github下面, elasticsearch-order是远程仓库项目的项目名。

从远端仓库提取数据并尝试合并到当前分支

如果一个远程仓库项目,别人提交了代码,你想更新成最新的代码怎么办。

使用git pull命令即可:

git pull origin master

删除跟远程仓库的连接

如果你需要删除一个远端仓库,不再需要它了。你可以使用 git remote rm [alias] 把它删掉。

git remote rm origin

注意,断开跟远程的连接后,如果还想连上,则需要再来一次:

git remote add origin https://github.com/rickiechina/elasticsearch-order.git

针对 git连接远程仓库的命令,小结一下:

git remote 查看远程库的信息

git remote -v 显示更详细的信息

git remote add origin https://github.com/rickiechina/elasticsearch-order.git 连接远程仓库

git clone https://github.com/rickiechina/elasticsearch-order.git 复制一份远程仓库项目到本地

git remote rm origin 关闭连接远程仓库

git push origin master 推送分支

git pull origin master 抓取更新

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...