Android学习工具之一自己创建Git库(Dean)

在前面一篇文件简述了一个标准流程的基本Git的操作!现在我尝试自己建立git库并操作文件将git命令的使用进行分析!采用SSH方式让局域网的同学们可以访问并且push和clone!

首先要安装的几个工具包:
Java代码   收藏代码
  1. git工具包  
  2. sudo apt-get install git-core    
  3. 一个图形操作界面的git工具  
  4. sudo apt-get install gitk  
  5. 局域网访问个哦你觉包ssh  
  6. sudo apt-get install ssh  
git工具包
sudo apt-get install git-core  
一个图形操作界面的git工具
sudo apt-get install gitk
局域网访问个哦你觉包ssh
sudo apt-get install ssh


注意了!开始搭建了!
先创建一个workspaces文件夹
Java代码   收藏代码
  1. deanye@dean:~$ mkdir workspaces  
  2. deanye@dean:~$ cd workspaces  
deanye@dean:~$ mkdir workspaces
deanye@dean:~$ cd workspaces



将此文件夹作为版本库
Java代码   收藏代码
  1. deanye@dean:~/workspaces$ git init  
  2. Initialized empty Git repository in /home/deanye/workspaces/.git/  
deanye@dean:~/workspaces$ git init
Initialized empty Git repository in /home/deanye/workspaces/.git/



这样,一个空的版本库就创建好了,并在当前目录中创建一个叫 .git 的子目录。你可以用 ls -a 查看一下,并请注意其中的三项内容:
  * 一个叫 HEAD 的文件,我们现在来查看一下它的内容:
  $ cat .git/HEAD
  现在 HEAD 的内容应该是这样:
  ref: refs/heads/master
  我们可以看到,HEAD 文件中的内容其实只是包含了一个索引信息,并且,这个索引将总是指向你的项目中的当前开发分支。
  * 一个叫 objects 的子目录,它包含了你的项目中的所有对象,我们不必直接地了解到这些对象内容,我们应该关心是存放在这些对象中的项目的数据。
  Note
  关于 git 对象的分类,以及 git 对象数据库的说明,请参看 [Discussion]
  * 一个叫 refs 的子目录,它用来保存指向对象的索引。
  具体地说,子目录 refs 包含着两个子目录叫 heads 和 tags,就像他们的名字所表达的意味一样:他们存放了不同的开发分支的头的索引, 或者是你用来标定版本的标签的索引。
  请注意:master 是默认的分支,这也是为什么 .git/HEAD 创建的时候就指向 master 的原因,尽管目前它其实并不存在。 git 将假设你会在 master 上开始并展开你以后的工作,除非你自己创建你自己的分支。
  另外,这只是一个约定俗成的习惯而已,实际上你可以将你的工作分支叫任何名字,而不必在版本库中一定要有一个叫 master 的分支,尽管很多 git 工具都认为 master 分支是存在的。
  现在已经创建好了一个 git 版本库,但是它是空的,还不能做任何事情,下一步就是怎么向版本库植入数据了。

新建几个文件和文件夹
Java代码   收藏代码
  1. deanye@dean:~/workspaces$ mkdir text_a  
  2. deanye@dean:~/workspaces$ mkdir text_b  
  3. deanye@dean:~/workspaces$ ls  
  4. text_a  text_b  
  5. deanye@dean:~/workspaces$ echo "abc">>text_c  
  6. deanye@dean:~/workspaces$ echo "abcd">>text_d  
  7. deanye@dean:~/workspaces$ ls  
  8. text_a  text_b  text_c  text_d  
  9. deanye@dean:~/workspaces$   
deanye@dean:~/workspaces$ mkdir text_a
deanye@dean:~/workspaces$ mkdir text_b
deanye@dean:~/workspaces$ ls
text_a  text_b
deanye@dean:~/workspaces$ echo "abc">>text_c
deanye@dean:~/workspaces$ echo "abcd">>text_d
deanye@dean:~/workspaces$ ls
text_a  text_b  text_c  text_d
deanye@dean:~/workspaces$ 




查看当前的状态
Java代码   收藏代码
  1. deanye@dean:~/workspaces$ git status  
deanye@dean:~/workspaces$ git status




这个时候可以案件刚才添加的两个文本文件的状态!文件夹为空所以无法看到

可以添加一个修改text_c到默认的branch master 然后在次查看状态
Java代码   收藏代码
  1. deanye@dean:~/workspaces$ git add text_c  
deanye@dean:~/workspaces$ git add text_c



git add 实际上是个脚本命令,它是对 git 内核命令 git update-index 的调用。因此上面的命令和下面的命令其实是等价的:
  $ git update-index --add text_c
  如果你要将某个文件从 git 的目录跟踪系统中清除出去,同样可以用 git update-index 命令。例如:
  $ git update-index --force-remove text_c

也可以全部添加当期的改动文件(注意此时并为提交到branch)
Java代码   收藏代码
  1. deanye@dean:~/workspaces$ git add .  
deanye@dean:~/workspaces$ git add .




通过 git commit 命令来提交:
Java代码   收藏代码
  1. deanye@dean:~/workspaces$ git commit -m "first commit"  
deanye@dean:~/workspaces$ git commit -m "first commit"




查看历史修改
Java代码   收藏代码
  1. deanye@dean:~/workspaces$ git log  
deanye@dean:~/workspaces$ git log




修改两个文件并且查看修改文件diff
Java代码   收藏代码
  1. deanye@dean:~/workspaces$ git diff .  
deanye@dean:~/workspaces$ git diff .




我们可以再次使用组合命令 git add 和 git commit 将我们的工作提交到版本库中
Java代码   收藏代码
  1. deanye@dean:~/workspaces$ git add .  
  2. deanye@dean:~/workspaces$ git commit -m "second"  
deanye@dean:~/workspaces$ git add .
deanye@dean:~/workspaces$ git commit -m "second"


或者直接
Java代码   收藏代码
  1. git commit -a -m "second"  
git commit -a -m "second"


上面是提交的基本流程下面一个重点也是git的精髓
Java代码   收藏代码
  1. 管理分支  
管理分支

查看当前分支
Java代码   收藏代码
  1. deanye@dean:~/workspaces$ git branch  
deanye@dean:~/workspaces$ git branch


创建一个分支并移到该分支
deanye@dean:~/workspaces$ git checkout -b first


git show-branch 命令可以使我们看到版本库中每个分支的世系发展状态,并且可以看到每次提交的内容是否已进入每个分支。
Java代码   收藏代码
  1. deanye@dean:~/workspaces$ git show-branch   
deanye@dean:~/workspaces$ git show-branch 


从上图可以看出branch的层次结构类似与树形
关于 GIT 版本世系编号的定义,请参看 git help rev-parse

再用 git whatchanged 命令来看看 master 分支是怎么发展的

deanye@dean:~/workspaces$ git checkout  master


我们可以在每一个不同分支上做自己的修改!
也就是有多种不同的工程环境!

合并两个分支:git merge
Java代码   收藏代码
  1. $ git checkout master  
  2. $ git merge -m "Merge" second  
$ git checkout master
$ git merge -m "Merge" second

合并两个分支,还有一个更简便的方式,下面的命令和上面的命令是等价的
Java代码   收藏代码
  1. $ git checkout master  
  2. $ git pull . second  
$ git checkout master
$ git pull . second

但是,此时 git 会出现合并冲突提示:$ cat text_c然后解决冲突
还有更复杂的三路合并和多内容树合并的情况。详情可参看: git help read-tree, git help merge 等文档。

逆转与恢复
逆转与恢复:git reset
  项目跟踪工具的一个重要任务之一,就是使我们能够随时逆转(Undo)和恢复(Redo)某一阶段的工作。
  git reset 命令就是为这样的任务准备的。它将当前的工作分支的 头 定位到以前提交的任何版本中,它有三个重置的算法选项。
  命令形式:
  git reset [--mixed | --soft | --hard] [<commit-ish>]
  命令的选项:
  --mixed
  仅是重置索引的位置,而不改变你的工作树中的任何东西(即,文件中的所有变化都会被保留,也不标记他们为待提交状态),并且提示什么内容还没有被更新了。这个是默认的选项。
  --soft
  既不触动索引的位置,也不改变工作树中的任何内容,我们只是要求这些内容成为一份好的内容(之后才成为真正的提交内容)。这个选项使你可以将已经提交的东西重新逆转至“已更新但未提交(Updated but not Check in)”的状态。就像已经执行过 git update-index 命令,但是还没有执行 git commit 命令一样。
  --hard
  将工作树中的内容和头索引都切换至指定的版本位置中,也就是说自 <commit-ish> 之后的所有的跟踪内容和工作树中的内容都会全部丢失。因此,这个选项要慎用,除非你已经非常确定你的确不想再看到那些东西了。
  一个重要技巧--逆转提交与恢复
Java代码   收藏代码
  1. git reset 44b8f4ca48673291ee6fa77f7c076c476a86f5f2 --hard  
git reset 44b8f4ca48673291ee6fa77f7c076c476a86f5f2 --hard

两种类型的标签
  在 git 中,有两种类型的标签,“轻标签”和“署名标签”。
  技术上说,一个“轻标签”和一个分支没有任何区别,只不过我们将它放在了 .git/refs/tags/ 目录,而不是 heads 目录。因此,打一个“轻标签”再简单不过了。
  $ git-tag my-first-tag
  如果你打算针对某个commit ID来打标签,虽然该命令可以通过gitk里的右键菜单来实现,但是该命令对实际应用是很有帮助的。
  $ git-tag mytag f0af6283824688f9d23426031734657661b54388
  “署名标签”是一个真正的 git 对象,它不但包含指向你想标记的状态的指针,还有一个标记名和信息,可选的 PGP 签名。你可以通过 -a 或者是 -s 选项来创建“署名标签”。
  $ git-tag -s <tag-name>

在另一台电脑上访问并操作此git库
Java代码   收藏代码
  1. deanye@dean:~$ mkdir text  
  2. deanye@dean:~$ cd text  
  3. deanye@dean:~/text$ git clone ssh://deanye@10.100.13.126/home/deanye/workspaces  
  4. Initialized empty Git repository in /home/deanye/text/workspaces/.git/  
deanye@dean:~$ mkdir text
deanye@dean:~$ cd text
deanye@dean:~/text$ git clone ssh://deanye@10.100.13.126/home/deanye/workspaces
Initialized empty Git repository in /home/deanye/text/workspaces/.git/




Java代码   收藏代码
  1. 修改文件如果需要提交可以提交的到git库的某一个分支  
  2. deanye@dean:~/text/workspaces$ git branch  
  3. 获取当前分支名  
  4. deanye@dean:~/text/workspaces$ git push ssh://deanye@10.100.13.126/home/deanye/workspaces/$REPO_PROJECT.git master:first  
修改文件如果需要提交可以提交的到git库的某一个分支
deanye@dean:~/text/workspaces$ git branch
获取当前分支名
deanye@dean:~/text/workspaces$ git push ssh://deanye@10.100.13.126/home/deanye/workspaces/$REPO_PROJECT.git master:first



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值