一、获取 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. Docker 实践备忘录

      平时零散的接触docker,时间久了概念和命令都会忘了,所以集中记下: docker 目标是实现轻量级的操作系统虚拟化解决方案. Docker 的基础是 Linux 容器(LXC)等技术 docker ...

    2. Nginx-windows

      1.下载 http://nginx.org/ 选择最新稳定版本,例如nginx-1.15.5 mainline version has been released. 点击后,跳转页面,选择Stable ...

    3. 【FICO系列】SAP FI验证故障排除(调试)

      公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[FICO系列]SAP FI验证故障排除(调试) ...

    4. Oracle拼接同一个字段多行的值

      本文引用自-   https://www.cnblogs.com/qianyuliang/p/6649983.html https://blog.csdn.net/defonds/article/de ...

    5. DOTS原则和愿景

      Unity Data Oriented Tech Stack基于一系列原则.这些原则为我们正在努力实现的目标提供了良好的背景.一些原则清楚地反映在代码中.其他则只是我们为自己设定的目标. 默认情况下的 ...

    6. 部署 --- Nginx

      Nginx介绍 简介: Nginx是由伊戈尔.塞索耶夫开发的,在04年10月开源的一款高性能HTTP和反向代理服务器. 因为它的稳定性好,功能丰富,有示例配置文件和较低的系统资源消耗而闻名 同时也是一 ...

    7. 简单记录一下虚拟机中安装Linux的流程以及部分软件的安装命令

      一,虚拟机使用的是VMware9 ,linux使用的是服务器中用的比较多的CentOS6.4.稍后我会把这两个版本放到网盘中,需要的朋友可以去下载: 网盘地址: 二,VM的安装比较简单,基本上按照网上 ...

    8. CF1190D Tokitsukaze and Strange Rectangle

      思路: 线段树 + 扫描线. 实现: #include <bits/stdc++.h> using namespace std; typedef long long ll; ; int n ...

    9. 洛谷 题解 P3942 【将军令】

      本题算法:贪心+排序+搜索+并查集+图论 输入中的t可以不用管,毕竟这只是特殊情况的标志 题目中虽然没有很明确地说明这是一棵树,但是题目中说有n个点,但是只有n-1条边,想用这n-1条边把整个图连通起 ...

    10. 磁盘冗余列阵Raid技术知识与实践

      Raid介绍 什么是Raid?  Raid级别介绍  Raid 技术分类 RAID分为两类: 软RAID, 系统层面实现的,性能差. 硬RAID, 硬件层面实现的,性能好. 主板板载RAID: 功能弱 ...