zoukankan      html  css  js  c++  java
  • Git 学习笔记<远程仓库与标签管理> (四)

    什么是远程仓库?

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

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

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

    创建仓库

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

    关于与远程仓库的连接

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

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

    使用

    1
    $ 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 git@github.com:csdbianhua/learningGithub.git

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

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

    然后是推送你的版本库。

    1
    $ git push -u origin master

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

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

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

    1
    $ git clone git@github.com:csdbianhua/learningGithub.git

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

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

    多人合作

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

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

    已经有的话,可以用

    1
    $git pull

     来让远程库与本地合并。

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

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

    1
    $ git checkout -b dev origin/dev

     并用

    1
    $ git push origin dev

     来推送dev分支。

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

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

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

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

     来绑定分支。

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

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

    标签是什么?

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

    管理标签

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

    1
    $git tag v1.1

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

    1
    $ git tag

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

    给某次commit打标签的话 ,用

    1
    $ 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 打个标签的话。

    键入

    1
    $ git tag v1.0 b26199e

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

    1
    2
    $ git show v1.0
    <BR>commit b26199e24c11a9be640c26f5399eb3e240c77553<BR>Author: 大大大大大沐魇 <imyijie@vip.qq.com><BR>Date:   Tue Aug 5 15:35:32 2014 +0800<BR><BR>    add LICENCE.txt<BR><BR>diff --git a/LICENSE.txt b/LICENSE.txt<BR>new file mode 100644<BR>index 0000000..bda4d91<BR>--- /dev/null<BR>+++ b/LICENSE.txt<BR>@@ -0,0 +1 @@<BR>+MY NAME IS HANSON<BR> No newline at end of file<BR>diff --git a/readme.txt b/readme.txt<BR>index d8036c1..0740acc 100644<BR>--- a/readme.txt<BR>+++ b/readme.txt<BR>@@ -1,2 +1,3 @@<BR>-Git is a version control system.<BR>-Git is free software.<BR> No newline at end of file

    还可以 

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

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

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

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

    删除标签

    1
    $ git tag -d v1.0

    把特定标签推送到远程

    1
    $ git push origin v1.0

    把所有标签推送到远程

    1
    $ git push origin --tags

     删除远程标签的话

    先删除本地的。

    1
    $ git tag -d v0.9

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

    1
    $ git push origin :refs/tags/v0.9
  • 相关阅读:
    Redis设置生存时间或过期时间的相关命令
    .Net Core使用Redis
    Redis的数据类型
    Java集合 使用Collections
    Java集合 使用Iterator
    Java集合 使用Stack
    响应式常用样式汇总
    图片 文字 背景等响应式设置总结
    微信动态聊天工具
    第2章 栅格系统
  • 原文地址:https://www.cnblogs.com/ainubis/p/3990294.html
Copyright © 2011-2022 走看看