Git 学习笔记<远程仓库与标签管理> (四)

什么是远程仓库?

就像第一章介绍的那样,远程仓库可以储存你编写的所有源码和资源文件.

甚至也可以当网盘使,不过当然有很多契合git管理文本的特性.

下面就要以 github 为示例远程仓库进行介绍.  (也可以自己弄一台服务器作远程仓库).

创建仓库

在主页找到 +New repository 或者右上角的加号里有。输入名字 描述 然后没钱只能public就能确定了。然后呢,点名字打开你的仓库。(主页右下角可以找到)

关于与远程仓库的连接

首先你打开你的保险箱得先证明身份吧,不然我怎么知道你是客户可以放东西?

那么如何进行身份的确认呢? 当然是用密码啦,不过这可意味着你每次要输入密码,而是通过一种SSH Key的东西。

使用

$ ssh-keygen -t rsa

直接回车就行了,不用设置密码。

这样一个命令会在~/.ssh 里创建一个私钥和一个公钥(通常分别叫id_rsa和id_rsa.pub  ,rsa 是加密方式,还有一种dsa方式)。

就像你可以自己做一把钥匙(私钥)和锁(公钥)。把锁挂在你的箱子上,然后用自己的私钥就可以打开了。

不同于现实的是,你可以挂很多把锁,一把打开就可以放东西了~而且只是放东西有限制,不是拿东西。想让拿东西有限制,花钱买VIP吧~

现在先在GitHub注册一个用户。然后点右上角的 account settings。再点SSH Keys。点Add SSH Keys。标题取个看得懂的。然后打开你~/.ssh 下的id_rsa.pub(用gedit ~/.ssh/id_rsa.pub就行了 cat 也可以)

把里面的内容复制进去,确定就可以了。这样你的箱子就挂上了你自己做的锁。如果想让别人也能往你箱子里放东西,让他把锁(公钥)发给你就好了。

现在你可以把你本地版本库推送到远程仓库了。打开你指定的仓库。右边有个 SSH clone URL 是https的话,下面有 You can clone with HTTPS, SSH, or Subversion.点那个ssh就会变成ssh路径。这个地址可以让你敲一行命令就能下载或者上传你的版本库。(下面还有个download ZIP ,下载别人的开源项目可以打包下载)。

现在进入你的本地仓库。输入

$git remote add origin [email protected]:csdbianhua/learningGithub.git

这样就把本地库和远程仓库关联起来了。 orgin是你给远程库取的名字 ,后面的地址应该是你复制的SSH clone URL 。

关联别人的是可以,但是你推送的话没有在我这里挂锁你也是放不了东西的。

然后是推送你的版本库。

$ git push -u origin master

加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来

以后提交的话就可以不用加u了(第一次推送这个分支时用就行了)。

下面是克隆远程库的方法。

$ git clone [email protected]:csdbianhua/learningGithub.git

这条命令就会在当前目录下创建一个learningGithub文件夹,里面就是库里的文件。

另外,可以使用其他形式链接,使用https链接速度较慢。

多人合作

$ git remote -v 显示详细(带-v)的远程仓库信息,包括抓取和推送信息的地址。没有权限就看不到push的地址。

现在你的小伙伴可以在别的电脑上clone远程库到本地。

已经有的话,可以用

$git pull

来让远程库与本地合并。

clone 默认的话 就只有master分支了。

想要别的分支 需要用这个命令本地创建并克隆dev

$ git checkout -b dev origin/dev

并用

$ git push origin dev

来推送dev分支。

万一有推送上去有冲突怎么办? 你只能pull回来到本地然后手动解决冲突即可。就像上章讲的分支合并的冲突处理一样的。

有时候$git pull可能会失败了,这时候你看提示如果是这样 There is no tracking information for the current branch.

那是你没有绑定本地的分支到远程仓库上。用

$ git branch --set-upstream dev origin/dev

来绑定分支。

好了 pull回来了 冲突解决了 add 然后commit -m "some message" 然后 git push origin dev 吧。

改了别人的没有给你权限的开源项目又想推送上去的话,可以发起一个pull request。项目的管理者可以同意也可以不同意。

标签是什么?

标签就是指你给某一刻某个分支的commit打的标签。

管理标签

比如现在你切换到master分支。 键入

$git tag v1.1

这样就打了一个标签 v1.1 给master最后一个commit

$ git tag

查看所有标签,按字母顺序排序的。

给某次commit打标签的话 ,用

$ git log --pretty=oneline --abbrev-commit

可以一行一行列出commit的列表。下面是我这里的情况

54a09c4 just test
90c7aee commit test
b26199e add LICENCE.txt
7ce407c wrote a readme file

这样想给add LICENCE.txt 打个标签的话。

键入

$ git tag v1.0 b26199e

就可以了,想要看标签所在commit的信息,输入

$ git show v1.0
commit b26199e24c11a9be640c26f5399eb3e240c77553Author: 大大大大大沐魇 <[email protected]>Date:   Tue Aug 5 15:35:32 2014 +0800

    add LICENCE.txt

diff --git a/LICENSE.txt b/LICENSE.txtnew file mode 100644index 0000000..bda4d91--- /dev/null+++ b/LICENSE.txt@@ -0,0 +1 @@+MY NAME IS HANSON\ No newline at end of filediff --git a/readme.txt b/readme.txtindex d8036c1..0740acc 100644--- a/readme.txt+++ b/readme.txt@@ -1,2 +1,3 @@-Git is a version control system.-Git is free software.\ No newline at end of file

还可以

$ git tag -a v1.0 -m "some text" b26199e

这样来在打标签的同时写一些备注(-a 指定标签 -m 指定备注 )

$ git tag -s v1.0 -m "some text" b26199e

-a 换成 -s 的话就会用私钥签名这个标签。必须要安装 gpg。此签名不可伪造。

删除标签

$ git tag -d v1.0

把特定标签推送到远程

$ git push origin v1.0

把所有标签推送到远程

$ git push origin --tags

删除远程标签的话

先删除本地的。

$ git tag -d v0.9

然后再删除远程的,格式像下面这样。

$ git push origin :refs/tags/v0.9

Git 学习笔记<远程仓库与标签管理> (四),布布扣,bubuko.com

时间: 2024-12-25 08:18:20

Git 学习笔记<远程仓库与标签管理> (四)的相关文章

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

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

四、git学习之——远程仓库

Git是分布式版本控制系统,同一个Git仓库,可以分布到不同的机器上.怎么分布呢?最早,肯定只有一台机器有一个原始版本库,此后,别的机器可以"克隆"这个原始版本库,而且每台机器的版本库其实都是一样的,并没有主次之分. 你肯定会想,至少需要两台机器才能玩远程库不是?但是我只有一台电脑,怎么玩? 其实一台电脑上也是可以克隆多个版本库的,只要不在同一个目录下.不过,现实生活中是不会有人这么傻的在一台电脑上搞几个远程库玩,因为一台电脑上搞几个远程库完全没有意义,而且硬盘挂了会导致所有库都挂掉,

Git 学习笔记&lt;本地版本库的管理&gt; (二)

今天来记录一下关于版本库的创建与管理的笔记. 版本库是什么? 版本库可以理解为一个仓库(一个可以被git管理的目录),里面文件的修改删除都可以被追踪,并且每个版本都会保存以便还原(仅仅保存修改或删除的文件),于是可以认为保存了各种不同的版本,所以叫版本库. 如何管理? Git给你提供各种不同的指令来管理版本库. 1.创建: 选择一个地方创建一个新文件夹,然后进入这个文件夹(windows中不要出现中文路径) $mkdir LEARNER   //当前目录下新建文件夹 $cd LEARNER //

Git学习笔记(六)分支管理

学习廖雪峰老师的Git教程的笔记,以供自己以后复习查看. ★★★★★ 创建.合并.删除分支.     ★创建分支 git branch branchName --------创建分支               git checkout branchName -----切换到分支           上面两条命令可以合并为:git checkout -b branchName 创建并切换到分支 ★合并分支               git merge branchName -------合并指

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

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

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

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

Git学习笔记整理

Git学习笔记 1.安装Git 注意git config命令的--global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置 $ git config --global user.name "Your Name" $ git config --global user.email "[email protected]" 2.创建版本库-repository $ mkdir learngit $ cd learngit $ pwd /Users/m

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学习笔记(二)学习,今天学习下git分支管理. 1.创建合并分支 默认创建的git目录只有master一个分支,现在我们创建dev分支,然后切换到dev分支: $ git checkout -b dev git checkout命令加上-b参数表示创建并切换,相当于以下两条命令: $ git branch dev $ git checkout dev 然后,用git branch命令查看当前分支: git branch命令会列出所有分支,当前分支前面会标一个*号. 然后,我们就可以在d