亚洲必赢手机入口新手向–git版本控制器。Git 版本控制。

by admin on 2018年10月5日

 

Git 版本控制

Git 版本控制器

(本文档由XDL讲师黄超,使用MarkDown构建而成为,转载请注明出处)

1.Git底装 和 基本配置

1.什么是Git

当今世界最先进/最好用之分布式版本控制系统,没有有

1.1 安装

Linux安装

仲向前制包(在线)
yum -y install git //RedHat系列
apt-get git install //Debian系列
源码包(官网下载)

Windows安装

Git在Windows使用模拟条件msysgit
下载地址:
https://git-for-windows.github.io/
专注:如果想叫windows作为git服务器则需搭建ssh服务。


2.哟是版本控制系统?

版本控制 — <<维基百科>>

版本控制是如出一辙种植软件工程技术,能当软件开发的历程中,确保由不同人所编纂的同一代码文件案都得同步.
版本控制能而项目之设计者,将品种恢复至事先任意的状态,这种选择权于设计过程中特地重要.
辩驳及装有的信息记录还好增长版本控制:利用版本控制来追踪、维护源码、文件与配置文件等等的改变


1.2 配置

无论Linux还是Windows,安装好后都如初始化

git config [--global] user.name "Your Name"
git config [--global] user.email "your@email.com"

中括号内的参数:
    --local 本地
    --system 系统
    --global 全局
    无参,则为当前库配置身份

3.版本控制发展史

2. Git常用操作

3.1 文件称艺术

既往底软件开发过程,代码管理为手动和邮件等形式,文件命名暨保存有问题

使图 : 毕业论文版本
亚洲必赢手机入口 1

2.1. 生改为新的版本库

  1. 亚洲必赢手机入口新建空目录
  2. 跻身该目录—单击右键—选择Git Bash Here
  3. 弹出git的命令行工具
  4. 初始化该目录为本仓库,键入 git init
  5. 显示 Initialized empty Git repository in xxxxxx
  6. ls -a 查看该目录下发出现.git的隐蔽目录,即版本库
  7. 初始化完成
3.2 集中式

席卷仓库以及工作区两组成部分:工作区编码,再上传至库的艺术成就差不多人口搭档。
问题:工作机与库机需要联网才会说了算版本,传输速度较慢。
亚洲必赢手机入口 2

2.2.添加文书及版本库

  1. 新建文件 1.txt

  2. 翻看时版状态

     git status     #查看当前版本状态
    
  3. 红字提示有文件不跟(未在版本控制)

  4. 在工具外输入以下,添加文书及本本库:

     git add 1.txt
     # 添加文件至缓存区
     git commit -m "描述"
     # 提交文件至版本库
    
     git add newfile1 newfile2 ...
     # 多文件添加
     git commit -m "描述"
     # 将缓存区的多次添加一次提交
    
     ps:
     git add .
     # 添加所有改动过的文件到缓存区
     git add --all
     # 添加所有文件到缓存区
    
  5. 履行完毕后,提示提交完成.

  6. git status 提示
    nothing to commit, working directory clean

  7. 时至今日最简单易行的增长文件及版本库已成功


3.2 分布式

各级台微机都发出工作区和储藏室自己主宰版本,数据进一步安全,有逻辑上的中坚。
亚洲必赢手机入口 3


2.3.查文件修改状态相关

git status
# 查看当前版本状态(是否修改)

修改文件测试为下 :

git diff            # 工作区 与 缓存区的区别
git diff --cached   # 缓存区 与 版本库的区别
git diff HEAD       # 工作区 与 版本库的区别

Git日志,分析日志构成 :

git log
# 查看提交历史
git log --oneline
# 以简短的方式查看提交日志

4.广泛版本控制系统

图 : 版本管理器的发展史

亚洲必赢手机入口 4

即张图上分为了季个秋 :

● 史前时:1982年之RCS。现在而可能还会当Unix的宣布包中找到她。


古典时期:1990年底CVS自身弱点已经过时;1985年的PVCS、1992年之clearcase(费用贵、功能复杂沿用至今);微软VVS反人类;Perforace(广泛,谷歌内部尽深代码管理器)


中世纪时:SVN解决了CVS的题材,集中式领域上。AccuRev(支持分支合并为不少局拜托cvs和clearcase)。


文艺复兴:BitKeeper(SUN公司大量运),2002年Linux内核使用BitKeeper,2005年闭源时有人试图破解BitKeeper,于是应运而生了Git。

2.4. 本回退

git reset --hard HEAD
# 将当前版本重置为HEAD(通常用于清空缓存区,或merge失败回退)

git reset --hard HEAD^   # 回退上一个版本
git reset --hard HEAD^^  # 回退上两个版本
git reset --hard HEAD~n  # 回退上n个版本

git reset --hard <commitid>
# 回退到指定版本,commitid根据log获取

Git问世

Git的首先只版本是Linux之父Linus
Torvalds亲手操刀设计及促成之(两宏观内为此C写了),Linus不仅仅被起一个原来设计,并于朝世人介绍Git时肯定批评了CVS和SVN等,Git消除了分段和集合的恐怖。很多大型开源项目由SVN迁移至Git。

2008年www.github.com也成为世界最为特别之SCM系统(软件配置管理),它应用的即使是Git版本库的技术.从此Git成为版本控制系统的主流。

GitHub上的著名项目 :
Linux内核、安卓、jQuery、Bootstrap、Ruby …


2.5. 表现日志

git reflog
# 行为日志,显示所有提交,回滚等..
git ls-files
# 显示缓存区的所有文件

5.Git底装 和 基本配置

2.6. 撤销

目的:将没有提交到本库的改动撤回。

  • 场面亦然 : 文件修改后没加加至缓存区

git checkout --filename
# 在工作区撤销文件的修改
  • 情况二 : 文件修改都补偿加至缓存区

git checkout HEAD [filename]
# 撤回添加至缓存区的修改,不指定filename则撤回所有

5.1 安装

Linux安装

其次前进制包(在线)
yum -y install git //RedHat系列
apt-get git install //Debian系列
源码包(官网下载)

Windows安装

Git在Windows使用模拟条件msysgit
下载地址:
https://git-for-windows.github.io/
只顾:如果想为windows作为git服务器则需要搭建ssh服务。


遵照学科使用windows版本来做示范:

设置步骤:

1.增选安装路径
亚洲必赢手机入口 5
2.挑选创建图标,选择设置Git Bash和Git GUI
亚洲必赢手机入口 6

3.抉择创建开始菜单
亚洲必赢手机入口 7
4.摘取:use git and optional unix tools from the windows command
prompt(红字提示)
亚洲必赢手机入口 8

5.选择: windows-style
亚洲必赢手机入口 9
6.选择 : use mintty 默认终端
亚洲必赢手机入口 10

7.选择 : 系统文件缓存 和 git的管理器(需要.net v4.5.1)
亚洲必赢手机入口 11
8.点击 Install 安装
亚洲必赢手机入口 12
9.安完成,选择运行git bash工具


2.7. 删除

git rm index.php
# 删除index.php文件
git rm --cached index.php
# 将index.php文件移出缓存区,但不删除( -r * 递归目录)
git rm -f 1.html
# 将缓存区中的1.html文件移出并删除

5.2 配置

无论Linux还是Windows,安装到位后还设初始化

git config [--global] user.name "Your Name"
git config [--global] user.email "your@email.com"

 

中括号内的参数:

 --local 本地
    --system 系统
    --global 全局
    无参,则为当前库配置身份

 

3. Git基本上口搭档

6. Git常用操作

3.1. 得远程的版本库

可行使简单种植艺术来获取远程版本库:

  • 在有指定的文件夹下采取,即可获得远端版本库及代码

git clone <远端版本库url> <本地存放该库的文件夹名>
  • 手动添加版本库,并拉取文件

git init
#初始化本地仓库

git remote add <remote> <url>
# 添加远程版本库 <remote>可自行取名,默认origin

git remote -v
# 查看远程版本库信息
git remote show <remote>
# 查看指定远程版本库信息

git remote remove <remote>
# 删除远程remote链接

git pull <remote> <branch>
# 下载代码及快速合并

6.1. 生成新的版本库

  1. 新建空目录
  2. 上该目录—单击右键—选择Git Bash Here
  3. 弹出git的命令行工具
  4. 初始化该目录为本仓库,键入 git init
  5. 显示 Initialized empty Git repository in xxxxxx
  6. ls -a 查看该目录下有现.git的隐形目录,即版本库
  7. 初始化完成

3.2. 推送分支代码

获远端版本库后,可以于地头本正常的手续编辑 :
新建或转移文件–>添加至缓存区–>提交到版本库

此刻,要惦记以本地版本库发给远端,只有commit提交是不够的.
还索要下面的操作 :

git push <remote> <branch>
# 上传代码及快速合并

行以上代码,会生出回报错 : 无法直接推送至远端的主分支

此刻,可以曲线救国,推送自己之分支到远端即可 :

git push origin master:dev

这儿,推送成功!


6.2.添加文件及版本库

  1. 新建文件 1.txt

  2. 查看时版状态

    git status     #查看当前版本状态
    

     

  3. 红字提示有文件未跟(未入版本控制)

  4. 每当工具外输入以下,添加文件及本本库:

    git add 1.txt
    # 添加文件至缓存区
    git commit -m "描述"
    # 提交文件至版本库
    
    git add newfile1 newfile2 ...
    # 多文件添加
    git commit -m "描述"
    # 将缓存区的多次添加一次提交
    
    ps:
    git add .
    # 添加所有改动过的文件到缓存区
    git add --all
    # 添加所有文件到缓存区
    

     

  5. 推行了晚,提示提交完成.

  6. git status 提示

    nothing to commit, working directory clean
    

     

  7. 至今最简易的增长文件及版本库已到位


4.Git分支管理

— PS部分: Git 实现原理 —

  1. 做事区 : 就是程序员日常编写代码的文书夹
  2. 本子库 : 负责代码版本控制,就是.git隐藏目录
  3. 版本库原理图 :

亚洲必赢手机入口 13

版本库包括:暂存区(index/stage),HEAD(指针),分支(默认为master主分支)等。

文本提交至版本库总共分点儿步:

1).git add filename # 添加至stage缓存区
2).git commit -m "描述" # 将stage的内容提交至版本库的master分支

 

实验:
修改文件->查看状态->
累加到缓存区->查看状态->
再也修改->提交->查看状态

查看区别:
1). 修改文件->查看状态 :
显示红字,文件没有在缓存区(工作区修改,还无付诸至缓存区)
2). 添加到缓存区git add . -> 查看状态 : 显示绿字,已提交到缓存区
3). 继续修改文件->git commit -m "第1次修改 1.txt" ->
再次翻开状态 : 显示红字:文件发出改变未加入到版本库

4).
这次提交,只是提交了add到缓存区之内容,第二不行修改的情节并没add到缓存区,所以版本库与工作区文件不一致.
5). 此时亟需以手上底文件add到缓存区,再次提交即可

4.1. 翻版本库分支

git branch
# 显示本地分支
git branch -a
# 显示所有分支
git checkout 分支名/标签名
# 切换到指定分支或标签

— PS.部分了 —


4.2. 开立分支/删除分支

git branch 分支名
# 新建分支
git checkout -b dev
# 创建并切换到dev分支

git branch -d 分支名
# 删除本地分支 -D 强制删除

6.3.查文件修改状态相关

git status
# 查看当前版本状态(是否修改)

 

修改文件测试为下 :

git diff
# 查看所有添加到缓存区的变更(工作区与版本库的区别)
git diff index.php
# 查看工作区文件和库文件区别
git diff --cached
# 查看所有已添加到缓存区,但还未commit的变更(缓存区与版本库的区别)

 

Git日志,分析日志构成 :

git log
# 查看提交历史
git log --oneline
# 以简短的方式查看提交日志

 


4.3. 集合分支

假使以B分支合并及A分支里
请切换到A分支内,合并B分支的操作以A分支内进行

git merge 分支名
# 合并分支到当前分支 

6.4. 版本回退

git reset --hard HEAD
# 将当前版本重置为HEAD(通常用于清空缓存区,或merge失败回退)

git reset --hard HEAD^   # 回退上一个版本
git reset --hard HEAD^^  # 回退上两个版本
git reset --hard HEAD~n  # 回退上n个版本

git reset --hard <commitid>
# 回退到指定版本,commitid根据log获取

 


4.4. 解决统一冲突

基本上支修改同一文件,合并或者出现冲。冲突有据此<<<===>>>表示

化解办法:
先行手动修改冲突有,再次提交即可。


6.5. 表现日志

git reflog
# 行为日志,显示所有提交,回滚等..
git ls-files
# 显示缓存区的所有文件

 


5. 用到代码托管体系

市面上赫赫有名的Git托管系统 :

  • GitHub
    https://github.com/
  • 开源中国
    https://git.oschina.net/

6.6. 撤销

目的:将无提交至本库的改动撤回。

  • 景况亦然 : 文件修改后没加加到缓存区

    git checkout --filename
    # 在工作区撤销文件的修改
    

     

  • 场面二 : 文件修改就添加到缓存区

    git checkout HEAD [filename]
    # 撤回添加至缓存区的修改,不指定filename则撤回所有
    

     


5.1. 开源中国 生成SSH密钥

1). 本地打开git bash ,cd切换至用户之下目录
2). 使用pwd来查阅目录是否是
3). 使用 ssh-keygen.exe -t rsa 来生成SHA256之SSH密钥(按回车确认即可)
4). cd .ssh/ 切换至ssh目录
5). ls 查看目录下文件
6). cat id_rsa.pub 查看转的密钥,并复制

7). 打开git@osc开源中国,登录自己的账户.点选个人资料
8). 选择SSH公钥
9).
在丰富公钥界面,将刚刚复制好之密钥粘贴进来,再好得一个拖欠密钥的讳,以便为分别管理

10). 本地新建一个目,用于拉取远端版本库
11). 使用 git init初始化该目录
12). 使用git remote add origin <SSH地址> 来添加远程版本库

13). 使用git remote -v 来查看远程版本库信息
14). 使用git pull origin marster来拉取版本库及代码

6.7. 删除

git rm index.php
# 删除index.php文件
git rm --cached index.php
# 将index.php文件移出缓存区,但不删除( -r * 递归目录)
git rm -f 1.html
# 将缓存区中的1.html文件移出并删除

 


5.2. github 添加SSH key

1). 运行 git Bash 客户端,输入如下代码:
$ cd ~/.ssh
$ ls
立马半单指令就是反省是否曾在 id_rsa.pub 或 id_dsa.pub
文件,如果文件都是,那么你得超越了步骤2,直接进步骤3

2). 创建一个 SSH key
$ ssh-keygen -t rsa -C "your_email@example.com"
代码参数含义:
-t 指定密钥类型,默认是 rsa ,可以概括。
-C 设置注释文字,比如邮箱。
-f 指定密钥文件存储文件称。

3). 添加你的 SSH key 到 github上面去
$ cat ~/.ssh/id_rsa.pub

4). 测试一下拖欠SSH key 在git Bash 中输入以下代码
$ ssh -T git@github.com
著类似如下,表示成功:
Hi username! You've successfully authenticated

5). git clone 远程git仓库地址


7. Git几近总人口搭档

6. 文件忽略

工作区某些文件未控制版本,可使用.gitignore文件进行忽略.
!(注意, .gitignore文件 是没有名字的文件.)
规则:
坐斜杠“/”开头表示目录;
以星号“*”通配多单字符;
因为问号“?”通配单个字符
因方括号“[]”包含单个字符的匹配列表;
以叹号“!”表示不忽视(跟踪)匹配到之文书或者目录;

布局文件是按行从上到下进行平整匹配的,意味着如果前的平整匹配的范围重新怪,则后面的条条框框以不见面生效.

7.1. 到手远程的版本库

好利用有限栽艺术来抱远程版本库:

  • 在某个指定的文件夹下用,即可获远端版本库及代码

    git clone <远端版本库url> <本地存放该库的文件夹名>
    

     

  • 手动添加版本库,并拉取文件

    git init
    #初始化本地仓库
    
    git remote add <remote> <url>
    # 添加远程版本库 <remote>可自行取名,默认origin
    
    git remote -v
    # 查看远程版本库信息
    git remote show <remote>
    # 查看指定远程版本库信息
    
    git pull <remote> <branch>
    # 下载代码及快速合并
    

     


7.2. 推送分支代码

获远端版本库后,可以在本地本常规的步调编辑 :
新建或改动文件–>添加交缓存区–>提交到版本库

此刻,要想拿地方版本库发给远端,只有commit提交是不够的.
尚亟需下面的操作 :

git push <remote> <branch>
# 上传代码及快速合并

 

执行以上代码,会发出回报错 : 无法直接推送到远端的主分支

此时,可以曲线救国,推送自己的道岔到远端即可 :

git push origin master:dev

 

这儿,推送成功!


8.Git分支管理

8.1. 翻看版本库分支

git branch
# 显示本地分支
git branch -a
# 显示所有分支
git checkout 分支名/标签名
# 切换到指定分支或标签

 

8.2. 开立分支/删除分支

git branch 分支名
# 新建分支
git checkout -b dev
# 创建并切换到dev分支

git branch -d 分支名
# 删除本地分支 -D 强制删除

 

8.3. 统一分支

要是用B分支合并及A分支里
呼吁切换至A分支内,合并B分支的操作以A分支内进行

git merge 分支名
# 合并分支到当前分支 

 

8.4. 化解统一冲突

多支修改同一文件,合并或者出现冲。冲突有用<<<===>>>表示

亚洲必赢手机入口 14

化解方法:
优先手动修改冲突有,再次提交即可。


8.5. 岔管理策略

亚洲必赢手机入口 15


9. 采取代码托管体系

市面上知名的Git托管系统 :

  • GitHub https://github.com/
  • 开源中国 https://git.oschina.net/

以下为开源中国也例,来读书使用

9.1. 地方生成SSH密钥

1). 本地打开git bash
,cd切换到用户的下目录
2). 使用pwd来查阅目录是否是
3). 使用 ssh-keygen.exe -t rsa
来生成SHA256底SSH密钥(按回车确认即可)
4). cd .ssh/
切换至ssh目录
5). ls 查看目录下文件
6). cat id_rsa.pub
查看转的密钥,并复制

7). 打开git@osc开源中国,登录自己的账户.点选个人资料
8). 选择SSH公钥
9).
在累加公钥界面,将刚复制好的密钥粘贴进来,再好得到一个欠密钥的名字,以便为分别管理

10). 本地新建一个索引,用于拉取远端版本库
11). 使用
git init初始化该目录
12). 使用git remote add origin <SSH地址>
来添加远程版本库

13). 使用git remote -v
来查看远程版本库信息
14). 使用git pull origin marster来拉取版本库及代码


Git常用命令速查

  • master 默认主分支
  • dev 默认开发分支

创立版本库

git init
# 初始化本地git版本库(创建新仓库)

git config --global user.name "xxx"
# 配置用户名

git config --global user.email "xxx@xxx.com"
# 配置邮件

git config --list
#查看当前配置列表

git clone <url>
# clone远程仓库

 

修改、提交、删除

git add index.php
# 添加index.php文件到缓存区
git add .
# 添加所有改动过的文件到缓存区
git add --all
# 添加所有文件到缓存区

git commit
# 提交缓存区内的文件(回车后需要键入描述:wq保存退出)
git commit -m "描述"
# 提交缓存区内的文件,并提供描述

git commit -am '描述'
# 将add和commit合为一步
git commit --amend -m 'xxx'
# 合并最后一次提交(用于反复修改)

git rm index.php
# 删除index.php文件
git rm --cached index.php
# 将index.php文件移出缓存区,但不删除( -r * 递归目录)
git rm -f 1.html
# 将缓存区中的1.html文件移出并删除

 

查看

git status
# 查看当前版本状态(是否修改)

git diff
# 查看所有添加到缓存区的变更(工作区与版本库的区别)
git diff index.php
# 查看工作区文件和库文件区别
git diff --cached
# 查看所有已添加到缓存区,但还未commit的变更(缓存区与版本库的区别)

git log
# 查看提交历史
git log --oneline
# 以简短的方式查看提交日志

git reflog
# 行为日志,显示所有提交,回滚等..
git ls-files
# 显示缓存区的所有文件

 

回退 与 撤销

git reset --hard HEAD
# 将当前版本重置为HEAD(通常用于merge失败回退)

git reset --hard HEAD^   # 回退上一个版本
git reset --hard HEAD^^  # 回退上两个版本
git reset --hard HEAD~n  # 回退上n个版本

git reset --hard <commitid>
# 回退指定版本,commitid根据log获取

git checkout --filename
# 在工作区撤销文件的修改
git checkout HEAD [filename]
# 撤回添加至缓存区的修改,不指定filename则撤回所有

 

分层操作

git pull origin master
# 获取远程分支master并merge到当前分支

git branch
# 显示本地分支
git branch -a
# 显示所有分支
git checkout 分支名/标签名
# 切换到指定分支或标签

git branch 分支名
# 新建分支
git branch -d 分支名
# 删除本地分支 -D 强制删除

 

长距离协作

git remote add <remote> <url>
# 添加远程版本库
git remote -v
# 查看远程版本库信息
git remote show <remote>
# 查看指定远程版本库信息
git remote remove <name>
# 删除远程remote链接
git remote rename <old> <new>
# 重命名远程链接名

git pull <remote> <branch>
# 下载代码及快速合并

git push <remote> <branch>
# 上传代码及快速合并

git merge origin master
# 将本地的远端库合并

git fetch origin
# 将远端库获取本地但不合并

 

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图