用git管理我们的代码有很多好处,首先,每一个 Git克隆 都是一个完整的文件库,含有全部历史记录和修订追踪能力,相对独立。不依赖于网络连接或中心服务器。最大特色就是“分支”及“合并”操作非常快速、简便。把内容按元数据方式存储,完整克隆版本库。
版本控制之Git(初体验)介绍了git管理代码的初级应用。下图整理平时工作中常用的命令。
关于hash值
首先我们先创建三个文件test.txt 和 README 和 LISENCE,git add . 提交到暂存区之后 git commit 到历史记录区。
上节说过,一旦git init初始化之后,在我们的文件夹里就会出现.git文件,里面是git的元数据。那我们cd .git 查看一下,git里面究竟是什么内容、发现里面很多东西,那我们后面会解释这些东西是什么,先cd objects,打开这个文件夹,发现里面还有一些,那我们再随便打开查看一下ls 0b,发现这个字符串特别像commit的hash值,那我们git log(下图)查看一下,发现git把commit的sha1的hash值拆分成了两个部分,前两个字母0a,作为一个文件夹,后边一部分作为文件放在文件夹里。这样是为了检索的方便。
那我们git cat-file -p 0a62da68834c3czd13c3b0d02b9771e184bdadf3 查看一下这个hash值里面的内容
发现里面有tree,和tree的hash值,tree是树的概念,那我们再git cat-file -p <tree的hash值>,查看一下里面的内容,发现里面还有3个hash值,这三个hash值又正好对应我们刚开始创建的三个文件。
每当我们提交一次的时候,我们所在的目录作为一个整体,git用一种数据结构,叫tree来表示它,给他生成一个hash值,这个hash值里面包含了我们所有的文件,每个具体文件都是一种blob结构,并且他也有一个hash值,这个hash值里面,就是文件的内容。
所以,对于git来讲,每一个目录都是tree的形式存在的,每个不可分割的文件,都是以blob的形式存在的。
此时,我们仔细看着5个hash值,再查看一下objects中的文件夹,发现每个hash值的前两个字符正好对应5个文件夹的名称。
那此时如果我们更改text.rb里面的文件内容,并且提交上去。git log 查看日志,发现多了一个hash值
那我们再次打开这个hash值,会发现,git将它重新进行了一次sha1的hash,但是其他没有更改的两个文件的hash并没有变化。
这说明,我们每次更改并且提交文件的时候,对应文件的hash值会变化,随之我们对应的tree的hash值和提交时产生的commit的hash值也会变化。所以,我们只要更改一个文件,就会至少会产生3个hash值的变化。那是不是很浪费空间,其实计算机在闲置的时候会自动压缩很久没有使用的hash值。
但是,新提交的时候,会有一个parent的hash值,这个hash值指向的就是我们上一次提交的文件、这样就将我们每次提交的文件都会保留下来。比如说我们最后一次提交的C文件,他的parent的hash值指向了上一次提交的B文件,B文件的parent的hash值就指向了他第一次提交的A文件。这样就将我们的历史记录联系了起来。
git应用----上传代码至新浪云
1、获取域名
首先在新浪云中创建一个云应用。
新浪云首页---控制台---云应用SAE---应用管理---创建新应用---填写二级域名信息和应用名称---创建应用
2、创建应用成功后,会弹出一个窗口,里面是你的仓库信息
3、注意图片下方的git代码部署说明。
1、先将我们本地的代码的文件进行git init初始化,变成git仓库
2、然后git add . 将我们的全部文件添加到暂存区
3、git commit -m ‘日志’ 将我们的代码填写好日志由暂存区提交到历史记录区
4、然后git push sae master:1 将我们本地的代码上传到新浪云的服务器中
5、重新刷新新浪云的网页,这时就能在新浪云服务器中查看我们的代码了。
当然,如果我们如果已经在本地提交到历史记录区了,那么直接push进新浪云就可以。
利用git也可以上传代码到github,利用github管理我们的代码。这个应该玩过github的人都知道的