Git 版本控制

码林棱镜
• 阅读 2664

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/](https://git-for-windows.github.io/)  
注意:如果想让windows作为git服务器则需要搭建ssh服务。

1.2 配置
无论Linux还是Windows,安装完成后都要初始化
git config [--global] user.name "Your Name"
git config [--global] user.email "your@email.com"

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

2. Git常用操作

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

  1. 至此最简单的添加文件到版本库已完成

2.3.查看文件修改状态相关
git status
# 查看当前版本状态(是否修改)

修改文件测试以下 :

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

Git日志,分析日志构成 :

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

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获取

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

2.6. 撤销
目的:将尚未提交至版本库的修改撤回。
  • 情况一 : 文件修改后尚未添加至缓存区
git checkout --filename
# 在工作区撤销文件的修改
  • 情况二 : 文件修改已添加至缓存区
git checkout HEAD [filename]
# 撤回添加至缓存区的修改,不指定filename则撤回所有

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

3. 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>
# 下载代码及快速合并

3.2. 推送分支代码

得到远端版本库后,可以在本地按正常的步骤编辑 :
新建或改动文件-->添加至缓存区-->提交到版本库

此时,要想将本地版本库发给远端,只有commit提交是不够的.
还需要下面的操作 :

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

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

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

git push origin master:dev

此时,推送成功!


4.Git分支管理

4.1. 查看版本库分支
git branch
# 显示本地分支
git branch -a
# 显示所有分支
git checkout 分支名/标签名
# 切换到指定分支或标签
4.2. 创建分支/删除分支
git branch 分支名
# 新建分支
git checkout -b dev
# 创建并切换到dev分支

git branch -d 分支名
# 删除本地分支 -D 强制删除
4.3. 合并分支

要将B分支合并到A分支里
请切换到A分支内,合并B分支的操作在A分支内进行

git merge 分支名
# 合并分支到当前分支 
4.4. 解决合并冲突
多分支修改同一文件,合并可能出现冲突。冲突部分用<<<===>>>表示

解决方法:
先手动修改冲突部分,再次提交即可。


5. 使用代码托管系统

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

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来拉取版本库及代码

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仓库地址


6. 文件忽略

工作区某些文件不控制版本,可使用.gitignore文件进行忽略.
!(注意, .gitignore文件 是没有名字的文件.)
规则:

以斜杠“/”开头表示目录;
以星号“*”通配多个字符;
以问号“?”通配单个字符
以方括号“[]”包含单个字符的匹配列表;
以叹号“!”表示不忽略(跟踪)匹配到的文件或目录;

  配置文件是按行从上到下进行规则匹配的,意味着如果前面的规则匹配的范围更大,则后面的规则将不会生效.

点赞
收藏
评论区
推荐文章
Wesley13 Wesley13
3年前
vscode安装go所有插件(全网最全)
1.vscode安装go所有插件vscode版本:1.51.0go版本:versiongo1.15.2windows/amd64git客户端版本:Git2.29.2.264bit2.使用vscode自动安装1.需要提前安装go、vscode、git客户端,配置git环境,配置go环境,GOPATH这个环境
Stella981 Stella981
3年前
Git基础考试题
Git:1.在windows上搭建git环境,成功后查看版本号Linux安装sudoaptgetinstallgityyuminstallgitywindows直接安装exe查看版本号:gitversion2.git与svn的区别(1)git是分布式的,svn是集中式的(2)git把内容按元数据的方式
Wesley13 Wesley13
3年前
11月14日任务
一、安装Git  \如果你已经安装好了Git,可以忽略这一步  CentOS安装Git:yuminstallgit  查看Git版本信息:gitversion  配置Git用户信息:gitconfigglobaluser.name"woider"gitconfigglob
Stella981 Stella981
3年前
Linux上安装git并在gitlab上建立对应的项目
1.CentOS上面安装git我所用的CentOS为CentOS6.5,其他版本没有测试。yuminstallgit 安装之后查看git版本信息gitversion2.配置git信息gitconfigglobaluser.name"yourname"gitconfigglobaluser.em
Stella981 Stella981
3年前
Git 安装 on centos7
本文演示如何在CentOS7上安装和使用git。1准备工作1.1浏览器访问安装包下载地址:https://www.kernel.org/pub/software/scm/git/找到下载列表中需要安装的版本,以2.17.0版本为例,地址为:https://www.kernel.org
Stella981 Stella981
3年前
Git的初始化配置和基本命令的使用
首先说下什么是Git,很多人会把Git和GitHub搞混淆。Git是一个版本控制的工具;GitHub是一个网站,只不过是基于Git的。安装Git就不累述了,自行百度。这里主要说下,初次运行Git的配置和Git基本命令的使用。初次运行Git的配置(windows系统):打开Git命令行输入以下命令:gitconfigglobaluser.
Stella981 Stella981
3年前
IntelliJ IDEA(八) :git的使用
项目管理离不开版本控制,目前主流版本控制工具大概就是SVN和Git,至于两者有啥区别这里就不详细介绍了,如果有不明白的可以上网查资料,后期如果有机会我再开篇栏目细说,而且现在市场上Git的使用率已经远远高于SVN。我们在用IDEA开发项目的时候如何熟练使用Git来控制代码版本呢?一、安装Git使用Git当然需要先安装Git,安装过程就
Stella981 Stella981
3年前
GitLab 安装配置指南
GitLab在CentOS7系统上的安装配置指南1、简单介绍GitLab是利用RubyonRails开发的一个开源版本管理系统,实现一个自托管的Git管理仓库,可通过Web界面进行访问、管理控制权限。Git的家族成员介绍Git:是一种开源分布式的版本控制系统,是一个命令,是一种工具。是伟大的程
Wesley13 Wesley13
3年前
ubuntu14.10server搭建git服务器成功记录
安装配置git1.安装git和openssh。在当前用户下执行如下命令安装git和openssh:sudoaptgetinstallgitcoreopensshserveropensshclientgitcore是git版本控制核心软件安装opensshserve
Stella981 Stella981
3年前
Git和GitHub的基本操作
GIT版本控制系统版本控制系统功能:1.记录版本历史信息(记录每一次修改的记录)2.方便团队之间相互协作开发3.远程开发......常用的版本控制系统cvs/svn:集中式分布系统git:分布式版本控制系统1.GIT工作原
小万哥 小万哥
2年前
Git安装和配置教程:Windows/Mac/Linux三平台详细图文教程,带你一次性搞定Git环境
Git是一款免费、开源的分布式版本控制系统,广泛应用于软件开发领域。随着开源和云计算的发展,Git已经成为了开发者必备的工具之一。本文将为大家介绍Git在Windows、Mac和Linux三个平台上的安装和配置方法,带你一次性搞定Git环境Windows平