Git从零开始(三)

一、远程仓库管理

  1、将本地内容推送到远程库

  先关联远程库,执行命令: git remote add origin https://github.com/Hollydan/gitstore.git (仓库地址可以同git协议 [email protected]:Hollydan/gitstore.git)

    origin指远程库的名字,可以自己起名;后面是远程服务器仓库地址(这里是我github库地址,Hollydan是github用户名,gitstore.是新建的远程库,根据自己实际情况填写)

  然后将本地库的内容推送到远程库:git push -u origin master

    第一次推送时会提示是否信任远程服务器,输入yes回车就好了。以后提交时只需要命令 git push origin master 

  2、从远程库克隆到本地库

  现在远程库添加一个仓库,然后执行: git clone [email protected]:Hollydan/test.git 在本地就多了一个test文件夹。

二、分支管理(默认是master分支)

  1、先创建分支并切换到新的分支。

    git branch dev

    git checkout dev

    上面两条命令也可以合并为一条:git checkout -b dev

    

    会看到提示,已经切换到了新分支dev

  2、查看分支

    git branch

    

    可看到有两个分支,而当前分支dev前面有个星号,从现在开始提交的所有文件都在dev分支上而不会改变之前master分支上的内容。

  3、切换回master,并将dev分支文件合并到master

    git checkout master

    git merge dev

    当两个分支改了同一个文件时,合并会发生冲突,这时应该先找到两次文件的不同,然后在合并。git log --graph 可以看到分支合并情况

    合并分支时,用普通模式,合并后的历史有分支, git merge --no-ff -m "merge with no-ff" dev 

  4、删除dev分支

    合并完之后就可以放心删除啦, git branch -d dev ,再git branch时就只能看到master一个分支啦。

    如果不想合并可强行删除, git branch -D dev

三、工作现场储藏及恢复

  1、储藏

    git stash  (可多次stash),git stash list 可查看储藏的工作现场。

  2、恢复并删除储藏

    git stash apply

    git stash drop

    上面两条命令可用一条代替: git stash pop 恢复的同时把stash删除

四、标签管理

  1、创建标签

    默认在当前版本创建标签: git tag v1.0 ,可用命令 git tag 查看标签

    如果给之前版本创建tag,则执行: git tag v0.8 6224937 (后面跟版本号)

    创建带注释的标签: git tag -a v1.0 -m "vision 1.0" 6224937 git show v1.0 可看到tag的详细信息

  2、删除本地标签

    git tag -d v1.0

  3、推送标签到远程

    git push origin v1.0 ,也可一次推送所有tag: git push origin --tags

  4、删除远程标签

    先删除本地 git tag -d v1.0 ,然后执行: git push :refs/tags/v1.0

    如果有多个stash,则用命令: git stash apply [email protected]{0} 

时间: 2024-10-20 04:49:04

Git从零开始(三)的相关文章

快速入门git第三步

安装:一.在linux ubuntu 上安装git sudo apt-get install git配置:二.初次运行git的配置,为什么是初次,因为更新或升级都会沿用老的git的配置, 可以用相同的命令进行了配置的修改, git 提供了一个工具git config ,专门用来配置或读取相应的环境变量,不同的环境变量导致了git在各个环节的具体工作方式和行为,环境变量存放在三个地方:/ect/config: 系统中对所有的用户都普遍使用的配置-/config: 只是适用与当前用户的配置.git/

Bmob移动后端云服务平台--Android从零开始--(三)Bmob数据操作((批量)增删改)

Bmob移动后端云服务平台--Android从零开始--(三)Bmob数据操作((批量)增删改) 上篇文章简单的利用Bmob实现了用户注册与登录效果(http://blog.csdn.net/a123demi/article/details/42059621). 在项目中,对数据的操作脱离不了增删改查.Bmob其实也一样,他对数据操作的增删改查做了很好的封装,以及其批量的处理.本文将重点讲解利用Bmob实现Android端与Bmob服务端的数据操作,实现增加.修改.删除以及他们的批量处理. 源码

【git学习三】git基础之git管理远程仓库

1.背景 git管理远程仓库,本文以github为例. 2.管理远程仓库 1.本地ssh认证,在github建立一个repo叫做ospaf-GetWordFre 2.添加远程仓库,可以用git remote 命令实现,o是仓库名,可以用git remote -v查看 git remote add o git://github.com/jimenbian/ospaf-GetWordFre.git 3.接着就可以向github上fetch或是push代码了.注意要选择分支 /************

Git入门(三)——没有版本控制意识的程序员不是一个好的程序员

之前所讲的都是"自娱自乐",自己管理自己的项目.本篇主要是Git入门的尾声,也是最为精华的一部分,即利用Git进行版本控制,进行"团队协作开发",也会介绍分支合并以及合并冲突时常见的处理方法. 五.团队协作流程 1. 基本流程 (1) 创建一个分支 当你在开发一个项目的时候,一般在同一时刻你会同时展开多个想法,其中一些比较成熟了,另一些还是很初级的.有了分支就可以很好地来进行管理了.当你在项目中创建一个分支的时候,你可能就是正在搭建一个可以尝试新想法的环境.你在新分

Git基础(三)

本章 就开始和大家一起学习第三块内容:远程仓储的使用操作.要参与任何一个 Git 项目的协作,必须要了解该如何管理远程仓库.远程仓库是指托管在网络上的项目仓库,可能会有好多个,其中有些你只能读,另外有些可以写.同他人协作开发某 个项目时,需要管理这些远程仓库,以便推送或拉取数据,分享各自的工作进展.管理远程仓库的工作,包括添加远程库,移除废弃的远程库,管理各式远程库分 支,定义是否跟踪这些分支,等等.本章我们将详细讨论远程库的管理和使用. 1.查看远程仓储 项目开发到一定的阶段,就需要将内容提交

Git中三种文件状态及其转换

Git作为一种版本控制解决方案,由于其具有的分布式特性,正被越来越多的用户熟知,一些有名的开源项目,如:Linux kernel,CakePHP,Ruby on Rails等,都在使用Git进行版本管理. 在Git中,文件状态是一个非常重要的概念,不同的状态对应不同的操作.因此,要想熟练掌握Git的用法,需要了解Git的几种文件状态. 为了说明的方便,现在初始化一个项目,也就是将项目所在目录纳入Git的管理之下.假设项目目录为hello_world,初始化之后,在目录下新建README.txt文

git学习——<三>git操作

一.创建仓库 创建一个目录 mkdir repository cd到该目录下,初始化该版本库 git init 至此,版本库创建成功,可以在该文件夹下看到.git文件夹,ls -ah可以看到该文件夹. 二.版本管理 1.将文件或文件夹添加到版本库中进行版本控制 在工作区创建一个文件 touch readme.txt 将该文件添加到暂存区 git add readme.txt 将文件从暂存区提交到版本库 git commit -m "some comment" *工作区.暂存区.版本库

Git从零开始(一)

一.首先windows安装git客户端 官网下载地址:https://git-for-windows.github.io/,这里下载会很慢,我试了好几次都失败了. 百度网盘资源: https://pan.baidu.com/s/1geHPPIz密码: sp6q 下载完之后选择安装路径,然后按照提示next,最后install. 然后在开始菜单下找到git下面的git bash,会弹出一个命令窗口,说明安装成功了. git是分布式版本控制系统,每个机器都需要有自己的名字和邮箱地址,接下来,在命令行

Git系列三之在线GitHub使用方法

代码托管地址:https://github.com 一.认证方式 1.https方式:不需要认证 [[email protected] demo]# git clone https://github.com/nulige/Bastion-of-machine.git Initialized empty Git repository in /root/demo/Bastion-of-machine/.git/ warning: You appear to have cloned an empty