Git的使用和部署
Git是什么?
Git是目前世界上最先进的分布式版本控制系统(没有之一)。
什么是版本控制系统?
- 没有版本控制系统
- 有了版本控制系统
版本 | 文件名 | 用户 | 说明 | 日期 |
---|---|---|---|---|
1 | service.doc | 张三 | 删除了软件服务条款5 | 7/12 10:38 |
2 | service.doc | 张三 | 增加了License人数限制 | 7/12 18:09 |
3 | service.doc | 李四 | 财务部门调整了合同金额 | 7/13 9:51 |
4 | service.doc | 张三 | 延长了免费升级周期 | 7/14 15:17 |
- 版本控制工具的作用:保存工作副本 保留代码更改的历史记录 在需要时返回到工作版本(代码回滚) 分支管理 代码合并
常见版本控制系统
集中式
特点:只有一台版本服务器
缺点:必须联网才能工作
- CVS是最早的开源而且免费的集中式版本控制系统
- SVN修正了CVS的一些稳定性问题
- IBM的ClearCase:安装大 速度慢
- 微软VSS(Visual Source Safe)
分布式
特点:每个人的电脑都是服务器 强大的分支管理
- git
- BitKeeper
- Mercurial和Bazaar
git的诞生
![](img/Linus Benedict Torvalds.png)
Linus Torvalds
Linus在1991年创建了开源的Linux,已经成为最大的服务器系统软件了。
Linus虽然创建了Linux,但Linux的壮大是靠全世界热心的志愿者参与的
那Linux的代码是如何管理的呢?
在2002年以前,手工方式合并代码!
集中式的CVS和SVN速度慢,需要联网
商用的版本控制系统,需要付费,不符合linux的开源精神
2002年,使用BitKeeper(属于BitMover公司)
2005年BitMover收回linux社区免费使用权
Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git
一个月之内,Linux系统的源码已经由Git管理了!牛是怎么定义的呢?大家可以体会一下。
Git迅速成为最流行的分布式版本控制系统,尤其是2008年,GitHub网站上线了,它为开源项目免费提供Git存储
安装git
Git可以在Linux、Unix、Mac和Windows这几大平台上正常运行了。
在Linux上安装Git
- 输入
git
,查看git是否安装
$ git
The program 'git' is currently not installed. You can install it by typing:
sudo apt-get install git
在Mac OS X上安装Git
- 一是安装homebrew,然后通过homebrew安装Git,具体方法请参考homebrew的文档:http://brew.sh/。
- 第二种方法更简单,也是推荐的方法,就是直接从AppStore安装Xcode,Xcode集成了Git,不过默认没有安装,你需要运行Xcode,选择菜单“Xcode”->“Preferences”,在弹出窗口中找到“Downloads”,选择“Command Line Tools”,点“Install”就可以完成安装了。
Xcode是Apple官方IDE,功能非常强大,是开发Mac和iOS App的必选装备,而且是免费的!
在Windows上安装Git
- git下载地址 https://git-scm.com/downloads
- 右键Git Bash通过git命令查看是否成功
- 右键Git Bash通过git version查看版本
自我介绍给git
每次 Git 提交时都会引用这两条信息,说明是谁提交了更新
git config --global user.name "Yakov Fain"
git config --global user.email "yakovfain@gmail.com"
** | 如果您希望能够为不同的项目使用不同的用户名和电子邮件,请在没有--global选项的情况下从项目目录运行上述命令。 |
---|---|
- 查看用户信息
git config --list
创建版本库repository
版本库:可以简单理解成一个目录,这个目录里的所有文件都可以被git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。
首先创建一个项目的目录
目录下执行git init
$ git init
Initialized empty Git repository in /Users/michael/learngit/.git/
通过
git init
命令把这个目录变成Git可以管理的仓库:目录下多了一个
.git
的目录,这个目录是Git来跟踪管理版本库的如果没有看到
.git
目录,因为这个目录默认是隐藏的,用ls -ah
命令即可看见接下来就可以在当前文件夹创建项目文件,比如:Fish.java Pet.java PetMaster.java
忽略文件
编译的中间文件比如class这些文件我们不需要上传到git,就可以通过忽略文件来实现
工程目录下执行
touch .gitignore
生成忽略文件在文件中定义忽略的内容,写法如下
忽略的标准
- 忽略操作系统自动生成的文件,比如缩略图等;
- 忽略编译生成的中间文件、可执行文件等,也就是如果一个文件是通过另一个文件自动生成的,那自动生成的文件就没必要放进版本库,比如Java编译产生的
.class
文件; - 忽略你自己的带有敏感信息的配置文件,比如存放口令的配置文件。
状态命令
git status
查看自从我上次向Git存储库提交更改以来修改了哪些文件
红色的文件是未跟踪的文件
注意:
版本控制系统只能跟踪文本文件的改动
二进制文件没法跟踪文件的变化(只知道改变了大小,不知道具体改了什么)
把文件添加到版本库
把大象放到冰箱需要3步,把一个文件放到Git仓库只需要两步。
添加命令(文件内容到索引)添加到购物车
使用
git add
$ git add Fish.java
一次添加多个
git add --all
$ git add --all
添加完之后,可以再次执行git status
命令查看状态
提交命令(购物车统一结账)
git commit -m "第一次提交"
注:
-m
后面的是这一次的提交说明
提交记录查看
git log
查看完整提交记录git log -n
查看最近n次提交记录注:commit后面的一串字符是
commit id
版本号,SHA1计算
小结
初始化一个Git仓库,使用git init
命令。
添加文件到Git仓库,分两步:
- 第一步,使用命令
git add <file>
,注意,可反复多次使用,添加多个文件; - 第二步,使用命令
git commit
,完成。
查看提交记录:git log
以及git log -n
版本管理
版本回退
当前版本往上回退版本
git reset --hard HEAD^
往上回退n个版本
git reset --hard HEAD~n
回退到某一个版本:
git reset --hard commit id
如果回退之后后悔,想恢复到最新版本
通过
git reflog
查看每一次记录回退到指定的
commit id
小结
HEAD
指向的版本就是当前版本- 使用命令
git reset --hard HEAD^
回退一个版本 - 使用命令
git reset --hard HEAD~n
回退n个版本 - 使用命令
git reset --hard commit_id
。 - 要重返未来,用
git reflog
查看命令历史,以便确定要回到未来的哪个版本。
分支管理
每一个开发人员都有一个分支,通常还有div分支以及master分支
创建与删除分支
查看当前分支
git branch
$ git branch
* master
创建并切换分支
git checkout -b mary
$ git checkout -b mary
Switched to a new branch 'mary'
D Pet.java
这个相当于两个命令
git branch mary
创建mary分支git checkout mary
切换到mary分支删除分支
git branch -d mary
$ git branch -d mary
Deleted branch mary (was 9901b67).
合并分支
把mary开发的代码合并到master主分支上
master主分支执行
git merge mary
mary分支增加了Haha.java
没有冲突是Fast-forward快进模式
解决冲突
首先张三从zhangsan分支提交了对Pter.java的修改,修改内容如下
class Peter{
int a = 10;
}
并把修改合并到主分支
mary开发中也对Peter.java进行了修改,修改如下
class Peter{
String name = "mary";
}
想要把mary分支合并到主分支master,就会出问题
这里就会说明有冲突
代码中也会出现提示
HEAD代表当前分支版本,mary代表mary分支
解决方案就是修改冲突并再次提交
远程仓库github
GitHub是一个基于Web的Git仓库托管服务,在这里您可以免费创建一个共享的代码仓库。希望在GitHub上创建私有存储库的人或组织可以购买付费帐户。
http/ssh
第1步:创建SSH Key。
在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有
id_rsa
和id_rsa.pub
这两个文件。如果没有,执行下面命令,创建SSH Key:$ ssh-keygen -t rsa -C "youremail@example.com"
建议使用真实的邮箱地址
id_rsa
是私钥,id_rsa.pub
是公钥第2步:登陆GitHub,打开“settings”,“SSH Keys”页面:
然后,点“New SSH Key”,填上任意Title,在Key文本框里粘贴
id_rsa.pub
文件的内容:
创建远程仓库
首先,登陆GitHub,在右上角找到“newrepository”按钮,创建一个新的仓库
在Repository name填入f
irstgit
仓库名,其他保持默认设置
添加远程仓库
目前firstgit
仓库还是空的,我们可以从这个仓库克隆出新的仓库,也可以把本地仓库与之关联,然后把本地仓库的内容推送到GitHub仓库。
本地仓库关联远程仓库
git remote add origin SSH
$ git remote add origin git@github.com:zhangsan12/firstgit.git
推送到远程仓库
推送到远程仓库
git push -u origin 分支
$ git push -u origin master
把当前分支
master
推送到远程master
分支。-u
会把本地master
分支和远程master
分支关联起来下一次再提交的话就可以简便
$ git push origin master
推送分支
推送分支,就是把该分支上的所有本地提交推送到远程库。推送时,要指定本地分支,这样,Git就会把该分支推送到远程库对应的远程分支上:
$ git push origin master
如果要推送其他分支,比如dev
,就改成:
$ git push origin dev
SSH警告
第一次使用Git的clone
或者push
命令连接GitHub时,会得到一个警告:
The authenticity of host 'github.com (xx.xx.xx.xx)' can't be established.
RSA key fingerprint is xx.xx.xx.xx.xx.
Are you sure you want to continue connecting (yes/no)?
原因:需要你确认GitHub的Key的指纹信息是否真的来自GitHub的服务器,输入yes
回车即可。
小结
关联远程库:git remote add origin git@server-name:path/repo-name.git
第一次推送master分支:git push -u origin master
后面推送最新修改:git push origin master
从远程库克隆
- 项目找到
clone or download
按钮,选择地址
使用命令
git clone
克隆一个本地库多人协作开发,每个人从远程克隆一份即可。
克隆其他分支
- 查看远程分支
git branch -a
- 切换分支
git checkout 分支
- 查看远程分支
小结
要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone
命令克隆。
Git支持多种协议,包括https
,但通过ssh
支持的原生git
协议速度最快。
多人协作
- 查看远程库的信息
git remote
:
$ git remote
origin
抓取分支
多人协作时,大家都会往master
和dev
分支上推送各自的修改。
现在,模拟一个你的小伙伴,可以在另一台电脑(注意要把SSH Key添加到GitHub)或者同一台电脑的另一个目录下克隆:
其他小伙伴从远程库clone并且在
master
上继续修改,然后,时不时地把master
分支push
到远程:你的小伙伴已经向
origin/master
分支推送了他的提交,而碰巧你也对同样的文件作了修改,并试图推送:
- 推送失败,因为你的小伙伴的最新提交和你试图推送的提交有冲突,解决办法也很简单,Git已经提示我们,先用
git pull
把最新的提交从origin/master
抓下来,然后,在本地合并,解决冲突,再推送:
- 如果
git pull
失败,原因是没有指定本地master
分支与远程origin/master
分支的链接,根据提示,设置master
和origin/master
的链接:
再pull:
git pull
成功,但是合并有冲突,需要手动解决,解决的方法和分支管理中的解决冲突完全一样。解决后,提交,再push:
总结
多人协作的工作模式通常是这样:
- 首先用
git pull
拉取最新代码试图合并; - 如果合并有冲突,则解决冲突,并在本地提交;
- 解决掉冲突后,再用
git push origin branch-name
推送
如果git pull
提示“no tracking information”,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream-to=origin/branch-name branch-name
。
这就是多人协作的工作模式,一旦熟悉了,就非常简单。
小结
- 本地新建的分支如果不推送到远程,对其他人就是不可见的;
- 从本地推送分支,使用
git push origin branch-name
,如果推送失败,先用git pull
抓取远程的新提交; - 在本地创建和远程分支对应的分支,使用
git checkout -b branch-name origin/branch-name
,本地和远程分支的名称最好一致; - 建立本地分支和远程分支的关联,使用
git branch --set-upstream branch-name origin/branch-name
; - 从远程抓取分支,使用
git pull
,如果有冲突,要先处理冲突。
git补充
github上创建ops仓库;
2. 在132服务器的/home/wfq/github/目录下克隆刚创建的ops仓库;
执行如下命令
git clone git@github.com:CodingBruceWang/ops.git
1
3. 132本地克隆了ops后,将ops的所有代码从/home/wfq/ops目录拷贝到/home/wfq/github/ops目录下,进入到/home/wfq/ops目录,执行cp -R * ~/github/ops;
4. 拷贝后,进入到/home/wfq/github/ops目录
依次执行
a. git add *
b. git commit -m "all the codes of ops; first time to commit;"
c. git push origin
至此,github和132服务器本地代码同步
Git的使用和部署的更多相关文章
- jenkins+git+maven搭建自动化部署项目环境
简介 折腾了两个晚上,趁着今晚比较有空,把jenkins+git+maven搭建自动化部署项目环境搭建的过程记录一下,这里我把github作为git的远程仓库(https://github.co ...
- 搭建Git服务器环境----Git hooks代码自动部署
引言:自己想搭一套git的服务端环境,不想用github码云等.经多方资料整合,实验总结,以下是亲测有效的方式.可用于公司日常开发 一.搭建Git环境 ① 安装 Git Linux 做为服务器端系统, ...
- CentOS配置git和maven自动部署java
#安装Git yum install git #测试是否成功 git -version #正确 #git version 1.7.1 #配置git config --global user.name ...
- Git从零教你入门(4):Git服务之 gogs部署安装
Git从零入门系列4: 先看上一篇文章: http://www.51testing.com/index.php?uid-497177-action-viewspace-itemid-3706817 今 ...
- git管理和自动部署项目
当一个项目需要纳入到版本控制的时候,选择的工具还是比较多的,最常见的就是工具有CVS,SVN,GIT等.在平时的开发中视情况而定,从来就没有最好的版本控制工具,只有最适合的工具.在这里我习惯用git来 ...
- IDEA第二章----配置git、tomcat(热部署)、database,让你的项目跑起来
第一节:下载git客户端,整合idea 由于博主公司用的git版本管理,所以本系列都是基于git版本工具的,当然SVN与git配置类似.git同样支持安装版和解压版,支持各种操作系统,我这里下载的是W ...
- Git hook实现自动部署
Git Hook 是 Git 提供的一个钩子,能被特定的事件触发后调用.其实,更通俗的讲,当你设置了 Git Hook 后,只要你的远程仓库收到一次 push 之后,Git Hook 就能帮你执行一次 ...
- centos+git+gitolite 安装和部署
一.部署环境 系统:CentOS 6.4x64 最小化安装 IP:192.168.52.131 git默认使用SSH协议,在服务器上基本上不用怎么配置就能直接使用.但是如果面向团队服务,需要控制权限的 ...
- Jenkins+Git+Maven构建并部署war包到tomcat
主要思路:1.jenkins从git中拉取项目源码:jenkins使用maven构建并将生成的war部署到tomcat容器下. 环境:Centos7.Maven3.5.3.git(单机) 安装Git ...
- jenkins maven git windows code 自动部署
本人刚刚接触 写的不好就对付看看吧 哈哈哈O(∩_∩)O哈哈~ 最近看见别人弄得自动部署 自己也是手痒痒 也想弄一个 所以就弄了一个 windows的 我用的是https的 在网上看了很多都是 s ...
随机推荐
- Restframework中的Request
1.介绍 该篇博客主要介绍restframework内置的Request类,它扩展了Django中的Request类,实现了很多方便的功能--如请求数据解析和认证等. 如: 在APIView中封装的r ...
- Flask—06-理解掌握flask数据模型(02)
数据模型 模型关系 一对多(使用最多) 一:学生(Student) 需要添加反向引用 多:文章(Article) 需要添加外键关联 一对一 一:学生(Student),主表 需要添加反向引用,在一对多 ...
- LINUX日志的错误等级
LINUX日志的错误等级 - CSDN博客 https://blog.csdn.net/solmyr_biti/article/details/50634533讯息等级 系统将讯息分为七个主要的等级, ...
- 核心动画(UIView封装动画)-转
一.UIView动画(首尾) 1.简单说明 UIKit直接将动画集成到UIView类中,当内部的一些属性发生改变时,UIView将为这些改变提供动画支持. 执行动画所需要的工作由UIView类自动完成 ...
- 【PTA 天梯赛训练】六度空间(广搜)
“六度空间”理论又称作“六度分隔(Six Degrees of Separation)”理论.这个理论可以通俗地阐述为:“你和任何一个陌生人之间所间隔的人不会超过六个,也就是说,最多通过五个人你就能够 ...
- C/C++远程开机
// 2C:4D:54:ED:08:F0 #include <stdio.h> #include <Windows.h> #include <winsock.h> ...
- [tree]合并果子(哈夫曼树+优先队列)
现在有n堆果子,第i堆有ai个果子.现在要把这些果子合并成一堆,每次合并的代价是两堆果子的总果子数.求合并所有果子的最小代价. Input 第一行包含一个整数T(T<=50),表示数据组数. 每 ...
- mysql修改登录密码三种方式
一.用SET PASSWORD命令 首先登录MySQL,使用mysql自带的那个客户端连接上mysql. 格式:mysql> set password for 用户名@localhost = ...
- MySQL实现序列自增
#创建序列表 DROP TABLE IF EXISTS `sequence`; CREATE TABLE `sequence` ( `name` ) NOT NULL COMMENT '序列名称', ...
- (转)Windows安装和使用zookeeper
(转)原地址https://www.cnblogs.com/shanyou/p/3221990.html 之前整理过一篇文章<zookeeper 分布式锁服务>,本文介绍的 Zookeep ...