Git学习笔记_1
来自B站狂神说以及尚硅谷,仅作学习笔记,供后续查阅
B站狂神说
尚硅谷
版本控制
一种在开发的过程中用于管理我们对文件、目录或工程等内容的修改历史,方便查看更改历史记录,备份以便恢复以前的版本的软件工程技术。
- 实现跨区域多人协同开发
- 追踪和记载一个或者多个文件的历史记录
- 组织和保护源代码和文档
- 统计工作量
- 并行开发、提高开发效率
- 跟踪记录整个软件的开发过程
- 减轻开发人员的负担,节省时间,同时降低人为错误
版本控制分类
1.本地版本控制
记录文件每次的更新,可以对每个版本做一个快照,或是记录补丁文件,适合个人用,如RCS
2.集中版本控制 SVN
所有的版本数据都保存在服务器上,协同开发者从服务器上同步更新或上传自己的修改
缺点:用户本地只有自己以前所同步的版本,不联网,用户看不到历史版本,也无法切换版本验证问题,或在不同分支工作。所有数据都保存在单一的服务器上,有很大的风险服务器损坏,如SVN,CVS,VSS
3.分布式版本控制 Git
所有版本信息仓库全部同步到本地的每个用户
4.Git与SVN的主要区别
常用Linux命令
Git基本理论
工作目录
暂存区
资源库
远程的Git仓库
工作流程
1.载工作目录中添加、修改文件
2.将需要进行版本管理的文件放入暂存区域
3.将暂存区域文件提交到git仓库
git管理文件的三种状态
已修改(modified)
已暂存(staged)
已提交(committed)
文件的四种状态
忽略文件
常用命令汇总
git config --system --list#查看系统config
git config --global --list#查看当前用户(global)配置
git config -l #查看配置
#设置用户名与邮箱
git config --global user.name "名称"
git config --global user.email 邮箱
#本地仓库搭建
#1.创建全新仓库
git init #在当前目录新建一个Git代码库,在项目目录多出了一个.git目录
#2.克隆远程仓库
get clone [url]#克隆一个项目和它的整个代码历史(版本信息)
例:
git clone https://gitee.com/kuangstudy/kuang_livenote.git
#查看文件状态
#查看指定文件的状态
git status [filename]
例:
$ git status hello.txt
On branch master
No commits yet
Untracked files:
(use "git add <file>..." to include in what will be committed)
hello.txt
nothing added to commit but untracked files present (use "git add" to track)
#查看所有文件状态
git status
例:
$ git status
On branch master
No commits yet
Untracked files:
(use "git add <file>..." to include in what will be committed)
git_notes/
hello.txt
nothing added to commit but untracked files present (use "git add" to track)
#添加所有文件到暂存区
git add .
#提交暂存区中的内容到本地仓库 -m 提交信息
git commit -m "消息内容"
例:
git commit -m "new file hello.txt"
#忽略文件
*.txt #忽略所有.txt结尾的文件
!lib.txt #但lib.txt除外
/temp #仅忽略项目根目录下的TODO文件,不包括其他目录temp
build/ #忽略build/目录下的所有文件
doc/*.txt #忽略doc/notes.txt但不包括doc/server/arch.txt
#生成公钥
ssh-keygen
#git分支中的常用指令
#列出所有本地分支
git branch
#列出所有远程分支
git branch -r
#新建一个分支,但依然停留在当前分支
git branch [branch-name]
#新建一个分支,并切换到该分支
git checkout -b [branch]
#合并指定分支到当前分支
git merge [branch]
#删除分支
git branch -d [branch-name]
#删除远程分支
git push origin --delete [branch-name]
git branch -dr [remote/branch]
#其他指令
git push
git pull
git reset
get checkout
#linux相关
cd :cd [要进入的下一级文件夹] 改变目录
cd ..:回退到上一个目录,直接cd进入默认目录
pwd:显示当前所在的目录路径
ls:列出当前目录中的所有文件,ll列出更详细的内容
touch [文件名.后缀] :在当前目录下新建一个文件
rm : rm [文件名.后缀] 把文件删除
mkdir :mkdir [文件夹名] 新建一个目录,新建一个文件夹
rm -r 文件夹名 :删除一个文件夹
rm -r src :删除src目录
mv [要移动文件名.后缀] src :移动文件到目标文件夹,必须保证文件和目标文件夹在同一个目录下
reset:重新初始化终端/清屏
clear:清屏
history:查看命令历史
help:帮助
exit:退出
#表示注释
mkdir :mkdir [文件夹名] 新建一个目录,新建一个文件夹
rm -r 文件夹名 :删除一个文件夹
rm -r src :删除src目录
mv [要移动文件名.后缀] src :移动文件到目标文件夹,必须保证文件和目标文件夹在同一个目录下
reset:重新初始化终端/清屏
clear:清屏
history:查看命令历史
help:帮助
exit:退出
#表示注释