Git基础记录

screenshot

今天终于考完了计算机原理了,之后还有一个在线考试系统的Project要弄,现在急需使用git来管理代码,之前都是很水地知道怎么使用,不过没有经常使用,看了一些学生的博客,觉得自己水的不行了,所以要好好学好PHP的Laravel框架,把项目搞好,后续把雅思考好。

很多人都知道,Linus在1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了。

Linus虽然创建了Linux,但Linux的壮大是靠全世界热心的志愿者参与的,这么多人在世界各地为Linux编写代码,那Linux的代码是如何管理的呢?

事实是,在2002年以前,世界各地的志愿者把源代码文件通过diff的方式发给Linus,然后由Linus本人通过手工方式合并代码!

你也许会想,为什么Linus不把Linux代码放到版本控制系统里呢?不是有CVS、SVN这些免费的版本控制系统吗?因为Linus坚定地反对CVS和SVN,这些集中式的版本控制系统不但速度慢,而且必须联网才能使用。有一些商用的版本控制系统,虽然比CVS、SVN好用,但那是付费的,和Linux的开源精神不符。

不过,到了2002年,Linux系统已经发展了十年了,代码库之大让Linus很难继续通过手工方式管理了,社区的弟兄们也对这种方式表达了强烈不满,于是Linus选择了一个商业的版本控制系统BitKeeper,BitKeeper的东家BitMover公司出于人道主义精神,授权Linux社区免费使用这个版本控制系统。

安定团结的大好局面在2005年就被打破了,原因是Linux社区牛人聚集,不免沾染了一些梁山好汉的江湖习气。开发Samba的Andrew试图破解BitKeeper的协议(这么干的其实也不只他一个),被BitMover公司发现了(监控工作做得不错!),于是BitMover公司怒了,要收回Linux社区的免费使用权。

Linus可以向BitMover公司道个歉,保证以后严格管教弟兄们,嗯,这是不可能的。实际情况是这样的:

Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git!一个月之内,Linux系统的源码已经由Git管理了!牛是怎么定义的呢?大家可以体会一下。

Git迅速成为最流行的分布式版本控制系统,尤其是2008年,GitHub网站上线了,它为开源项目免费提供Git存储,无数开源项目开始迁移至GitHub,包括jQuery,PHP,Ruby等等。

历史就是这么偶然,如果不是当年BitMover公司威胁Linux社区,可能现在我们就没有免费而超级好用的Git了。

  • git的安装略过,我是在windows直接安装git-bash的,然后自带git,安装个vagrant和virtual-box,里面很多软件都集成好了。如果有时间的话我后续会把安装git-bash和vagrant的步骤详细po出来的。
  • 1.创建版本库
     1 $ mkdir firstgit
     2 $ cd firstgit
     3 $ pwd
     4 
     5 /Users/charlieputh/firstgit
    

在你的一个目录下创建一个目录

  • 第二步,通过git init命令把这个目录变成Git可以管理的仓库:

1 root@homestead:/vagrant_data/firstgit# git init 2 Initialized empty Git repository in /vagrant_data/firstgit/.git/

  • 第三步,创建一个readme.txt,并用add加进这个仓库里面

1 root@homestead:/vagrant_data/firstgit# vim readme.txt 2 git add readme.txt 3 //如果是需要加入当前目录的所有文件 使用 git add .

  • 用命令git commit告诉Git,把文件提交到仓库:
  • screenshot

</p>

  • 去远程仓库

screenshot

  • 推送到远程仓库

1 $ git remote add origin git@github.com:charlieputh/firstgit.git

  • 推送完成之后利用git push进行推送
     1 $ git remote add origin git@github.com:charlieputh/firstgit.git
     2 $ git push -u origin master
     3 Counting objects: 3, done.
     4 Writing objects: 100% (3/3), 218 bytes | 0 bytes/s, done.
     5 Total 3 (delta 0), reused 0 (delta 0)
     6 To git@github.com:charlieputh/firstgit.git
     7 * [new branch]      master -> master
     8 Branch master set up to track remote branch master from origin.
    

然后就可以在自己的gayhub上找到自己的repository啦!

后面打算好好看Laravel的文档,自己立一个flag:2months-challenge finish the oes project!

每2-3天来进行更新每次新的project,专门见一个page来更新每次project内容,后续也还会更新git的其他内容。




    Enjoy Reading This Article?

    Here are some more articles you might like to read next:

  • What is Mathematics: Solution Chapter 3
  • What is Mathematics: Solution Chapter 2
  • What is Mathematics: Solution Chapter 1
  • A small guide to supplements: What you need to know
  • 混乱与秩序