在这里下载git:https://git-scm.com/

安装的时候, 如果是windows系统的话, 可以勾选unix的命令行工具, 这样在windows命令行下会多出很多命令, 例如ls.

Git基本命令大致分这些, 这一部分只讲创建项目这块.

  1. 创建git项目
  2. 基本工作流程 (Workflow)
  3. 文件相关操作
  4. 历史和别名
  5. 忽略文件 (Ignoring)

创建项目

1.开始新项目

git init 项目名:

通过这个命令git创建了一个文件夹叫做learn-git.

进入这个目录, 执行ls命令, 不会看到任何文件:

但是如果执行ls -al命令, 就可以看见以.开头的文件了:

这时就可以看到一个.git文件夹了. git的仓库就在这.

进入这个.git文件夹:

回到工作文件夹 (learn-git).

通过git status命令查看git仓库的状态:

可以看到, 目前是在master分支上, master分支是git的默认分支.

目前还没有任何提交(commit), 也没有任何东西需要commit, 因为我还没有创建任何文件, 那么就开始创建文件吧.

[这里我使用vscode]

然后vscode会创建一个lorem.txt文件, 并打开它.

贴进去一些文字:

Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.

如果没有自动换行显示的话, 可以按opt+z:

回到命令行, 再次输入git status查看状态:

这时我们看到了一些变化:

写到是有个文件未被追踪 lorem.txt.

我需要做的就是把这个文件添加到git index或者git staging 区.

这时就使用这个命令: git add lorem.txt.

执行命令后再看一下状态:

这时写到, 有变化需要被提交(commit, 以后说英文吧), 这就是说lorem.txt这个新文件现在处于git的staging区, 等待被commit, 还没有被commit. 我可以移除这个文件, 并且不会有git 仓库(repository)有任何影响. 不过现在我还是想提交它, 所以执行 git commit命令, 如果不带任何参数的话, git将打开默认的编辑器:

我的默认编辑器是vi.

vi的操作是, 输入i, 然后进入insert模式, 就可以输入文字了:

然后按esc, 输入命令:wq 保存并关闭vi. 就会回到原来的命令行.

这里显示了刚才我在git commit时输入的文字, 但是换行没有了, 实际上还有的, 只不过是这里没显示罢了.

还有这个root-commit表示, 这是这个repository的第一个commit.

然后再执行git status:

写到没有需要commit的东西, 工作树是干净的.

这时lorem.txt已经进入了git respository. 这个变化也成了git commit历史的一部分.

2.添加git到现有项目:

需要一个项目, 所以可以访问这个有趣的网站: http://www.initializr.com/ 去生成一个项目:

把这些都勾选上, 这样可以多一些文件.

然后点击Download it.

下载后解压缩该文件, 使用unzip命令:

然后会出现一个initializr目录, 我把这个目录改一下名:

接下来, 进入这个目录, 然后就准备开始把git添加到这个项目了.

使用git init命令, 这时不需要加上项目名参数了:

git就会初始化一个新的repository, 并把当前目录作为working directory 工作目录.

这时就可以看到.git目录了:

查看以下状态 git status:

当前是在master分支, 没有任何commit, 并且有很多未被追踪的文件.

为了把所有这些文件一次性添加到git staging (临时)区和git index (索引), 那就使用命令: git add . 注意这里还有一个点.

git就会把所有的文件都列出来, 因为这个点 . (period) 会把该项目下所有的文件都递归的添加进去.

接下来就是git commit -m "需要写的文字可以写在这里": 这次我是在行内输入的文字, 加参数-m, 然后文字写在双引号内:

这几次命令中还可以看到圆圈里面的文字, 就照着做就行, 进行用户名和邮件的全局配置.

然后再看一下状态 git status:

不出所料.

当前呢, 这个项目/目录是这个git repository的一部分, 之所以称这个working directory是git repository的一部分, 这是因为它下面有个.git目录. 如果把这个目录删除了, 那么它就不再被git所管理了. 下面就这么做一下:

rm -fr .git :

嗯 git status表示这不是一个git repository.

参与Github项目.

先拿张老师的一个项目为例: https://github.com/geffzhang/opendotnet

肯定是需要github账户并登陆的.

fork 项目.

这里, 登陆后, 右上角显示的是我的账户的头像. 左边是该repository的用户以及当前repository的名字.

然后点击fork按钮.

选择我的用户名.

然后, 我就把张老师的项目复制到我的用户名下了,  可以看到左上角是我的用户名, repository名字不变, 还有一个注释, 写的是forked的from原来用户.

随后我要克隆这个项目(clone).

在箭头处复制该repository的地址, 然后打开本地电脑的命令行, 输入命令 git clone repository的地址 来进行clone.

(这里我换了一个项目进行fork, 因为上面这个项目太大了):

可以看到, 项目较大, 进度很慢.

等clone完之后, 进入该文件夹. 可以看到项目文件了:

可以看到.git目录, 里面有文件:

回到上层目录查看状态:

因为这是刚刚clone过来的项目, 所以它是最新的 update to date.

里面的origin 是对这个github repository的远程的引用, /master表示是在这个远程repository的master分支上.

今天就写这些.

这里讲了三种不同为项目添加git的方式.

使用到了几个最常用的命令:

git init, git add, git commit, git status, git clone.

Git基本命令 -- 创建Git项目的更多相关文章

  1. 如何将git本地创建的项目推送到github仓库

    除了集中式的版本控制系统CVS和SVN外,还有目前世界上最先进的分布式版本控制系统Git,它的创始人是创建了linux的大神 - linus.GitHub网站与2008年开始服役,为开源项目免费提供G ...

  2. Java_eclipse软件与git配合使用创建git仓库

    一.在eclipse上安装git,和安装其他插件一样 help->Install new software->add... 在弹出框中输入name,location;点击-->ok ...

  3. eclipse软件与git配合使用创建git仓库

    一.在eclipse上安装git,和安装其他插件一样 help->Install new software->add... 在弹出框中输入name:git,location:http:// ...

  4. git基本命令和仓库操作

    首先git是什么?git是github上的一个代码托管工具,是一款代码版本管理工具,github上的代码是基于git来进行托管的.github是全球的开源社区.Git 保存的不是文件的变化或者差异,而 ...

  5. git入门 创建版本库, 版本管理 分支 标签

    参考: https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 GIT最流行的分布式版本 ...

  6. idea创建springcloud项目图文教程(EurekaServer注册中心)

    http://blog.csdn.net/hcmony/article/details/77854999 idea创建springcloud项目图文教程(EurekaServer注册中心)(六) 1, ...

  7. 【git】搭建git服务器

    在 Linux 下搭建 Git 服务器 目录 ① 安装 Git ② 服务器端创建 git 用户,用来管理 Git 服务,并为 git 用户设置密码 ③ 服务器端创建 Git 仓库 ④ 客户端 clon ...

  8. vs在微软官方tfs创建私有项目过程

    谁也不是成天创建新项目,每次一创建就跟没干过这活似的,这次把它记下,再用的时候来翻,也希望能给别人点帮助. 上https://dev.azure.com/,tfs原来的网址会往这里跳,现在都在往dev ...

  9. 第二章——建立一个HelloWorld项目,练习使用git的add/commit/push/pull/fetch/clone等基本命令。比较项目的新旧版本的差别-----答题者:徐潇瑞

    1.首先下载安装git,很简单所以就不详细说了,当弹出一个类似的命令窗口的东西,就说明Git安装成功 2.因为Git是分布式版本控制系统,所以需要填写用户名和邮箱作为一个标识 3.接着,注册githu ...

随机推荐

  1. Git hook实现自动部署

    Git Hook 是 Git 提供的一个钩子,能被特定的事件触发后调用.其实,更通俗的讲,当你设置了 Git Hook 后,只要你的远程仓库收到一次 push 之后,Git Hook 就能帮你执行一次 ...

  2. 原生js总结(干货)

    1.js基本数据类型 number string boolean underfined null 2.查找文档中的特定元素 document.getElementById("id" ...

  3. 微信小程序AES加密解密

    微信小程序  其实在调用一些第三方 js的时候 其实没有大家想的那么复杂,无非就是把原生js调用方式   改为微信小程序 js调用方式 废话不多说直接贴代码 其实就是将原生function 或者 对象 ...

  4. Redis常见七种使用场景(PHP实战)

    edis 是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API. 本篇文章,主要介绍利用Redis常见应用场景下PHP实战. ...

  5. 【ASP.NET Core】解决“The required antiforgery cookie "xxx" is not present”的错误

    当你在页面上用 form post 内容时,可能会遇到以下异常: The required antiforgery cookie "????????" is not present ...

  6. Hibernate学习(四)get和Load比较

    package cn.lonecloud.test.crud; import org.hibernate.HibernateException; import org.hibernate.Sessio ...

  7. Service工作过程

    Service两种工作状态的作用 1)启动状态:用于执行后台计算 2)绑定状态:用于其他组件和Service的交互 注意:Service这两种状态可以共存,即Service既可以处于启动状态也可以同时 ...

  8. 浅谈CDN、SEO、XSS、CSRF

    CDN 什么是CDN 初学Web开发的时候,多多少少都会听过这个名词->CDN. CDN在我没接触之前,它给我的印象是用来优化网络请求的,我第一次用到CDN的时候是在找JS文件时.当时找不到相对 ...

  9. flask项目开发中,遇到http 413错误

    在flask项目中,上传文件时后台报http 413 Request Entity Too Large 请求体太大错误! 解决的2种方法: 1.在flask配置中设置 MAX_CONTENT_LENG ...

  10. linux RHCS集群 高可用web服务器

    RHCS集群,高可用服务器 高可用 红帽集群套件,提供高可用性,高可靠性,负载均衡,快速的从一个节点切换到另一个节点(最多16个节点)负载均衡 通过lvs提供负载均衡,lvs将负载通过负载分配策略,将 ...