一、版本控制系统
1、简介
version control system 简称VCS 版本控制系统是一种记录一个或多个文件的内容变化,以便将来查阅特定版本的内容变化情况的系统。
简单来说::就是用来保存内容更变记录的系统,可以将文件回退到过去某个时间点的状态。
2、作用
- 查阅文件的修改记录,如:修改者、修改时间、修改的文件内容等。
- 对比不同版本中文件的变化细节
- 将文件回溯到之前的某个状态
3、种类
版本控制系统的种类:
- 本地版本控制系统
版本库存放在本地磁盘上
缺点:无法协同开发 - 集中化版本控制系统
版本库集中存放在中央服务器上,所有参与人员都连接该服务器,实现协同开发
缺点:自己电脑上没有版本库,本地无法进行版本管理,必须连接中央服务器才能进行版本控制,如果中央服务器宕机,则无法工作
代表应用:Subversion (SVN) - 分布式版本控制系统
每个人的电脑上都是一个完整的版本库,在本地就可以进行版本管理,无需连网。
但一般都会通过远程仓库来交换版本的修改
代表应用:Git
二、Git简介
1、Git是什么
Git 是一个开源的分布式版本控制系统,用来进行项目版本管理
其实就是一个软件,有一组命令组成,能够对项目代码进行版本控制
基本流程:
- 使用git命令将远程仓库上的文件克隆到本地仓库中
- 从本地仓库中检出文件到工作区(一般都自动完成)
- 将新创建的文件添加到暂存区
- 将暂存区中的内容提交到本地仓库中
- 将本地仓库中的内容推送到远程仓库上
2、安装Git
windows系统需要手动安装Git软件,LInux和Mac OS系统都自带Git
我使用的pycharm,自带有Git
工具:
- Git命令行工具:
从cmd中输入 git –version 可以查看
Git自带 Git Bash 点击进入输入 git –version 可以查看 - Git图形化客户端 Git Gui
3、初始化
对Git进行初始化配置
定义当前系统git 的使用者名称和邮箱,提交代码时显示的名字和邮箱
git config –global user.name “liuzhishan”
git config –global user.email “123456@163.com”
三、Git使用
1、常见命令
命令 | 作用 | 备注 |
---|---|---|
git init | 初始化本地Git仓库(项目) | 会在当前目录中创建一个 .git 目录,用于记录所有的版本变更信息 |
git status | 查看本地仓储的文件状态 | |
git add 文件路径 | 将文件添加到列表(暂存区),交由git托管 | -A或–all 或 . 表示添加所有文件,也可以使用* 进行匹配 |
git commit | 将跟踪列表(暂存区)中的文件提交到本地仓库 | -m 指定提交日志 |
git log | 查看提交日志 | |
git reset –hard 版本id | 回退到指定版本 | HEAD表示当前的版本 |
git reflog | 查看所有操作记录 | 包括被回退的版本id、reset操作等 |
ls | 查看文件 | 隐藏文件用 ls -a 查看所有文件,.git就是一个隐藏文件 |
cd | 进入文件内 | |
具体看Git常见命令 |
注意:所有的命令都必须在Git仓库的根目录下执行(.git同级路径)
2、文件状态
- untracked
未跟踪,表示文件不受git管理,一般新建的文件处于该状态
Untracked files - staged
已暂存,表示已对修改的文件做了标记,使之包含在下次要提交的文件跟踪列表中
Change to be committed - committed
已提交,表示文件已经被提交到本地仓库 - modified
已修改,表示文件内容已被修改,但没有做标记
Change not staged for commit
3、忽略文件
可以在git仓库的根目录下添加一个名为 .gitignore的文件,用于指定需要被git忽略的文件或文件夹
注意:
- 文件名必须是 .gitignore
- 文件必须在项目的根目录下
- 每行指定一个忽略文件
- 以 # 开头的行 表示注释
touch .gitignore #创建一个.gitignore文件
vim .gitignore #编辑一下这个文件
点击Esc键 输入 :wq退出
.gitignore文件中输入忽略的文件
之后查看文件便不显示了
四、远程仓库
1、简介
基于GIt的代码托管平台,常用的Git远程仓库:
- GitHub https://github.com
- 码云 https://gitee.com
2、操作
步骤:
1、注册账号、创建仓库
2、添加远程仓库的地址
例如:
git remote add origin https://gitee.com/mrliu987/project-name-1.git
3、将本地仓库的提交记录推送到远程的master分支
git push origin master
4、拉取远端master分支的更新记录到本地
git pull origin master
命令 | 作用 | 备注 |
---|---|---|
git remote add 仓库别名 远程仓库地址 | 添加远程仓库地址 | 仓库别名可以自定义,一般默认使用origin(起源的意思) |
git remote -v | 查看远程仓库信息 | fetch抓取、push推送 |
git remote rm-名称(也就是别名) | 删除远程仓库地址 | |
git push 名称 分支 | 将本地仓库指定分支推送到远程仓库 | 一般为master主分支,默认为推送到远程仓库的同名分支,没有则新建 |
git pull 名称 分支 | 拉取远程仓库指定分支中新的数据到本地 | 会与本地仓库进行merge合并(更新操作,非第一次) |
git clone 远程仓库地址 | 克隆远程仓库的项目到本地 | 用于从远程仓库下载git项目(第一次 ) |
git clone 和git pull 区别:
- clone是没有本地仓库时,将远端的整个项目下载过来
- pull是有本地仓库时,将远程仓库里的新的数据更新过来,并且与本地代码进行merge合并操作
5、冲突问题
本地仓库和远程仓库文件或者文件里内容冲突时,先pull 拉取远程仓库文件,然后修改完,在git add . 添加。在去git push
五、分支Branch
1、简介
分支就是版本上的更新迭代,默认只有master主分支
可以从主分支上分离出其他的分支,各分支间互不干扰
2、操作
命令 | 作用 | 备注 |
---|---|---|
git branch | 显示所有分支 | 默认只有master分支 |
git branch 分支名 | 创建分支 | |
git checkout 分支名 | 切换分支 |
六、静态页面托管
1、简介
码云提供了免费的静态网页托管服务,可以托管个人的静态网页,称为码云Pages
两种方式:
- 方式一、带二级目录
- 方式二、不带二级目录
2、操作
方式一:带二级目录,步骤:
1、创建一个仓库,仓库名称自定义
2、将本地的静态资源推送到远程仓库
必须提供 index.html页面,默认访问的就是该页面
3、选择pages服务
服务 —Gitee Pages ——选择部署分支master
4、访问生成的网站地址
第三步完了之后会生成一个地址
方法二:不带二级目录
– 创建一个与个人空间地址同名的仓库,默认为与码云账号相同
– 通过网站网址直接进入
七、在pycharm中使用Git
1、操作
步骤:
1、配置Git
Setting —— Version Control —— Git——指定git命令的执行路径——点击Test
2、检出项目
VCS——Checkout from Version Control ——GIt——指定远程仓库的URL和本地存放目录——点击Clone
3、提交/推送项目
VCS——Commit——Commit and Push——输入远程仓库的账号和密码
VCS——Git——Push
4、解决冲突
当本地提交的内容和远程仓库的内容有冲突时需要手动解决,进行合并merge
2、颜色提示
当将项目文件clone下来时,状态栏中文件的颜色代表意思
红色:未加入版本控制 untracked
绿色: 已加入控制,未提交staged
白色: 已加入控制,已提交,无改动 committed
蓝色: 已加入控制,已提交,有改动modified
灰色:版本控制已忽略文件
绿色、白色、蓝色状态是已经属于git管理,不需要git add ,. 添加了
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/61400.html