SVN学习笔记 svn入门
yuyutoo 2024-11-02 15:22 3 浏览 0 评论
一. SVN
1.什么是SVN
SVN: subversion 子级版本 (子级源代码版本控制管理软件)
svn:全称Subversion,是代码版本管理软件,管理着随时间改变的数据。这些数据放置在一个中央资料档案库 (repository) 中。 这个档案库很像一个普通的文件服务器, 不过它会记住每一次文件的变动。这样你就可以把档案恢复到旧的版本, 或是浏览文件的变动历史。 许多人会把版本控制系統想像成某种 "时光机器"。
使用svn可以很好地协调一个团队共同开发同一个项目,而不会出现代码冲突、覆盖的情况。
SHAPE \* MERGEFORMAT
上图是多人共同开发同一个项目,内部最大的问题是,在比较短的时间内如果有多人同时开发同一个文件,会造成彼此代码覆盖的情况发生。A的代码在最后会把B的代码给覆盖掉,10点以后就只体现A程序员的功能效果。
SVN其中的作用一个就是避免上述情况发生。
2. 使用svn的作用
① 多人开发同一个项目不会出现代码覆盖情况。
② 针对一个文件可以创建许多不同版本,并且可以随时查看不同版本的内容。
③ 公司领导可以通过svn查看每个人的工作情况
二. SVN的安装
1. 服务器端安装
2. 客户端安装
3. 创建多个svn仓库(存储代码)
> svnadmin create h:/svnServer/app/shop
4. 启动仓库服务
> svnserve -d(独立端口运行) -r(仓库地址) 仓库地址
> svnserve -d -r h:/svnServer/app/shop //启动shop仓库服务
该svn服务走svn协议,端口号码是3690
5. 使得本地客户端(码农)与仓库取得联系
> 右键------> checkout
三. 使用svn服务
1. 给svn仓库提交第一个程序文件
步骤:
① 右键------> SVN---->Add
(本地的.svn对该文件形成管理)
② 右键------> Commit
(本次的文件提交给svn仓库)
1.1 文件颜色标志
① 蓝色加号:本地的.svn对该文件有形成管理
② 绿色对号:本地文件、.svn管理的版本文件、仓库文件 三者一致
③ 红色叹号:本地文件 与 .svn和仓库文件 不一致(用户自己修改了该文件)
④ 黄色叹号:表示该文件正处于冲突状态
2. 多个程序员给仓库提交文件
SHAPE \* MERGEFORMAT
3. 同时运行多个svn仓库服务
把所有仓库的上级目录当成服务给启动起来。
· svnserve -d -r d:/svnServer/app/
主机名:svn://localhost ---------------->app目录
svn://localhost/student---------->与student仓库取得联系
svn://localhost/book------------->与book仓库取得联系
svn://localhost/shop-------------->与shop仓库取得联系
3.1 旧用户更换svn主机名
删除.svn文件,断开与仓库的联系
重新checkout通过svn新主机名建立与仓库的联系
4. 同一个文件的不同版本切换
一个程序文件可以在svn仓库里边形成许多不同版本,并可以随时查看。
总结:
1. 安装svn的服务器、客户端软件
2. 创建仓库(根据不同的项目创建对应的仓库)
> svnadmin create 仓库地址
3. 使用svn( checkout update commit )
4. 启动svn仓库服务
> svnserve -d -r 仓库地址
四.冲突解决(重点)
上图两个程序员在短时间之内共同开发同一个程序文件(goods.php)
10点以后系统只会体现linken开发的功能(mary开发的功能被linken给覆盖了)
文件覆盖的解决:
① 给每个文件分配一个"令牌",谁拿到令牌谁就有权利开发该文件
(同一个程序文件同一个时间点只允许有一个人开发)
② 给每个文件设置一个版本号码,提交的时候如果服务器的版本等于本地版本号码就允许提交,否则不允许提交(本地号码 小于 服务器版本)
冲突:
广义角度的冲突,提交程序文件 本地版本号码 小于 服务器版本号码
狭义角度的冲突,多个程序员对同一个文件同一处代码的修改再共同提交文件的时候回产生冲突。
1. 冲突具体形式:
1.1大家修改的代码不在同一处
解决:
执行update操作,把仓库最新的文件更新到本地,并和本地文件做Merge融合操作。
继续提交文件即可。
1.2 大家修改的代码在同一处
无论什么样子的冲突:解决就是通过update把最新的版本更新到本地,文件稍作修改后继续提交。
五. 账号和权限
1. 设置账号
2. 给账号设置权限
2.1 给具体用户设置权限
2.2 给一个组别设置权限
2.3 开启只操作某个目录权限
步骤:
① 管理员先把该目录给创建出来并提交给svn仓库
② 外包团队给该 目录提交文件
③ 管理员删除本身创建的目录,执行update更新操作,即可查看外包团队的工作情况
六.设置开机启动项服务
七. 真实环境使用svn
总结:
1. 冲突解决
类型:大家修改代码在(不在)同一处
解决:统一执行update操作,服务器文件会和本身文件做融合(大家的版本号码统一),文件代码做适当调整继续提交
2. 账号和权限设置
(把匿名账号设置为none)
权限设置:
① 具体用户权限设置
② 给组别统一设置权限
③ 给用户设置只操作某个目录的权限
3. 给svn设置服务
> sc create 名称 binpath= "服务执行文件 -r 服务仓库地址 --service" start= auto
>sc delete 名称
作业:
1. 组长搭建svn服务,并给组员设置用户名和密码、权限
2. 组员使用svn服务,进行commit和update操作
相关推荐
- 如何在HTML中使用JavaScript:从基础到高级的全面指南!
-
“这里是云端源想IT,帮你...
- 推荐9个Github上热门的CSS开源框架
-
大家好,我是Echa。...
- 硬核!知网首篇被引过万的论文讲了啥?作者什么来头?
-
整理|袁小华近日,知网首篇被引量破万的中文论文及其作者备受关注。知网中心网站数据显示,截至2021年7月23日,由华南师范大学教授温忠麟等人发表在《心理学报》2004年05期上的学术论文“中介效应检验...
- 为什么我推荐使用JSX开发Vue3_为什么用vue不用jquery
-
在很长的一段时间中,Vue官方都以简单上手作为其推广的重点。这确实给Vue带来了非常大的用户量,尤其是最追求需求开发效率,往往不那么在意工程代码质量的国内中小企业中,Vue占据的份额极速增长...
-
- 【干货】一文详解html和css,前端开发需要哪些技术?
-
网站开发简介...
-
2025-02-20 18:34 yuyutoo
- 分享几个css实用技巧_cssli
-
本篇将介绍几个css小技巧,目录如下:自定义引用标签的符号重置所有标签样式...
- 如何在浏览器中运行 .NET_怎么用浏览器运行代码
-
概述:...
- 前端-干货分享:更牛逼的CSS管理方法-层(CSS Layers)
-
使用CSS最困难的部分之一是处理CSS的权重值,它可以决定到底哪条规则会最终被应用,尤其是如果你想在Bootstrap这样的框架中覆盖其已有样式,更加显得麻烦。不过随着CSS层的引入,这一...
-
- HTML 基础标签库_html标签基本结构
-
HTML标题HTML标题(Heading)是通过-...
-
2025-02-20 18:34 yuyutoo
- 前端css面试20道常见考题_高级前端css面试题
-
1.请解释一下CSS3的flexbox(弹性盒布局模型),以及适用场景?display:flex;在父元素设置,子元素受弹性盒影响,默认排成一行,如果超出一行,按比例压缩flex:1;子元素设置...
- vue引入外部js文件并使用_vue3 引入外部js
-
要在Vue中引入外部的JavaScript文件,可以使用以下几种方法:1.使用``标签引入外部的JavaScript文件。在Vue的HTML模板中,可以直接使用``标签来引入外部的JavaScrip...
- 网页设计得懂css的规范_html+css网页设计
-
在初级的前端工作人员,刚入职的时候,可能在学习前端技术,写代码不是否那么的规范,而在工作中,命名的规范的尤为重要,它直接与你的代码质量挂钩。网上也受很多,但比较杂乱,在加上每年的命名都会发生一变化。...
- Google在Chrome中引入HTML 5.1标记
-
虽然负责制定Web标准的WorldWideWebConsortium(W3C)尚未宣布HTML5正式推荐规格,而Google已经迁移到了HTML5.1。即将发布的Chrome38将引入H...
- HTML DOM 引用( ) 对象_html中如何引用js
-
引用对象引用对象定义了一个同内联元素的HTML引用。标签定义短的引用。元素经常在引用的内容周围添加引号。HTML文档中的每一个标签,都会创建一个引用对象。...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)