git小白入门全攻略
git是什么(写在前边的叨叨,就是给一点不懂的小白打个比喻,大佬请自行跳过)
git在平时的开发中用的太频繁了,以至于我都不知道如何去形容它。囧。
假设我们开发的工作类似于图书整理,写的代码就是很多人借书还书,假设我和你一起来整理这些书,有很多人来借书,你给A一本,我给B一本,这没有任何问题,但是,突然来了C和D,他俩同时要借一本《时间简史》,而且这本书仅此一本,我的手伸向了这本书,你的手也伸向了这本书,然后,是书在我们俩的争夺中被撕成两半了?还是我和你打起来了?
我们当然都不会这么蠢,我们拿书的时候一定会看看对方有没有正在拿,如果你先伸手了我就让给你,没有必要打一架(笑)。
我们多人开发的时候,维护一套代码,git这个工具就包含了我们许多的行为,比如常用的git pull 就相当于是用眼睛去看一下,看看书架是不是有别人已经动过了,别人已经把书摆满了,自己还继续往这个地方放书,当然放不进去啦。
git安装
- windows :https://git-scm.com/downloads
- linux:
yum install git
/apt-get install git
- MacOS:
brew install git
git常规操作
1. 新建仓库,设置全局的个人信息,ssh-key的设置
- 新建仓库
git init
- 设置个人信息
git config --global user.name "yourname"
git config --global user.email test@runoob.com
git config --list //查看当前配置信息
- ssh-key的设置
由于本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以必须要让github仓库认证你SSH key,在此之前,必须要生成SSH key。
首先在家目录下进入 .ssh 文件夹,如果没有这个文件夹或者文件夹下没有id_rsa、id_rsa.pub两个文件,就进行下边的生成过程。
ssh-keygen -t rsa -C "youremail@example.com"
之后一路回车,.ssh文件夹下就有了两个文件,私钥id_rsa和共钥id_rsa.pub,需要提供ssh密钥的都是要的共钥,id_rsa.pub。
2. 拉取远程仓库,设定远程仓库,分支和远程建立连接
- 拉取远程仓库
git clone [git地址]
这个就是最常用的git拉取一个仓库的代码到本地的命令,会在当前的目录下新建一个仓库代码文件夹。如果你的ssh已经保存在这个仓库里了,那么你可以push,否则的话你只有pull的权限。
- 设定远程仓库
比如现在你是在本地init了一个仓库,然后你在github上申请了一个仓库地址,你要把你的代码推到github上,就需要设定远程仓库了。
git remote add [名字] [地址]
比如git remote add origin git@github.com:gaopu1995/hiphp.git
,就可以把本地仓库和远程建立连接。一般默认叫它 origin。
其他的几个远程仓库命令:
git remote //查看当前远程分支名字
git remote -v //查看当前远程分支的url,有两个,一个fetch的,一个push的,一般会是一样的,就是你设置的那一个
git remote remove <name> //移除远程分支
git remote -h //其他的就自己看一下帮助吧
- 当前分支和远程仓库的分支建立连接
git push --set-upstream origin master
如果你删除或者更换了远程仓库,新的仓库在你推送的时候会让你把你当前的分支和远程分支建立映射关系,最后的两个参数就是远程仓库名和远程仓库的分支名,操作对象是你当前分支。
3. 推拉提交,处理冲突
- 推拉提交
git pull //拉取最新代码
git push //把本地提交推送到远程
git add [文件](多个文件空格隔开) //把本地的更改添加到更改缓存中
git commit -m "提交注释" //提交目前缓存中的更改
解释一下:
- git的管理是针对修改的,而推拉的单位都是每次提交的修改,就是你每次拉取(pull)的时候,都是按照别人推送的内容拉取的。比如别人推送了三个文件的修改,那你拉下来,要么不拉取,要么就是这三个文件的改动。
- 而推送的时候,首先是有一个缓存区,你把你想要提交的修改文件添加到这个缓存区,然后提交的时候就会统一把这个缓存区里的所有修改都提交到本地。
- 提交是提交到本地,本地的修改推送(push)到远程仓库,别人才能拉取到你的修改。
- commit的注释一定要写明白。这是个合作工具。交流很重要。
- 处理冲突
- 冲突是什么:比如一个文件,他修改了,而你在没有拉取他的代码之前,也对这个部分修改了,就会产生冲突。
- 为什么会有冲突:前边说过,git是对修改进行管理的,比如本来是一个a,他把a->b,你把a->c,现在他先提交的,你拉取他的代码,你的git合并你们的修改的时候,要把a变成b,但是你已经把a变成c了,git就会把这个区域标出来
- 怎么改:冲突部分会用 >>>>>>>>分支 标出来,改成正确的,add然后commit就行。
4. 新分支,分支合并,分支删除
git checkout [分支名] //切换分支
git checkout -b [新分支名] //从当前分支copy一个新的分支
git branch -d [分支名] //删除分支
git branch //显示当前所在分支
git merge [分支名] //当前分支合并目标分支的修改
5. 暂存stash
git stash //暂存代码
git stash list //查看stash存的内容
git stash pop //恢复第一个暂存
git stash clear //清理暂存
6. 查看log
git log //查看提交记录
git log --oneline //查看提交记录的简单模式
7. 回溯
git reset --hard commit_id //回退到某个版本
git小白入门全攻略的更多相关文章
- SpringCloud之Hystrix服务降级入门全攻略
理论知识 Hystrix是什么? Hystrix是由Netflix开源的一个服务隔离组件,通过服务隔离来避免由于依赖延迟.异常,引起资源耗尽导致系统不可用的解决方案.这说的有点儿太官方了,它的功能主要 ...
- 开发小白也毫无压力的hexo静态博客建站全攻略 - 躺坑后亲诉心路历程
目录 基本原理 方法1 - 本机Windows下建站 (力荐) 下载安装node.js 用管理员权限打开命令行,安装hexo-cli和hexo 下载安装git 初始化hexo 使用hexo gener ...
- 打造一个高逼格的android开源项目——小白全攻略 (转)
转自:打造一个高逼格的android开源项目 小引子 在平时的开发过程中,我们经常会查阅很多的资料,最常参考的是 github 的开源项目.通常在项目的主页面能看到项目的简介和基本使用,并且时不时能看 ...
- 【转】轻松搞定FTP之FlashFxp全攻略
转载网址:http://www.newhua.com/2008/0603/39163.shtml 轻松搞定FTP之FlashFxp全攻略 导读: FlashFXP是一款功能强大的FXP/FTP软件,融 ...
- Android使用XML全攻略(1)
Android使用XML全攻略(1) Android 是针对移动设备的一种新兴的开源操作系统和 SDK.借助它,您可以创建功能强大的移动应用程序.当您的应用程序可以访问 Web 服务时,其吸引力 ...
- MyEclipse优化全攻略
(0) 吐槽 Eclipse仅仅是个半成品有木有?什么都须要自己安装插件,新手非常难用有木有? 安装上插件以后了版本号兼容和各种问题烦死人有木有? 都怪碎片和版本号乱公布有木有? IntelliJ I ...
- VSCode插件开发全攻略(十)打包、发布、升级
更多文章请戳VSCode插件开发全攻略系列目录导航. 发布方式 插件开发完了,如何发布出去分享给他人呢?主要有3种方法: 方法一:直接把文件夹发给别人,让别人找到vscode的插件存放目录并放进去,然 ...
- VSCode插件开发全攻略(三)package.json详解
更多文章请戳VSCode插件开发全攻略系列目录导航. package.json 在详细介绍vscode插件开发细节之前,这里我们先详细介绍一下vscode插件的package.json写法,但是建议先 ...
- VSCode插件开发全攻略(一)概览
文章索引 VSCode插件开发全攻略(一)概览 VSCode插件开发全攻略(二)HelloWord VSCode插件开发全攻略(三)package.json详解 VSCode插件开发全攻略(四)命令. ...
随机推荐
- 从前端和后端两个角度分析jsonp跨域访问(完整实例)
一.什么是跨域访问 举个栗子:在A网站中,我们希望使用Ajax来获得B网站中的特定内容.如果A网站与B网站不在同一个域中,那么就出现了跨域访问问题.你可以理解为两个域名之间不能跨过域名来发送请求或者请 ...
- 如何调整cell的大小
一般情况下,我们使用tableview的时候从来没有设置过cell的大小(w,h).位置(x,y)等,而是系统直接给我们自动生成,但是有的时候我们可能会改动cell的大小及位置,比如:在适配ios6跟 ...
- Java读取Txt封装到对象中——(三)
JavaBean package bean; public class Question { private String timu; //题干 private String leixing; //类 ...
- SpringBoot扩展SpringMVC自动配置
SpringBoot中自动配置了 ViewResolver(视图解析器) ContentNegotiatingViewResolver(组合所有的视图解析器) 自动配置了静态资源文件夹.静态首页.fa ...
- UML和模式应用5:细化阶段(5)---系统顺序图
1.前言 系统顺序图(SSD)是为阐述系统相关的输入和输出事件而快速.简单的创建的制品,它们是操作契约和对象设计的输入. SSD展示了直接与系统交互的外部参与者.系统(作为黑盒)以及由参与者发起的系统 ...
- oracle forall
select * bulk collect into r_115 from TZTJ_CL0115 where nf = v_nf and yf = v_yf and ...
- Centos6.5使用ELK(Elasticsearch + Logstash + Kibana) 搭建日志集中分析平台实践
Centos6.5安装Logstash ELK stack 日志管理系统 概述: 日志主要包括系统日志.应用程序日志和安全日志.系统运维和开发人员可以通过日志了解服务器软硬件信息.检查配置过程中的 ...
- linux设备模型:扩展篇
Linux设备模型组件:总线 一.定义:总线是不同IC器件之间相互通讯的通道;在计算机中,一个总线就是处理器与一个或多个不同外设之间的通讯通道;为了设备模型的目的,所有的设备都通过总线相互连接,甚至 ...
- Ex 5_26 变量约束是否能同时满足(并查集)_第九次作业
利用并查集进行处理,定义一个维护数组components,components[i]表示变量序号为i的变量所处的集合,首先处理相等的变量,把它们放入同一个集合中,最后再处理不相等变量,若两个不相等的变 ...
- Linux服务器性能评估
一.影响Linux服务器性能的因素 1. 操作系统级 CPU 内存 磁盘I/O带宽 网络I/O带宽 2. 程序应用级 二.系统性能评估标准 影响性能因素 影响性能因素 评判标准 好 坏 糟糕 CPU ...