百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

SVN学习笔记 svn入门

yuyutoo 2024-11-02 15:22 4 浏览 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操作

相关推荐

【Socket】解决UDP丢包问题

一、介绍UDP是一种不可靠的、无连接的、基于数据报的传输层协议。相比于TCP就比较简单,像写信一样,直接打包丢过去,就不用管了,而不用TCP这样的反复确认。所以UDP的优势就是速度快,开销小。但是随之...

深入学习IO多路复用select/poll/epoll实现原理

Linux服务器处理网络请求有三种机制,select、poll、epoll,本文打算深入学习下其实现原理。0.结论...

25-1-Python网络编程-基础概念

1-网络编程基础概念1-1-基本概念1-2-OSI七层网络模型OSI(开放系统互联)七层网络模型是国际标准化组织(ISO)提出的网络通信分层架构,用于描述计算机网络中数据传输的过程。...

Java NIO多路复用机制

NIO多路复用机制JavaNIO(Non-blockingI/O或NewI/O)是Java提供的用于执行非阻塞I/O操作的API,它极大地增强了Java在处理网络通信和文件系统访问方面的能力。N...

Python 网络编程完全指南:从零开始掌握 Socket 和网络工具

Python网络编程完全指南:从零开始掌握Socket和网络工具在现代应用开发中,网络编程是不可或缺的技能。Python提供了一系列高效的工具和库来处理网络通信、数据传输和协议操作。本指南将从...

Rust中的UDP编程:高效网络通信的实践指南

在实时性要求高、允许少量数据丢失的场景中,UDP(用户数据报协议)凭借其无连接、低延迟的特性成为理想选择。Rust语言凭借内存安全和高性能的特点,为UDP网络编程提供了强大的工具支持。本文将深入探讨如...

Python 网络编程的基础复习:理解Socket的作用

计算机网络的组成部分在逻辑上可以划分为这样的结构五层网络体系应用层:应用层是网络协议的最高层,解决的是具体应用问题...

25-2-Python网络编程-TCP 编程示例

2-TCP编程示例应用程序通常通过“套接字”(socket)向网络发出请求或者应答网络请求,使主机间或者一台计算机上的进程间可以通信。Python语言提供了两种访问网络服务的功能。...

linux下C++ socket网络编程——即时通信系统(含源码)

一:项目内容本项目使用C++实现一个具备服务器端和客户端即时通信且具有私聊功能的聊天室。目的是学习C++网络开发的基本概念,同时也可以熟悉下Linux下的C++程序编译和简单MakeFile编写二:需...

Python快速入门教程7:循环语句

一、循环语句简介循环语句用于重复执行一段代码块,直到满足特定条件为止。Python支持两种主要的循环结构:for循环和while循环。...

10分钟学会Socket通讯,学不会你打我

Socket通讯是软硬件直接常用的一种通讯方式,分为TCP和UDP通讯。在我的职业生涯中,有且仅用过一次UDP通讯。而TCP通讯系统却经常写,正好今天写了一个TCP通讯的软件。总结一下内容软件使用C#...

Python 高级编程之网络编程 Socket(六)

一、概述Python网络编程是指使用Python语言编写的网络应用程序。这种编程涉及到网络通信、套接字编程、协议解析等多种方面的知识。...

linux网络编程Socket之RST详解

产生RST的三个条件:1.目的地为某端口的SYN到达,然而该端口上没有正在监听的服务器;2.TCP想取消一个已有的连接;3.TCP接收到一个根本不存在的连接上的分节;现在模拟上面的三种情况:cl...

ABB机器人编程实用技巧,多项案例

...

Python中实现Socket通讯(附详细代码)

套接字(socket)是一种在计算机网络中进行进程间通信的方法,它允许不同主机上的程序通过网络相互通信。套接字是网络编程的基础,几乎所有的网络应用程序都使用某种形式的套接字来实现网络功能。套接字可以用...

取消回复欢迎 发表评论: