Git Step by Step – (7) Git远程仓库(续)
上一篇文章介绍了Git远程仓库的一些使用,但是还是有些东西需要补充一下,所以有了这个续篇。
.gitignore
前一篇中,我们介绍了Git的patch功能,当我们生成patch之后,"git status"就会显示patch文件是"Untracked files"。当然,我们也没有必要去跟踪这个patch文件。
同样,项目中可能会经常生成一些Git系统不需要追踪(track)的文件,在编译生成过程中 产生的文件或是编程器生成的临时备份文件。我们可以在使用"git add"是避免添加这些文件到暂存区中,但是每次都这么做会比较麻烦。
所以,为了满足上面的需求,Git系统中有一个忽略特定文件的功能。我们可以在工作目录中添加一个叫".gitignore"的文件,来告诉Git系统要忽略哪些文件。
可以看到,当我们使用添加过".gitignore"文件后,文件中的过滤规则就生效了。
注意:
- 在windows环境中不支持文件名为".gitignore",所以可以把文件命名为".gitignore."
- ".gitignore"文件只会对当前目录以及所有当前目录的子目录生效;也就是说如果我们把".gitignore"文件移到"advance"文件夹中,那么过滤规则就是会对"advance"及其子目录生效了
- 建议把".gitignore"文件提交到仓库里,这样其他的开发人员也可以共享这套过滤规则
过滤语法
下面介绍一下常用的过滤语法:
- 斜杠"/"开头表示目录
- 星号"*"通配多个字符
- 问号"?"通配单个字符
- 方括号"[]"包含单个字符的匹配列表
- 叹号"!"表示不忽略匹配到的文件或目录
下面举一些简单的例子:
- foo/*:忽略目录 foo下的全部内容
- *.[oa]:忽略所有.o和.a文件
- !calc.o:不能忽略calc.o文件
exclude文件
在Git仓库中有一个".git/info/exclude"文件,当我们指向对特定的仓库使用特定的过滤规则时,我们可以把过滤语句写在exclude文件中。
细看远程仓库命令
前面一篇文章简单的介绍了push、pull命令的使用,这里将进一步展开介绍。
首先,我们看看"git branch"和"git remote"命令,它们可以给我们提供很多有用的信息。
- git branch
- git remote
git push
push命令用来将本地分支的更新推送的远程仓库,该命令的格式如下:
git push <远程主机名> <本地分支名>:<远程分支名>
- 通过"git push"更新、创建远程分支
- 通过"git push"删除远程分支
- 省略分支信息的"git push origin"
通过这种方式push的时候,报出了一个警告,提示"push.default"没有设置。
在Git中push有两种设置:
- simple方式:只是推送当前分支的更新到对应的远程分支;在Git 2.0以后就默认使用这种方式
- matching方式:会推送所有有对应的远程分支的本地分支
根据Git的提示,我们可以通过"git config --global push.default"来设置push方式。
git pull
pull命令的作用是取回远程某个分支的更新,然后合并到指定的本地分支,pull命令格式如下:
git pull <远程主机名> <远程分支名>:<本地分支名>
- git pull origin release-1.0:release1.0
取回origin主机release-1.0分支的更新,与本地的release-1.0分支合并。
一般来说,pull命令都是在关联的本地分支和远程分支之间进行;当然,你可以使用不关联的本地分支和远程分支进行pull操作,但是不建议这么做。
如果真的需要别的远程分支上的更新,建议使用"cherry-pick"把这个更新拿到关联的远程分支上,然后在关联分支上进行pull操作。
- 省略本地分支名:git pull origin release-1.0
表示取回origin/next远程分支的更新,然后合并到当前分支
- 如果当前分支存在上游(关联)分支,可以直接使用git pull origin
表示本地的当前分支自动与关联的origin主机分支进行合并
"git pull"操作实际上等价于,先执行"git fetch"获得远程更新,然后"git merge"与本地分支进行合并。
当然,pull命令也支持使用rebase模式进行合并:
git pull --rebase <远程主机名> <远程分支名>:<本地分支名>
在这种情况下,"git pull"就等价于"git fetch"加上"git rebase"。
建议使用"git fetch"加上"git rebase"的方式来取代"git pull"获取远程更新,具体原因后面再介绍。
git fetch
fetch命令比较简单,作用就是将远程的更新取回到本地。
- git fetch origin
该命令表示将远程origin主机的所有分支上的更新取回本地
- git fetch origin master
该命令只取回远程origin主机上master分支上的更新
总结
通过这些介绍,相信大家一定会更加熟悉远程仓库操作命令,使得在Git环境中工作的更加顺利。
Git Step by Step – (7) Git远程仓库(续)的更多相关文章
- Git版本控制工具(三)----远程仓库GitHub的使用
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- 初次使用git上传代码到github远程仓库
https://blog.csdn.net/loner_fang/article/details/80488385 2018年05月28日 21:02:31 蒲公英上的尘埃 阅读数:697 因为最近在 ...
- Git推送到多个远程仓库
Git推送到多个远程仓库 Grey 原文地址 准备工作 在码云和Github上分别新建两个不包括任何文件的空仓库(若是两个已经有文件的仓库,请参见关联已经存在的项目) https://github.c ...
- 一、Git的一些命令操作----创建版本库、增加文件到Git库、时光机穿梭、远程仓库
具体详细教程请链接:http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 我这里只是记录 ...
- iOS开发——源代码管理——git(分布式版本控制和集中式版本控制对比,git和SVN对比,git常用指令,搭建GitHub远程仓库,搭建oschina远程仓库 )
一.git简介 什么是git? git是一款开源的分布式版本控制工具 在世界上所有的分布式版本控制工具中,git是最快.最简单.最流行的 git的起源 作者是Linux之父:Linus Bened ...
- git——学习笔记(二)远程仓库
GIT杀手锏之一——远程仓库 拥有远程仓库的两个办法 1:搭一个Git服务器 2:在GitHub上免费托管的Git仓库 本地仓库 远程仓库 一.在GitHub上免费托管的Git仓库 电脑: 1. ...
- Git ~ 大杀器之一 远程仓库 ~ Git
一般情况ixashi找一台电脑作为服务器的角色 , 每天24小时开机 , 其他扥每个人都从这个 “服务器” 仓库里面克隆一份到自己的电脑上面 并且将各自的提交推送到服务器仓库中 , 也可以从服务器仓库 ...
- Git实现从本地加入项目到远程仓库
Git是如今最流行的版本号控制系统之中的一个了,今天也试试了.成功了上传了远程仓库,接下来看看我是怎么做的. 1.首先,要有git的账号.点击查看怎么注冊? 2.注冊成功之后.登陆GitHub.然后, ...
- 使用Git与Github创建自己的远程仓库
原因 早就想创建一个自己的远程仓库,方便发布到Nuget上,自己用也好,项目组用也好,都方便. 今天抽了个时间建了个仓库,随便记下溜方便后来的人. 流程 1,创建自己的GitHub仓库 首先需要到 G ...
- Git:四、连接GitHub远程仓库
1.拥有一个GitHub网站的账号 2.创建SSH Key 打开终端(Windows打开Git Bash),输入: ssh-keygen -t rsa -C "youremail@??.co ...
随机推荐
- 《bootstrap》实战---作为了解
感觉这句话说的挺有道理,"一些最佳实践不管是语义标记还是移动优先的设计,抑或资源性能优化,都需要额外的时间和精力才能时间".用心做,才会做好.
- css中关于居中的那点事儿
css中关于居中的那点事儿 关于居中,无论是水平居中,还是垂直居中都有很多方式,下面我来介绍一些常用的. 第一部分:水平居中 1.实现行内元素的居中.方法:在行内元素外面的块元素的样式中添加:text ...
- Effective Objective-C 2.0 学习记录
由于最近入职,公司安排自由学习,于是有时间将Effective Objective-C 2.0一书学习了一遍.由于个人知识面较窄,对于书中有些内容无法理解透彻,现将所学所理解内容做一遍梳理,将个人认为 ...
- jquery.flip插件翻转效果
首先去网站http://lab.smashup.it/flip/下载插件 简单应用: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Tran ...
- Codeforces 14D
#include<iostream> #include<cstdio> #include<cstring> using namespace std; const i ...
- html进阶css(5)
css定位机制 css有三种基本的定位机制:普通流,浮动和绝对定位. 除非专门指定,否则所有框都在普通流中定位.也就是说,普通流中的元素的位置由元素在html中的位置决定. 块级框从上到下一个接一个的 ...
- log4j控制指定包下的日志
最近观察日志发现如下两个问题: 1.项目用的是springboot项目,整合了rabbitmq,项目启动后,会自动监控rabbitmq谅解是否正常,导致控制台一直输出监控日志,此时就想阻止该类日志输出 ...
- 史上最全Java面试题整理(附参考答案)
下列面试题都是在网上收集的,本人抱着学习的态度找了下参考答案,有不足的地方还请指正,更多精彩内容可以关注我的微信公众号:Java团长 1.面向对象的特征有哪些方面? 抽象:将同类对象的共同特征提取出来 ...
- Hadoop 2.7.4 HDFS+YRAN HA部署
实验环境 主机名称 IP地址 角色 统一安装目录 统一安装用户 sht-sgmhadoopnn-01 172.16.101.55 namenode,resourcemanager /usr/local ...
- docker下debian镜像开启ssh, 允许root用密码登录
用的官方python镜像做开发, 暴露端口, 用pycharm ssh进去开发. 忽然发现本来ssh能连上, 但是更了新的python镜像连不上了. 有折腾了一下, 连上了. 主要是python官网镜 ...