集中式版本控制工具
1.版本库放在中央服务器,团队里面的每个人工作的时候都要从中央服务器下载代码
2.必须联网才能进行工作
3.个人修改后,提交到中央版本库
举例:SVN和CVS
分布式版本控制工具
1.分布式版本控制系统没有中央服务器,每个人的电脑上都是一个完整的版本库。
2.工作的时候,不需要联网。因为版本库就在你自己的电脑上。
3.多人协作只需要把各自的修改推送给对方,就能互相看到对方的修改了
举例:Git
Git工作流程图
data:image/s3,"s3://crabby-images/21e3f/21e3f11c15673d1e1a03243fb7f82e7f5a65ba5e" alt="在这里插入图片描述"
Git配置
1.Git GUI:Git提供的图形界面工具
2.Git Bash:Git提供的命令行工具
基本配置
1.打开Git Bash
2.设置用户信息
data:image/s3,"s3://crabby-images/1a2ef/1a2efe3d041ca04a2aed21b308cc472bc1a81071" alt="在这里插入图片描述"
3.查看配置信息
data:image/s3,"s3://crabby-images/e9594/e95941d4810575455842788b8179575b8fbff33e" alt="在这里插入图片描述"
4.为常用指令配置别名
有些常用的指令参数非常多,每次都要输入好多参数,我们可以使用别名 4.1.打开用户目录,创建.bashrc文件 data:image/s3,"s3://crabby-images/98d96/98d96e02d41cf4354722759242354eb8e905fab5" alt="在这里插入图片描述" 4.2.在.bashrc文件下输入如下内容
#用于输出git提交日志
alias git-log='git log --pretty=oneline --all --graph --abbrev-commit'
#用于输出当前目录所有文件及基本信息
alias ll='ls -al'
4.3.解决中文乱码问题
4.3.1 打开GitBash执行下面命令
git config --global core.quoteepath false
4.3.2 在Git安装目录下 /etc/bash.bashrc文件最后加入下面两行(我的Git安装在D盘)
export LANG="zh_CN.UTF-8"
export LC_ALL="zh_CN.UTF-8"
获取本地仓库
要使用Git对代码进行版本控制,首先要获得本地仓库
1.新建一个空目录作为本地git仓库
2.进入目录点击Git Bash
3.执行git init
4.创建成功后可以看到隐藏的.git目录
data:image/s3,"s3://crabby-images/c9edf/c9edf85dc253274fe535aa7f6fb7cdade96d0327" alt="在这里插入图片描述"
git常用指令
data:image/s3,"s3://crabby-images/f528b/f528bf2ca8432254c1f1a0f32164950dae16bc3c" alt="在这里插入图片描述"
1.查看修改的状态(工作区、暂存区)
git status
2.添加工作区到暂存区
git add 单个文件名|通配符(.)
git add .
3.提交暂存区到本地仓库
git commit -m "注释内容"
4.查看提交日志
data:image/s3,"s3://crabby-images/e8f5a/e8f5a18cac37a365fe0fbf70dc028a533e974e6b" alt="在这里插入图片描述"
5.版本回退(撤销)
data:image/s3,"s3://crabby-images/f21be/f21be0a2d997fa8c6b205330f0e2166f9234ddac" alt="在这里插入图片描述"
查看日志 git log
以精简的方式显示提交记录(已经配好别名的情况下) git-log
添加文件名至忽略列表
data:image/s3,"s3://crabby-images/e6796/e679612798fb1f855d5d378c3b5bd78f7d9a745a" alt="在这里插入图片描述"
touch .gitignore
分支
几乎所有的版本控制系统都以某种形式支持分支。使用分支意味着你可以把你的工作从开发主线上分离开来进行重大的BUG修改。开发新的功能,以免影响开发主线 data:image/s3,"s3://crabby-images/76b16/76b16fe9718c45c861a607d66d89a32a2738e09c" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/ee37c/ee37c99cafae5bb0b2589e510261cf92fde21100" alt="在这里插入图片描述" 查看分支,使用git-log较为方便 data:image/s3,"s3://crabby-images/4be3a/4be3a0811dad781389ee98aaeed619b878da014a" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/ed7d2/ed7d20815f78e69b50bb756f7cff2417bd4d23e4" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d0e84/d0e8466b41cebb3a528d6d0682b4b07a116e3995" alt="在这里插入图片描述" 不是同一文件同一行的,git会自动合并分支 data:image/s3,"s3://crabby-images/34dff/34dff6188322cb41c145cfd51f8813ef85b9fbfb" alt="在这里插入图片描述"
Git远程仓库
1.常用的(代码托管服务)远程仓库
data:image/s3,"s3://crabby-images/d4230/d42300b0e84782ed4b0849a5d61090826e150054" alt="在这里插入图片描述"
2.在码云上搭建私服
2.1创建仓库
data:image/s3,"s3://crabby-images/35396/3539647b733ca12661e34f897be06709ffb4f4e9" alt="在这里插入图片描述"
2.2 配置SSH公钥
1.生成SSH公钥
ssh-keygen -t -rsa
之后不断回车,如果公钥已经存在,则自动覆盖
2.Gitee设置账号共公钥
获取公钥
cat ~/.ssh/id_rsa.pub
data:image/s3,"s3://crabby-images/c87e4/c87e47224dbdd4748fd9c01864cd7cde7608beb2" alt="在这里插入图片描述" 将公钥粘贴在gitee上边 data:image/s3,"s3://crabby-images/0d134/0d13474e7f9ad95cf523fa124274370aa3d3c838" alt="在这里插入图片描述" 3.验证是否配置成功
ssh -t git@gitee.com
4.操作远程仓库
1.连接远程仓库 git remote add origin 远程仓库ssh地址 //origin为远程仓库别名 data:image/s3,"s3://crabby-images/520a6/520a65edb183f09fabdf58748af7648a7e4e3d20" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/57033/57033c2d04470d277f15befcc7cda8a7893cf928" alt="在这里插入图片描述" 2.将本地代码同步到远程仓库
git push [-f] [--set-upstream] [远端名称[本地分支名][:远端分支名]]
git push origin master:master
//-f为强制覆盖
//--set-upstream 推送到远端的同时建立起和远端的关联关系
git push origin --set-upstream 0master:master
data:image/s3,"s3://crabby-images/402c0/402c0c840a62db79c3e0cda8b4ae4657baeaf6d9" alt="在这里插入图片描述" 5.从远程仓库克隆
如果有一个远端仓库,可以直接克隆到本地
git clone <仓库路径> [本地目录]
//本地目录可以省略,会自动生成一个目录
6.从远程仓库抓取和拉取
抓取:就是将仓库里面的更新都抓取到本地,不会进行合并 拉取:将远程仓库里面的修改拉到本地并自动进行合并,等同于fetch+merge
//抓取
git fetch [remote name] [branch name]
//拉取
git pull [remote name] [branch name]
7.解决冲突 A先将文件push到远程仓库,为了避免冲突 B要先在本地git pull,修改冲突的地方之后提交到本地仓库再push到远程仓库
|