那分布式版本控制系统与集中式版本控制系统有何不同呢?首先,分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比方说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。
和集中式版本控制系统相比,分布式版本控制系统的安全性要高很多,因为每个人电脑里都有完整的版本库,某一个人的电脑坏掉了不要紧,随便从其他人那里复制一个就可以了。而集中式版本控制系统的中央服务器要是出了问题,所有人都没法干活了
在实际使用分布式版本控制系统的时候,其实很少在两人之间的电脑上推送版本库的修改,因为可能你们俩不在一个局域网内,两台电脑互相访问不了,也可能今天你的同事病了,他的电脑压根没有开机。因此,分布式版本控制系统通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改,没有它大家也一样干活,只是交换修改不方便而已。
$ git config --global user.name "Your Name"
$ git config --global user.email "[email protected]"
$ git init
输入以上命令,把这个目录变成Git可以管理的仓库Initialized empty Git repository in D:/.git/
git add
告诉Git,把文件添加到仓库首先 touch readme.txt (创建readme文件)
git add readme.txt
git commit
告诉Git,把文件提交到仓库 git commit -m "wrote a readme file"
$ git status
On branch master //当前的分支
nothing to commit, working directory clean
$ git diff readme.txt
diff --git a/readme.txt b/readme.txt
index 80694b3..610db72 100644
--- a/readme.txt
+++ b/readme.txt
@@ -6,4 +6,4 @@ asdfsdafsdfsdf
adfasdfsd
adfdsaf
-asfasdfas
\ No newline at end of file
+asfasdfas123
$ git log
commit 0f32004c37a6b8b49430f6d22a333470738de94b
Author: wuyinlei <1069584784@qq.com>
Date: Sat Apr 2 10:12:23 2016 +0800
第二次提交
commit 8bcb79e2f0c08c58c9cc37e7bfa11909fd0da1c7
Author: wuyinlei <1069584784@qq.com>
Date: Sat Apr 2 10:10:36 2016 +0800
第一次提交
$ git log --pretty=oneline
0f32004c37a6b8b49430f6d22a333470738de94b 第二次提交
8bcb79e2f0c08c58c9cc37e7bfa11909fd0da1c7 第一次提交
$ git reset --hard HEAD^
HEAD is now at 8bcb79e 第一次提交
**这个时候在次查看就可以看到已经回退了**
$ git log --pretty=oneline
8bcb79e2f0c08c58c9cc37e7bfa11909fd0da1c7 第一次提交
$ git reflog
0f32004 HEAD@{0}: commit: 第二次提交 8bcb79e HEAD@{1}: commit (initial): 第一次提交
git branch dev
git checkout dev
或者
git checkout -b dev //-b参数表示创建并切换
//以下的就是查看创建的分支
若兰@DESKTOP-HNR0QUU MINGW64 /d/wuyinlei (master)
$ git checkout -b dev
Switched to a new branch 'dev'
若兰@DESKTOP-HNR0QUU MINGW64 /d/wuyinlei (dev)
$ git checkout dev
Already on 'dev'
$ git branch
* dev
master
//现在可以在dev分支上修改或者提交内容了,当切换回master分支后是无法查看dev分支修改的内容的
git checkout master
$ git checkout dev
Switched to branch 'dev'
若兰@DESKTOP-HNR0QUU MINGW64 /d/wuyinlei (dev)
$ echo "dev modefi">>readme.txt
若兰@DESKTOP-HNR0QUU MINGW64 /d/wuyinlei (dev)
$ cat readme.txt
dev modefi
$ git add readme.txt
warning: LF will be replaced by CRLF in readme.txt.
The file will have its original line endings in your working directory.
若兰@DESKTOP-HNR0QUU MINGW64 /d/wuyinlei (dev)
$ git commit -m "branch dev"
[dev warning: LF will be replaced by CRLF in readme.txt.
The file will have its original line endings in your working directory.
16fd01f] branch dev
warning: LF will be replaced by CRLF in readme.txt.
The file will have its original line endings in your working directory.
1 file changed, 1 insertion(+)
若兰@DESKTOP-HNR0QUU MINGW64 /d/wuyinlei (dev)
$ cat readme.txt
dev modefi
若兰@DESKTOP-HNR0QUU MINGW64 /d/wuyinlei (dev)
$ git checkout master
Switched to branch 'master'
若兰@DESKTOP-HNR0QUU MINGW64 /d/wuyinlei (master)
$ cat readme.txt
git merge dev
$ git merge dev
Updating 8bcb79e..16fd01f
Fast-forward
readme.txt | 1 +
1 file changed, 1 insertion(+)
//这个时候在查看,就已经合并了
$ cat readme.txt
dev modefi
git branch -d dev
$ git branch -d dev
Deleted branch dev (was 16fd01f).
//在查看,就只有master一个主分支了
$ git branch
* master
ssh-keygen -t rsa -C"email.com"
查看秘钥:
把出来的秘钥复制到github上:
把生成的秘钥:添加到github上
* 在.ssh\目录下创建一个config文件,内容如下:
Host github.com
User git
Hostname ssh.github.com
PreferredAuthentications publickey
IdentityFile~/.ssh/id_rsa
Port 443
测试通过
ssh -t git@github.com
或者
ssh -T git@github.com
以上的我没有测试通过,,,,
下面来看下我自己的push推送吧
我们复制好这里面的地址,然后用GitBash切换到你的项目根目录下
输入以下的命令
$ git clone https://github.com/wuyinlei/loadermanager.git
这个时候,就会在这个目录下创建本地版本库
这个时候我们自己进入到这个目录的根目录下:
然后我们进入这个目录下,把里面的文件剪切出来放到项目根目录下,这个时候删除那个空的文件夹
这个时候在Git Bash上,还是切换到项目的根目录下,输入以下的命令:
$ git add . (.代表着同步全部)
$ git commit -m "一个简单的介绍loader加载器" (""这里面添加注释)
$ git push origin master 提交到远程版本库
这个时候要输入用户名和密码,输入自己的用户名和密码,接着enter按键。
这个时候我们在次刷新网页,可以看到我们的代码已经同步到了github上面:
至此,这个时候我们已经完成了本地和远程库的同步。
参考文档:廖雪峰的Git教程:
http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000