SVN--基本原理与使用(超详细)

目录

  • 一、SVN概述
  • 二、SVN服务端软件安装
  • 三、SVN服务端配置
  • 四、SVN客户端软件安装与使用
  • 五、SVN三大指令
  • 六、SVN图标集与忽略功能
    • 6.1 图标集
    • 6.2 忽略功能
  • 七、SVN版本回退
  • 八、SVN版本冲突
  • 九、SVN配置多仓库与权限控制
    • 9.1 配置多仓库
    • 9.2 权限控制
  • 十、服务配置与管理
  • 十一、模拟真实开发环境
  • 十二、SVN客户端开启分支

一、SVN概述

1.为什么需要SVN版本控制软件
在这里插入图片描述
  我们想开发一个系统,需要张三,李四、王五三个人进行开发,每个人开发一个系统的某几个模块,我们称作协作开发。他们开发之间进行交流称作远程开发。 最后合并成几个版本,如v1.0 、v2.0。这时候就需要SVN来进行版本管理,主要是三个功能:版本回退,协作开发,远程开发。

2.解决之道
  SCM:(Software configuration management)软件配置管理,所谓的软件配置管理实际就是对软件源代码进行控制与管理
CVS:元老级产品
VSS:入门级产品
ClearCase:IBM公司提供技术支持
SVN:主流产品

3.什么是SVN
  SVN的全程SubVersion
  SVN是近年来崛起的版本管理工具,是CVS的接班人。目前,绝大多数都使用SVN作为代码版本管理软件

  特点:操作简单,入门容易
  支持跨平台操作(window、linux,MacOS)
  支持版本回退功能

4.获取SVN软件
  属于C/S结构软件(客户端与服务器端)
服务端软件:VisualSVN
网址:http://www.visualsvn.com/
客户端软件:TortoiseSVN
网址:http://tortoisesvn.net/downloads

二、SVN服务端软件安装

1、SVN工作流程
在这里插入图片描述
2、服务器端软件安装(VisualSVN)
  服务端软件存储于软件/服务器端
在这里插入图片描述
1)双击服务端软件安装
在这里插入图片描述
2)下一步,继续
在这里插入图片描述
3)下一步,继续

在这里插入图片描述
4)下一步,继续
在这里插入图片描述
Location:软件的安装位置,注意不要出现中文、空格或特殊字符。
Repositories:默认版本仓库位置,自己选择。
Server Port:端口号,443 或者 8443 都可以。
Backups:备份文件保存路径。

在这里插入图片描述
不打钩,点击Next进入下一步:

5)下一步,继续,安全完成

三、SVN服务端配置

1、创建一个项目
① 首先在SVN服务器端创建一个公有目录WebApp做为项目目录
② 在WebApp目录下创建Shop文件夹,做为Shop(版本仓库)

在这里插入图片描述
③ 创建版本仓库,DOS(Disk Operating System,磁盘操作系统)环境基本语法:
  svnadmin create Shop 文件夹路径(Shop仓库)
  如果Shop仓库配置成功,那么Shop文件夹会显示以下目录结构
在这里插入图片描述
  如果Shop仓库配置成功,那么Shop文件夹会显示以下目录结构
在这里插入图片描述
2、进行服务端监管
  Apache-> http://localhost或(ip地址)访问到htdocs目录下的相关文件(监管)
  SVN-> svn://localhost或(ip地址)访问到相关数据仓库(如Shop仓库)
基本语法:
svnserve -d(后台运行) -r(监管目录) 版本仓库路径

svnserve -d -r E:/SVN/WebApp/Shop

如下图所示:
在这里插入图片描述
通过以上指令,我们的svn://localhost或ip地址就可以直接指向Shop版本仓库
3、权限控制
默认情况下,SVN服务器是不允许匿名用户上传文件到服务器端的,所以必须更改系统相关配置文件
在这里插入图片描述
在这里插入图片描述
更改箭头指向的代码,去除前面的空格以及#号,更改其值为write(可读写)

四、SVN客户端软件安装与使用

1、获取软件安装包

2、确认操作系统位数
32位操作系统
64位操作系统
  如何确认操作系统位数呢?可以在计算机图标上鼠标右键->属性
  通过以上分析可知,我们需要安装64位客户端软件。
3、客户端软件安装步骤
① 双击软件运行(TortoiseSVN)
在这里插入图片描述
② 同意许可协议,下一步:
在这里插入图片描述

③ 选择默认安装即可,下一步:
在这里插入图片描述
④ 下一步,Install,系统将会自动安装SVN软件,单击Finish即可。
注:在TortoiseSVN客户端软件安装完毕后,请一定要重启计算机,否则SVN图标是无法显示的
  如果我们鼠标右键出现如下两个图标,代表我们已经安装成功!
在这里插入图片描述
⑤ 安装汉化包
  双击运行安装语言包,系统将会自动寻找之前TortoiseSVN软件安装目录,并进行自动安装,安装完成后可以进行如下设置:
在这里插入图片描述
⑥ 使用客户端软件连接SVN服务器(Checkout检出)
  首先在你的项目目录鼠标右键->TortoiseSVN->版本库浏览器->输出SVN服务器地址:
在这里插入图片描述
  svn://SVN服务器地址-> Shop项目(仓库)
在这里插入图片描述
  显示隐藏文件

在这里插入图片描述
  如果出现以上.svn隐藏文件夹,代表检出成功。

五、SVN三大指令

SVN中的svn add相当于git中的 git add操作
SVN中的svn checkout相当于git中的 git clone操作
SVN中的svn commit相当于git中的 git commit操作
SVN中的svn update相当于git中的 git pull操作 其中git pull相当于git fetch+git merge
git中还有push操作,表示将本地数据推送到远程仓库。可以类似相当于 svn的commit+update
1、回顾SVN三大指令
1)(Checkout)检出操作:① 链接到SVN服务器端 ② 更新服务端数据到本地
注意:Checkout只在第一次链接时操作一次,以后如果进行更新操作请使用Update(更新指令)
2)(Commit)提交操作:① 提交本地数据到服务器端
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
  以上工作大部分是由管理员完成的,那么如果新来一个程序员(李四),他需要做哪些操作呢?
3)检出操作,效果如下:
在这里插入图片描述
4)Commit(提交),效果如下:

在这里插入图片描述
  以上指令通常是在模块开发完毕后上传
5)项目经理(Update更新操作)
在这里插入图片描述
单击SVN更新操作即可

六、SVN图标集与忽略功能

6.1 图标集

1)常规图标

在这里插入图片描述
含义:当客户端文件与服务器端文件完全同步时,系统会显示以上图标
2)冲突图标

在这里插入图片描述
含义:当客户端提交的文件与服务器端数据有冲突,系统会显示以上图标
3)删除图标
在这里插入图片描述

含义:当服务端数据已删除,那么客户端该文件将显示以上图标
4)增加图标
在这里插入图片描述

含义:当我们编写文档已添加到提交队列,那么系统将自动显示以上图标
5)无版本控制图标
在这里插入图片描述
含义:当我们编写的文件没有添加到上传队列,系统将自动显示以上图标
6)修改图标
在这里插入图片描述
含义:当客户端文件有修改但未提交,此时将自动显示以上图标

7)只读图标
在这里插入图片描述
含义:当客户端文件以只读形式存在时,将自动显示以上图标

8)锁定图标
在这里插入图片描述
含义:当服务端数据已锁定,那么客户端文件将自动显示以上图标

9)忽略图标

在这里插入图片描述
含义:客户端文件已忽略,不需要进行提交上传,那么将自动显示以上图标

6.2 忽略功能

有些文件不希望上传至svn服务器,应该将该文件或该类型的文件添加至忽略列表
1)忽略某个指定的文件
在这里插入图片描述
其中UML表示忽略当前文件,UML(recurisely)表示忽略递归的子目录

2)忽略某类型文件
在这里插入图片描述
其中*表示通配符,包含所有.xlsx的文件都将被忽略

七、SVN版本回退

1、什么是版本回退
有些时候,软件的运行可能使开发者或使用者不满意,这时我们需要把当前版本退回到以前的某个版本。
在这里插入图片描述
2、版本回退功能
① 在项目空白处鼠标右键,采用如下图所示操作

在这里插入图片描述
  选择更新版本至

  然后再根据日志进行版本回退

在这里插入图片描述
  根据日志信息选择要回退的状态,效果如下图所示

在这里插入图片描述
版本回退之后发现,之前删除的文件就被恢复出来了

八、SVN版本冲突

1、什么是版本冲突
在实际项目开发中,如果两个人同时修改某个文件就会产生版本冲突问题。
2、模拟版本冲突
在这里插入图片描述
  模拟以上过程,出现如下错误提示:
在这里插入图片描述
3、解决之道
1)合理分配项目开发时间
旺财 上午开发
小强 下午开发

2)合理分配项目开发模块
旺财 购物车模块
小强 文章模块

3)通过SVN解决版本冲突问题
① 更新服务器端数据到本地

在这里插入图片描述
index.php :整合后的index.php文件
index.php.mine :小强修改后的index.php文件
index.php.r3 :09:00更新时的index.php(起始状态)
index.php.r4 :旺财修改后的index.php文件

② 删除除index.php以外的其他三个文件
③ 修改整合index.php冲突文件
④ 重新提交数据到SVN服务器端,即可解决版本冲突问题

九、SVN配置多仓库与权限控制

在开发过程中,通常一个项目就是一个仓库

9.1 配置多仓库

  在实际项目开发中,我们可能会同时开发多个项目,那么我们如何进行多项目监管呢?
  通过svnserve进行仓库监管,但是监管指令只能监管某一个文件夹,而不能同时监管多个仓库。
  答:可以通过监管WebApp总目录来达到监管所有仓库的目的
svnserve -d(后台运行) -r(监管目录) WebApp(项目总目录)
① 打开DOS窗口,输入如下指令

svnserve -d -r E:SVN/WebApp

svn://localhost或ip地址来访问D:/svn/WebApp目录
如果需要访问Shop项目、Wechat项目
Shop项目:svn://localhost/Shop
Wechat项目:svn://localhost/Wechat

9.2 权限控制

  如果要使用权限控制有一个前提:必须首先开启权限功能
  在每一个仓库中都有一个conf文件夹,里面有三个文件
authz文件:授权文件
告诉哪些用户具有哪些权限
passwd文件:认证文件
标识当前svn系统中某个仓库具有哪些用户以及相应的密码
默认情况下,以上两个文件都是禁用的,如需要使用,首先要开启以上两个文件
svnserve.conf 配置文件
开启步骤如下:
① 注释匿名用户的可读写权限,修改文件svnserve.conf
在这里插入图片描述
② 开启认证文件与授权文件,修改文件svnserve.conf
在这里插入图片描述
③ 编写认证文件定义相关用户名与密码,修改passwd文件
在这里插入图片描述
④ 编写授权文件,修改authz文件
在这里插入图片描述
在这里插入图片描述
⑤ 测试
在commit中进行提交,提交之后就会出现以下情况
在这里插入图片描述
输入admin,admin888超级管理员,即可完成提交

十、服务配置与管理

1、配置自启动服务
sc create SVNService binpath= “D:\subversion\bin\svnserve.exe --service -r D:/svnroot” start= auto
sc create 服务名称 binpath=空格”svnserve.exe –service –r D:/svn/WebApp” start=空格auto
创建系统服务,服务名SVNService
① 打开运行,输入cmd指令,打开DOS环境(请使用超级管理员运行:搜索输入命令提示符,单击右键选择以管理员身份运行)
② 输入一下指令
在这里插入图片描述

③ 查看系统服务
控制面板->管理工具->服务 (在Window11中的位置在控制面版->Window 工具->服务)
在这里插入图片描述
双击运行,启动SVNService服务
在这里插入图片描述
  如果运行成功代表开启SVN监管服务。

2、创建批处理文件
启动服务 net start 服务名称
停止服务 net stop 服务名称
删除服务 sc delete 服务名称
在这里插入图片描述

以上功能在实际项目开发中经常使用,所以可以封装为.bat批处理文件,效果如下:
在这里插入图片描述

十一、模拟真实开发环境

1、SVN工作流程
在这里插入图片描述

2、钩子程序
所谓钩子就是与一些版本库事件触发的程序,例如新修订版本的创建,或是未版本化属性的修改。
默认情况下,钩子的子目录(版本仓库/hooks/)中包含各种版本库钩子模板。
在这里插入图片描述post-commit.tmpl :事务完成后所触发的钩子程序
钩子程序默认情况可以采用批处理指令或Shell指令来进行编写

3、通过批处理指令编写钩子程序
① 指令svn服务端工作目录
设置服务器端SVN路径
SET SVN=“E:\SVN\yingyongruanjian\bin\svn.exe”
② 指定Web服务器工作目录
设置服务器端项目运行目录
SET DIR=“E:\SVN\apache\shop”
③ 通过update指令实时更新数据到DIR目录中
SVN update %DIR%
④、具体使用步骤
第一步:复制post-commit.tmpl为post-commit.bat文件
第二步:填入相关批处理指令
在这里插入图片描述
第三步:在apache目录创建Shop项目并更新SVN服务端数据到本地
第四步:更新文件到SVN服务器端,可以在Shop目录实时获取到最新数据
第五步:可以通过虚拟主机形式直接访问更新文件

十二、SVN客户端开启分支

BAE地址: http://bce.baidu.com/

1.首先关联仓库, 右键 — 点击 ’ SVN Checkout…’
在这里插入图片描述
2.在项目上点击右键,在TortoiseSVN菜单中选择Branch/Tag;

3.在To path输入框中输入新建分支的路径,一般是:/branches/分支名,也就是相当于分支保存的路径名;
4.在下面选择HEAD revision in the repository,为当前SVN中trunk目录下最新的代码建立分支,如果需要为制定的revision建立分支,可以进行选择
5.点击OK分支建立完成

在这里插入图片描述
6.打开branches目录,发现目录依然为空,没有刚才建立的分支,这是因为分支建立的操作是在服务器端完成的,当需要编辑分支时,在branches目录点击Update,刚才建立的分支就会下载下来。

分支创建成功后,远程仓库可以查看到分支目录,本地仓库(branches)中不生成新的目录,需要 Update 下来

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/5565.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux 第十七章

🐶博主主页:ᰔᩚ. 一怀明月ꦿ ❤️‍🔥专栏系列:线性代数,C初学者入门训练,题解C,C的使用文章,「初学」C,linux 🔥座右铭:“不要等到什么都没有了…

刷机维修进阶教程-----VIVO机型 修复基带 更改参数 实例步骤操作解析

写到前面: 任何参数修改和刷写分区都有风险。严重会导致无基带 无信号等故障。操作前都需要谨慎,养成备份关键数据分区的习惯。以便出现问题可以恢复。不管是修复基带分区还是更改相关参数,在操作前都有可以恢复原分区数据与刷机救砖的能力在操作。今天以vivo机型来做演示。…

bun 换源 国内阿里源 npmmirror 加速下载

Github https://github.com/oven-sh/bun 版本号 bun 1.1.5 windows 安装 bun 如果本机有 nodejs 环境, 可以 npm install -g bun 安装 ( 官方把 exe 已经传到了 npm 仓库, 走的国内 npm 镜像, 下载速度会很快) 没有 nodejs, 可以用 powershell 脚本安装 具体操作 全局 …

力扣刷题 63.不同路径 II

题干 一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish”)。 现在考虑网格中有障碍物。那么从左上角到…

Pytorch GPU版本安装

一、背景 记录一下安装Pytorch GPU版本过程。 由于手残,卸载了电脑上的显卡驱动,现在我连显卡类型是啥都不知道了。 总体思路:安装显卡驱动->安装cuda->安装pytorch库 二、安装显卡驱动 2.1 查看本地显卡型号 通过「DirectX 诊断工具…

Leetcode 145:二叉树的后序遍历(迭代法)

给你一棵二叉树的根节点 root ,返回其节点值的 后序遍历 。 思路: 迭代法的思路是,使用栈,一层一层的将树节点遍历入栈。 比如下面这个树,使用迭代法,1)第一层,让根节点入栈。2&a…

顺序表??

1.引入:首先需要了解数据结构的作用:是计算机存储、组织数据的方式。就比如之前学的数组,就是一种基础的数据结构。通过数组,就可以去维护很多个同类型的数据,实现增加删除等的功能,这样就可以有效管理这些…

嵌入式学习63-C++

知识零碎: newmalloc friend 友元函数 …

微搭低代码入门01微搭底层能力介绍

目录 1 什么是应用2 有服务器和无服务器3 关系型数据库和文档型数据库4 云存储5 云函数6 静态网站托管总结 日常经常解答初学者的问题,问的最多的就是学习微搭,需要多久,要不要学习代码。有的初学者心比较急躁,总是希望一蹴而就&a…

边循环边删除List中的数据

List边循环,边删除;这种一听感觉就像是会出问题一样,其实只要是删除特定数据,就不会出问题,你如果直接循环删除所有数据,那可能就会出问题了,比如: public static void main(String[…

一些优雅的监控运维技巧

准备工作 安装 sysstat sudo apt install sysstat查看某个进程的cpu情况 pidstst -u -p 256432查看某个进程的RAM情况 pidstst -r -p 256432查看某个进程的IO情况 pidstst -d -p 256432查看某个进程下的线程执行情况 pidstst -t -p 256432查看指定PID的进程对应的可执行文件…

C++协程库封装

操作系统&#xff1a;ubuntu20.04LTS 头文件&#xff1a;<ucontext.h> 什么是协程 协程可以看作轻量级线程&#xff0c;相比于线程&#xff0c;协程的调度完全由用户控制。可以理解为程序员可以暂停执行或恢复执行的函数。将每个线程看作是一个子程序&#xff0c;或者…

OpenCV如何实现背投(58)

返回:OpenCV系列文章目录&#xff08;持续更新中......&#xff09; 上一篇&#xff1a;OpenCV直方图比较(57) 下一篇&#xff1a;OpenCV如何模板匹配(59) 目标 在本教程中&#xff0c;您将学习&#xff1a; 什么是背投以及它为什么有用如何使用 OpenCV 函数 cv::calcBackP…

蓝桥杯国赛填空题(弹珠堆放)

小蓝有 20230610 颗磁力弹珠&#xff0c;他对金字塔形状尤其感兴趣&#xff0c;如下图所示&#xff1a; 高度为 1 的金字塔需要 1 颗弹珠&#xff1b; 高度为 2 的金字塔需要 4 颗弹珠&#xff1b; 高度为 3 的金字塔需要 10 颗弹珠&#xff1b; 高度为 4 的金字塔需…

Python 语音识别系列-实战学习-语音识别特征提取

Python 语音识别系列-实战学习-语音识别特征提取 前言1.预加重、分帧和加窗2.提取特征3.可视化特征4.总结 前言 语音识别特征提取是语音处理中的一个重要环节&#xff0c;其主要任务是将连续的时域语音信号转换为连续的特征向量&#xff0c;以便于后续的语音识别和语音处理任务…

qt嵌入并控制外部程序

一、流程 1、调用Window接口模拟鼠标&#xff0c;键盘事件 POINT point; LPPOINT lpppoint &point; GetCursorPos(lpppoint);//获取鼠标位置 SetCursorPos(point.x, point.y);//设置鼠标位置//鼠标左键按下 mouse_event(MOUSEEVENTF_LEFTDOWN | MOUSEEVENTF_LEFTUP, poi…

逻辑漏洞:初识水平越权与垂直越权

目录 1、什么是越权漏洞呢&#xff1f; 2、水平越权 3、垂直越权 4、burpsuite autorize插件 最近在学习逻辑漏洞的相关知识和技能&#xff0c;这里pikachu靶场作为演示进行学习一下&#xff1a; pikachu靶场&#xff1a;GitHub - zhuifengshaonianhanlu/pikachu: 一个好玩…

计算机服务器中了devicdata勒索病毒怎么办?Devicdata勒索病毒解密工具步骤

在这个网络飞速发展的时代&#xff0c;网络为企业的生产运营起到了关键性作用&#xff0c;利用网络可以开展各项工作业务&#xff0c;大大提高了企业生产效率与业务水平&#xff0c;在大家都为网络的便利感到欣慰时&#xff0c;网络数据安全问题&#xff0c;成为众多企业关心的…

模型智能体开发之metagpt-多智能体实践

参考&#xff1a; metagpt环境配置参考模型智能体开发之metagpt-单智能体实践 需求分析 之前有过单智能体的测试case&#xff0c;但是现实生活场景是很复杂的&#xff0c;所以单智能体远远不能满足我们的诉求&#xff0c;所以仍然还需要了解多智能体的实现。通过多个role对动…

02 spring-boot+mybatis+elementui 的登录,文件上传,增删改查的入门级项目

前言 主要是来自于 朋友的需求 项目概况 就是一个 学生信息的增删改查 然后 具体到业务这边 使用 mybatis xml 来配置的增删改查 后端这边 springboot mybatis mysql fastjson hutool 的一个基础的增删改查的学习项目, 简单容易上手 前端这边 node14 vue element…