Bootstrap

[Git]-Linux下的git操作

目录

【git的概述】

1.分布式和集中式的区别

2.windows下的git下载方式

3.Linux下的git下载方式

【git的配置】

1.系统中所有用户都可以使用该配置

2.当前用户可使用该配置

3.当前项目可使用该配置

4.具体的配置

【git的操作】

1.git的基本操作

1.1初始化仓库

1.2查看文件、分支状态

1.3将文件提交到暂存区

1.4将暂存区文件提交到仓库

1.5查看commit日志

1.6比较本地文件和仓库区别

2.git的恢复操作

2.1从本地仓库恢复文件到工作区

2.2丢弃工作区的修改

2.3本地仓库文件的移动和删除

2.4回到本地仓库的上一个版本

2.5通过版本号恢复本地仓库

2.6查看修改了几次版本

3.标签管理(版本管理)

3.1什么是标签

3.2创建标签

3.3查看标签

3.4删除标签

3.5查看指定标签信息

3.6恢复到指定标签的位置

4.临时工作区

4.1临时工作区创建

4.2临时工作区查看

4.3使用指定的工作区

4.4使用最新的临时工作区并删除

4.5删除指定的临时工作区

4.6删除所有临时工作区

5.分支的操作

5.1查看当前分支

5.2创建一个分支

5.3切换工作分支

5.4.创建并切换到新的分支

5.5将指定的分支合并到当前分支

5.6删除指定分支

【远程仓库】

1.什么是远程仓库

2.创建远程仓库

3.远程仓库的删除

4.将本地仓库的文件推送到远程仓库

5.从远程仓库获取项目


【git的概述】

git是一个代码协同管理软件,主要用来完成多人协同开发的时候管理项目


1.分布式和集中式的区别

分布式:么一个节点都保存完成的代码,没有统一的中央服务器,节点与节点之间互相下载并推送代码,列如git

集中式:代码是集中管理,每次完成的代码上传到中央管理器,然后再从中央管理器下载代码使用,列如svn


2.windows下的git下载方式

Windows官网下载: Git - Downloads


3.Linux下的git下载方式

通过如下命令完成下载

sudo apt-get install git

如果出现无法获得锁和无法锁定管理目录的情况,重启直到可以安装 


【git的配置】

git的配置分为,所有用户、当前用户、当前项目

1.系统中所有用户都可以使用该配置

git config --system 配置信息
配置文件是:/etc/gitconfig

2.当前用户可使用该配置

git config --global配置信息
配置文件是:~/.gitconfig

3.当前项目可使用该配置

git config
配置文件是:当前项目下的 ./.git/config

4.具体的配置

用户名配置

git config --system user.name xxx
xxx为设置的用户名

 这里由于权限不够加了sudo

邮箱配置

git config --system user.email xxx
xxx为设置的邮箱

 

配置编辑器

git config core.editor vim
依赖项目

查看当前所有配置信息

git config --list

 


【git的操作】

git主要的就是通过把工作区的代码先添加到暂存区,然后再把暂存区的代码添加到本地仓库,本地仓库则可以通过远程仓库来上传或者下载代码


1.git的基本操作

1.1初始化仓库

首先创建一个文件夹,然后再进入该文件夹执行如下命令即可初始化仓库

git init

1.2查看文件、分支状态
git status

1.3将文件提交到暂存区
git add 文件名   
提交指定文件到暂存区


git add *        
提交所有文件到暂存区

1.4将暂存区文件提交到仓库
git commit -m 提交说明
提交说明可以很清晰的了解文件提交时候的更改

如果文件提交到了本地仓库之后,再在工作区对文件进行修改的话,可以通过get status来判断是把工作区的文件覆盖到本地仓库,还是通过本地仓库的文件恢复工作区的文件

1.5查看commit日志

通过查看commit日志,可以查看是谁,邮箱是什么,在什么时候往本地仓库添加了什么,通过如下命令查看

git log
查看所有commit日志

git log --pretty=oneline
查看单行日志

1.6比较本地文件和仓库区别
git diff 文件名

由于刚才往1.c文件添加了内容并没有上传到本地仓库,所以会有差异 


2.git的恢复操作

2.1从本地仓库恢复文件到工作区
git checkout 文件名

2.2丢弃工作区的修改
git checkout -- 文件名
丢弃工作区文件的修改,不会同步到本地仓库中
2.3本地仓库文件的移动和删除
git mv 源文件 目的目录
在本地仓库中将源文件移动目的目录中(本地也会移动)


git rm 文件名
在本地仓库中删除指定的文件(本地也会删除)

2.4回到本地仓库的上一个版本
git reset --hard HEAD^
^的个数决定回到上几个版本

2.5通过版本号恢复本地仓库
git reset --hard commit_id
commit_id就是提交后,通过git log 查看的长串数据前七位

2.6查看修改了几次版本
git reflog


3.标签管理(版本管理)

3.1什么是标签

在当前工作的位置添加快照,保存工作状态,一般用于版本的迭代

可以理解为给版本号取别名 

3.2创建标签
git tag 标签名称
创建标签,默认是使用最新的版本号设置

git tag 标签名称 -m 提示信息
创建标签并设置提示信息

git tag 标签名称 commit_id
指定某一个commitID设置标签

3.3查看标签
git tag
查看当前标签

git show 标签
查看标签代表信息

3.4删除标签
git tag -d 标签名称

3.5查看指定标签信息
git show 标签
查看指定标签代表信息

3.6恢复到指定标签的位置
git reset --hard 标签名称

4.临时工作区

如果想要实现一个功能,但是现在有三种实现方法,为了确定哪个实现的方法更好,于是可以通过创建临时的工作区来分别判断,需要的留下,不需要删除

个人理解为,把当前工作区复制若干份,分别操作,筛选。修改本地文件后创建临时工作区,配套使用,可以把修改保存到临时工作区

4.1临时工作区创建
git stash

4.2临时工作区查看
git stash list

  

4.3使用指定的工作区
git stash apply stash@{编号}

4.4使用最新的临时工作区并删除
git stash pop

4.5删除指定的临时工作区
git stash drop stash@{编号}

4.6删除所有临时工作区
git stash clear

5.分支的操作

怎么理解分支,分支中权限最大的是maser,相当于决策每一个分节点上传上来的代码的可否。如果说一个大型的项目开发是一个分支,那么每个组长就是主分支延伸出去的分支,组长在往下就是组员的分支,每个人负责自己的任务

5.1查看当前分支
git branch

 5.2创建一个分支
git checkout
5.3切换工作分支
git checkout <分支名称>

5.4.创建并切换到新的分支
git checkout -b <分支名称>

5.5将指定的分支合并到当前分支
git merge <分支名称>

5.6删除指定分支
git branch -d <分支名称>


【远程仓库】

1.什么是远程仓库

另一台主机上面的仓库,可以被其他主机访问

2.创建远程仓库

远程仓库的创建步骤如下:

1.创建文件夹

2.设置文件夹属主(默认即可)

3.进入文件夹,设置为共享仓库

        git init --bare <项目名称> ,项目名称一般以.git结尾

4.设置本地仓库的属主(默认即可)

5.在本地仓库添加远程仓库

        git remote add 仓库名称 用户名@IP地址:共享仓库的绝对路径

        仓库名称可以使用任何名字,且必须在某个仓库下执行才可以建立和远程仓库的连接

3.远程仓库的删除

git remote rm 仓库名称

4.将本地仓库的文件推送到远程仓库

git push -u 远程仓库名称 要推送的分支
-u选项第一次添加才需要,后续不用

5.从远程仓库获取项目

创建一个03git文件夹,从远程仓库中获取项目

git clone 用户名@IP地址:共享仓库绝对路径
后续获取只需git pull

 

 

;