一、获取 Git 仓库

初始化仓库

##基于当前目录初始化仓库
$ git init
##指定demo目录初始化仓库
$ git init demo

克隆现有仓库

##克隆现有的仓库,默认目录名:libgit2
##git clone <repo>
$ git clone https://github.com/libgit2/libgit2
##克隆现有的仓库,指定目录名:mylibgit
##git clone <repo> <directory>
$ git clone https://github.com/libgit2/libgit2 mylibgit

注意:Git 克隆的是该 Git 仓库服务器上的几乎每一个文件的每一个版本,而不是仅仅复制完成你的工作所需要文件,这是 Git 区别于其它版本控制系统的一个重要特性。

二、添加版本控制

commit文件流程

##进入仓库目录创建文件
$ cd /demo
$ touch demo_01.c
$ touch demo_02.c
$ mkdir LICENSE
##添加文件追踪track,即添加文件至暂存区
$ git add *.c
$ git add LICENSE
##提交文件至版本库,-m 参数指定提交log
$ git commit -m 'initial project version'

说明:git add 命令使用文件或目录的路径作为参数。如果参数是目录的路径,该命令将递归地跟踪该目录下的所有文件。

文件状态

新建文件状态为:??

$ cd /home/super/gitDemo
$ touch a.txt
$ git status -s

添加track后,文件状态为:A

git add a.txt
git status -s

未commit前,修改文件,查看文件状态为:AM

echo "a" > a.txt
git status -s

再次track后,状态为:A

git add a.txt
git status -s

执行commit后,文件同步,无状态

git commit a.txt -m "init a.txt"
git status -s

执行commit后,再次修改文件,状态为: M(右M)

echo "b" > a.txt
git status -s

再次track后,状态为:M (左M)

git add a.txt
git status -s

未commit前,再次修改文件,状态为:MM

echo "d" > a.txt
git status -s

再次track后,状态为:M (左M)

git add a.txt
git status -s

执行commit,文件同步,无状态

git commit a.txt -m "init a.txt 0.1"
git status -s

git status简要状态说明

标记 说明
?? 新添加的未跟踪文件
A  新添加到暂存区中的文件
AM 新文件添加到暂存区后,未commit前,在工作区修改过
 M (M在右边)已被commit过的文件在工作区被修改但还没add暂存区
M  (M在左边)已被commit过的文件在工作区被修改并已add暂存区
MM 已被commit过的文件在工作区被修改并提交到暂存区后又在工作区中被修改

忽略文件跟踪配置

Git允许指定无需被纳入管理的文件,使它们不必出现在未跟踪文件列表。

##创建文件.gitignore
cd <dir>
touch .gitignore
##添加如下配置信息
# no .a files
*.a # but do track lib.a, even though you're ignoring .a files above
!lib.a # only ignore the TODO file in the current directory, not subdir/TODO
/TODO # ignore all files in the build/ directory
build/ # ignore doc/notes.txt, but not doc/server/arch.txt
doc/*.txt # ignore all .pdf files in the doc/ directory
doc/**/*.pdf

.gitignore 文件的格式规范如下:

  • 所有空行或者以 # 开头的行都会被 Git 忽略
  • 可以使用标准的 glob 模式匹配
  • 匹配模式可以以(/)开头防止递归
  • 匹配模式可以以(/)结尾指定目录
  • 要忽略指定模式以外的文件或目录,可以在模式前加上惊叹号(!)取反

说明: glob 模式指 shell版简化的正则表达式。

  星号 * 匹配零个或多个任意字符;

  [abc] 匹配任何一个列在方括号中的字符(这个例子要么匹配一个 a,要么匹配一个 b,要么匹配一个 c);

  问号(?)只匹配一个任意字符;如果在方括号中使用短划线分隔两个字符,表示所有在这两个字符范围内的都可以匹配(比如 [0-9] 表示匹配所有 0 到 9 的数字);

  使用两个星号 * 表示匹配任意中间目录,比如 a/**/z 可以匹配 a/z , a/b/z 或 a/b/c/z 等。

参考资料

参考网站:https://git-scm.com/book/zh/v1/起步

  • 作者:
    DeepInThought


    出处:
    https://www.cnblogs.com/DeepInThought


    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
  • 【2】Git仓库的更多相关文章

    1. 多本地代码工作点更新到2个远端GIT仓库

      摘要:本文介绍了笔者多个本地工作节点(地方)的多台电脑(PC/笔记本电脑)同步源码到2个远端的GIT(一个GITHUB国外强制公开,一个oschina国内可不公开). 作者:太初 转载说明:请指明原作 ...

    2. Git中如何利用生成SSH个人公钥访问git仓库

      Git中如何利用生成SSH个人公钥访问git仓库方法(这里以coding平台为例): 1. 获取 SSH 协议地址 在项目的代码页面点击 SSH 切换到 SSH 协议, 获得访问地址, 请使用这个地址 ...

    3. eclipse连接多个git仓库方法

      只需要在本地建立多个仓库就行,提交的时候一个本地仓库对应一个git仓库

    4. svn 版本迁移到 git 仓库

      1.拉取 svn代码并转成 git 版本 git svn fetch http://svn.qtz.com/svn/qtz_code/java/qtz_sm/project/qtz_sm -Auser ...

    5. git仓库的初始化

      关于git仓库的初始化和git push的操作 git init git remote add origin ssh://myserver.com/home/git/myapp.git git pul ...

    6. xcode 版本控制推送代码到远程git仓库的步骤

      一 代码推送到远程git仓库 1.在git中建立一个下项目(假设项目名称为->Mygit) 2.在xocde上新建一个测试项目(假设项目名称为GitTest) 3.打开电脑终端: 1)首先利用终 ...

    7. 【Git学习笔记】初始化Git仓库和版本回退

      学习地址 http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 什么是版本库呢?版本库又 ...

    8. (转)如何将本地git仓库上传到GitHub中托管+实践心得

      Git——新手入门与上传项目到远程仓库GitHub(转) - Chen_s - 博客园http://www.cnblogs.com/Chenshuai7/p/5486278.html 注意的问题: 1 ...

    9. svn迁移到git仓库并保留commit历史记录

      svn迁移到git仓库并保留commit历史记录 最近在做svn迁移到gitlab,由于之前一直是由svn做版本控制.最简单的方式是将svn的内容export出来,然后添加到gitlab即可.但是,如 ...

    10. 如何在Linux下使用Gitblit工具创建Git仓库服务

      嗨!朋友,今天我们将学习如何在你的Linux服务器或者PC上安装Gitblit工具.首先,我们看看什么是Git,它的功能以及安装Gitblit的步骤.Git是分布式版本控制系统,它强调速度.数据一致性 ...

    随机推荐

    1. LODOP直接导出图片不弹框

      之前有博文测试了导出图片的图片长度关系,是直接弹窗的选择保存路径的方式:Lodop导出图片,导出单页内容的图片最近测试下不弹窗保存图片是否可以,样例是保存的excel,测试了下图片,图片也是可以的,该 ...

    2. Flutter的布局方法

      重点是什么? Widgets 是用于构建UI的类. Widgets 用于布局和UI元素. 通过简单的widget来构建复杂的widget Flutter布局机制的核心就是widget.在Flutter ...

    3. 花里胡哨,如何在Linux终端输出带有颜色的字体,将带颜色的字体赋值给变量

      背景 ​ 在日常操作Linux的情况下,总会遇到一些需求,比如说,把输出的内容用不同颜色标注出来,以达到醒目.提示的目的,那么如何在Linux终端输出带有颜色的字体呢? Linux终端输出字符颜色 ​ ...

    4. 《精通并发与Netty》学习笔记(08 - netty4+springboot项目案例)

      本节通过案例介绍springboot与netty的集成 第一步:新建Spring Initializr 项目 我这里选择Gradle项目,也可选择Maven项目 (注意:最好选择自己下载gradle, ...

    5. 《剑指offer》树专题 (牛客10.25)

      考察的知识点主要在于树的数据结构(BST,AVL).遍历方式(前序,中序,后序,层次).遍历算法(DFS,BFS,回溯)以及遍历时借助的数据结构如队列和栈.由于树本身就是一个递归定义的结构,所以在递归 ...

    6. Qt中QGraphics类坐标映射关系详解

      1.Item(图元)坐标:属于局部坐标,通常以图元中心为原点(中心对称),非中心对称类,比如dialog类,一般以左上角为原点,正方向x朝右,y朝下. 2.setPos的坐标是父类坐标系的坐标,一般对 ...

    7. ActiveMQ单机部署及简单应用

      系统版本:Centos 7 前言 MQ是消息中间件,是一种在分布式系统中应用程序借以传递消息的媒介,常用的有ActiveMQ,RabbitMQ,kafka.ActiveMQ是Apache下的开源项目, ...

    8. Linux 中文man手册安装

      首先需要确认的是有没有安装中文支持,如果没有请安装:#yum groupinstall -y "Chinese Support" 现在下载安装包: wget http://manp ...

    9. 洛谷 题解 P1352 【没有上司的舞会】

      树形DP的一道较为基础的模板题 状态 dp[i][0/1]为第i个员工是否来参加的最大值 转移 先找到根节点 先遍历完它的儿子,再来更新答案 dp[i][0]+=max(dp[j][0],dp[j][ ...

    10. c++ 行为型_备忘录模式(Memento)

      行为型_备忘录模式(Memento) 作用场景: 当意图在对象外面保存对象的内部状态,但是又不想破坏对象的封装性,就可以考虑备忘录模式. 解释: 其参与者包括 1.Memnto(备忘录,如下列Coun ...