Git学习笔记(2)

Git学习笔记(2)

9.远程仓库

你可能会想,如果我的一切东西都存储在自己的电脑上,要是我换了一个电脑,想继续工作;如果电脑硬盘崩掉了,那岂不是我所有的努力都白费了吗?不会的,git当然不会那么局限的,你当然可以在有网络时 ,把你的一切代码推送到git服务器上面,然后就可以在任何地方,想要的话,clone下来就可以了,关于git服务器,你可以自己搭建一个,当然,大多数人都没有那些设备,更没那必要,因为早已有人替你搭建好了,并且还慷慨的可以让你免费使用,那就是github,相信大家都知道他,也早已有他的帐号了吧,这里请对我说yes。 废话了这么多,现在就开始正题吧。由于大家很多人不一定看了我的git学习笔记(1),这里推荐一下:http://blog.csdn.net/it_dream_er/article/details/46980415 我就现在重新建一个例子吧。先到git官网,登录之后,会在网站右上角看到一个小加号,鼠标靠上去,有Create new...字样,点一下,再点击New repository,在新页面输入你要新建的仓库名,选中Initialize this repository with a README,然后直接点击绿色的,Create repository,就可以了。这里,我就输入example吧, 然后,新的页面里显示example这个仓库里只有有一个文件README.md;至此,远程仓库建好了,页面右边有个小方框,上面写着SSH clone URL,复制里面内容,然后回到终端。在一个合适的地方,打开终端,输入:
$ git clone [email protected]:dreamer2018/example.git

出现:

Cloning into ‘example‘...
remote: Counting objects: 3, done.
remote: Total 3 (delta 0), reused 0 (delta 0), pack-reused 0
Receiving objects: 100% (3/3), done.
恭喜,你已成功将远程仓库克隆到本地了,打开名为example的文件夹,里面会有README.md文件。下面,我将介绍有关将本地的文件推送到远程端的命令,为了讲述更清晰,我们就在刚克隆的文件夹里面新建一个文件:example.txt,里面写入git was made by linus ,英语学的不咋的,大家见笑了,然后:
$ git add example.txt
$ git commit -m "example.txt first commit"

这两句命令相信的家再熟悉不过了,然后下面命令大家记住了:

$ git push -u origin master

这句命令是将本地仓库的东西推送(push)到云端仓库,成功push后会出现:

Counting objects: 4, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 306 bytes, done.
Total 3 (delta 0), reused 0 (delta 0)
To [email protected]:dreamer2018/example.git
   d0c976e..86a3168  master -> master
Branch master set up to track remote branch master from origin.
然后,神奇的事出现了,当你再次打开云端的example仓库后,会发现除了原本的README.md之外,还躺着一个名叫example.txt的文件,里面内容是git was made by linus,现在,可以充分说明,你将本地文件成功push上去了。再说一下,关于git push -u origin master这条命令,你可能会发现,许多大神给你秀git时,使用的是git push origin master,这里,我为什么要加-u呢?由于远程库是空的,我们第一次推送时,加上了-u参数,Git不但会把本地的内容推送的远程,还会把本地仓库和远程仓库关联起来,在以后的push或者clone时就可以简化命令。上面,我们使用的是将远程端的仓库克隆到本地,也可以将本地仓库与远程仓库进行关联,看命令:
$ git remote add origin [email protected]:dreamer2018/example.git
就可以了,然后后面的push操作不变。需要注意的是,我是以自己的git做例子,大家敲命令时,要注意将上面的 dreamer2018替换成自己github的账户名就行了。

10.分支管理

什么是分支呢?上面多次出现的master指的就是当前分支。同一个文件,当你多次提交后,git会将其穿成一条时间线,一个提交的时间点,就被称为一条分支。你可能会问:我又不去开发git,分支在我的实际工作中有什么用呢?假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能干活了。如果等代码全部写完再一次提交,又存在丢失每天进度的巨大风险。然而现在有了分支,就不用怕了。你创建了一个属于你自己的分支,别人看不到,还继续在原来的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到开发完毕后,再一次性合并到原来的分支上,这样,既安全,又不影响别人工作。我们先来看看怎样创建分支:
$ git branch dev  //创建一个属于自己的分支dev

然后看看当前有那些分支:

$ git branch

你会发现,出现这样: dev* master上边表明,当前有两个分支,并且当分支指向的是master,切换分支:

$ git checkout dev

会出现:Switched to branch ‘dev‘表明你已经选中了dev这个分支然后在使用git branch这个命令,出现:* dev master表明,当前分支指向的是dev分支。你就可以正常工作了,当然有些人会感到这比较麻烦,有没有一条命令直接创建新分支,然后切换到新的分支呢?是的,有的,如下:

$ git checkout -b dev

我们现在就打开example.txt 这个文件,在里面输入git is a free software,保存退出,然后:

$ git add example.txt
$ git commit -m "example.txt for dev"

然后再切换到master分支,你会发现,该才添加的没了,不用怕,我们现在就把dev分支和master分支合并就可以了

$ git merge dev //将dev分支上面的修改合并到master分支上面

出现:

Updating 86a3168..dda0909
Fast-forward
 example.txt |    1 +
 1 file changed, 1 insertion(+)
表明你就成功了,再打开example.txt 就发现刚才更改的回来了,恩,棒棒的。11.解决冲突可能,你在使用git时还很少使用分支,但是我还是强烈建议你使用分支。说到使用分支,就不可避免的要提到关于主分支和新建的分支合并是出现的种种问题,其中一种常见的比较容易解决的问题,就是在合并时出现冲突的问题,现在,我们开始:问题出现:当你在新建分支里进行修改,然后add,commit,又切换回主分支,进行修改,提交,然后,问题就来了,当你将两分支合并时,就会出现冲突问题,无法合并,那么你得手动的删除不要的,保留有用的,添加没有的,然后再提交。先大概知道了解决思路,下面,在们看例子:依旧是上面example.txt为例。当然,先添加一个分支吧
$ git checkout -b dev;

然后打开文件example.txt,在里面添加一句,create a new line by dev,然后提交。切换到master分支:

$ git checkout master

执行此命令,会出现警告:

Switched to branch ‘master‘
Your branch is ahead of ‘origin/master‘ by 1 commit.
继续修改文件example.txt,在里面添加一句create a new line by master然后再提交。在进行提交时就会出现
Auto-merging example.txt
CONFLICT (content): Merge conflict in example.txt
Automatic merge failed; fix conflicts and then commit the result.
这里,冲突出现了,得手动解决冲突,怎样解决冲突呢?,打开文件,会看到:
git was made by linus
git is a free software
<<<<<<< HEADcreate a new line by master
=======
create a new line by dev
>>>>>>> dev
你要做的就是修改《《《《《和》》》》》》》中间的部分,该删的删,该留的留,然后提交,冲突就解决了。OK,第二次笔记就到此了。
参考文章:http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/001375840202368c74be33fbd884e71b570f2cc3c0d1dcf000

版权声明:本文为博主原创文章,可以不经博主允许转载,但必须注明出处,我将保留追究责任的权利。

时间: 2024-10-12 15:51:37

Git学习笔记(2)的相关文章

Git 学习笔记

Git 学习笔记 本文整理参考廖雪峰的 Git 教程, 整理 Git 学习笔记, 用于 Git 常用命令速查:常用命令用彩色标注! Git学习笔记 $ git config --global user.name "Your Name" 配置本机所有仓库的用户名 $ git config --global user.email "[email protected]" 配置本机所有仓库的Email地址 $ git init 初始化一个Git仓库 $ ls -ah 查看隐

Git学习笔记(二)

本次学习的是 版本回退 基本命令: 查看提交历史      git log 版本回退            git reset 查看每一次的命令 git reflog 具体步骤: 添加一句话到readme.txt中,并提交到Git库中. . readme.txt在Git中目前有三个版本: 按提交时间先后顺序排列如下: 第一个:wrote a readme.txt 第二个:add distrubuted 第三个:add difficulties 如果版本过多的话,根本记不住,只能查看使用命令git

Git 学习笔记&lt;简介与安装&gt; (一)

Git,开源中国以及GitHub所使用的系统, Is A 一个分布式版本控制系统 Be Used to 为团队合作写代码提供方便的管理系统.几乎满足你所有关于合作写代码的幻想. Has 本地端:工作区.版本库 (版本库还含有一个暂存区) 远程仓库:版本库(用来储存版本库的服务器) How To Install Linux: 首先,先输入git,看看是否安装Git: $ gitThe program 'git' is currently not installed. You can install

Git学习笔记总结和注意事项

一.Git简介 Git是目前世界上最先进的分布式版本控制系统,其特点简单来说就是:高端大气上档次! 二.Windows上Git安装 最早Git是在Linux上开发的,很长一段时间内,Git也只能在Linux和Unix系统上跑.不过,慢慢地有人把它移植到了Windows上.现在,Git可以在Linux.Unix.Mac和Windows这几大平台上正常运行了. msysgit是Windows版的Git,从http://msysgit.github.io/下载,然后按默认选项安装即可.安装完成后,在开

Git 学习笔记&lt;远程仓库与标签管理&gt; (四)

什么是远程仓库? 就像第一章介绍的那样,远程仓库可以储存你编写的所有源码和资源文件. 甚至也可以当网盘使,不过当然有很多契合git管理文本的特性. 下面就要以 github 为示例远程仓库进行介绍.  (也可以自己弄一台服务器作远程仓库). 创建仓库 在主页找到 +New repository 或者右上角的加号里有.输入名字 描述 然后没钱只能public就能确定了.然后呢,点名字打开你的仓库.(主页右下角可以找到) 关于与远程仓库的连接 首先你打开你的保险箱得先证明身份吧,不然我怎么知道你是客

【版本控制】git学习笔记(二)

关于git的基本使用请阅读上篇博文内容,[版本控制]git学习笔记(一). 1.远程仓库 Git是分布式版本控制系统,同一个Git仓库,可以分布到不同的机器上.怎么分布呢?最早,肯定只有一台机器有一个原始版本库,此后,别的机器可以"克隆"这个原始版本库,而且每台机器的版本库其实都是一样的,并没有主次之分. 你肯定会想,至少需要两台机器才能玩远程库不是?但是我只有一台电脑,怎么玩? 其实一台电脑上也是可以克隆多个版本库的,只要不在同一个目录下.不过,现实生活中是不会有人这么傻的在一台电脑

Git学习笔记(四)

一.忽略特殊文件 在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件. 不需要从头写.gitignore文件,GitHub已经为我们准备了各种配置文件,只需要组合一下就可以使用了.所有配置文件可以直接在线浏览:https://github.com/github/gitignore .gitignore文件本身要放到版本库里,并且可以对.gitignore做版本管理! 二.配置别名 $ git config --global al

git学习笔记(非常乱)

gitwiki 我是一个php程序员,但是我还是用windows开发环境.我不争气. 下载 git bash(windows环境下的git) 安装完之后设置用户名和邮箱 git config --global user.name "linjingxiong" git config --global user.email "[email protected]" 基本的命令: git init cd /d/../../  进入D盘的某目录 pwd          列出

Git 学习笔记&lt;分支管理&gt; (三)

分支是什么? 分支就像树分出的树枝,不同的是,它们之间可以互相合并. 将版本的推进想象成一个链表的伸长:  version 1.0 ==> version 2.0 ==>version3.0  . master是主要的分支基本上用于发布产品.你可以从master分出一个dev,在上面创建新功能,或者修bug然后调试.最后再合并到master里面.就像下面这样. master分支:  version 1.0=========>version 2.0===... \            

Git学习笔记(8)——标签管理

本文主要记录的Git标签的作用.标签的多种创建方式,以及标签的删除,与推送,和使用GitHub的Fork参与别人的项目. 标签的作用 发布版本时,通常先在版本库中打一个标签,这样,就唯一确定了打标签时刻的版本.无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来.所以,标签也是版本库的一个快照.Git的标签虽然是版本库的快照,但其实它就是指向某个commit的指针(跟分支很像,但是分支可以移动,标签不能移动),所以,创建和删除标签都是瞬间完成的. 创建标签 [email pro