今天我们来聊聊svn的使用
前言:作为一名码农,如果你告诉你的小伙伴你不会使用版本控制,那么你将会被小伙伴所鄙视,这个文章从区别带你领略他们的优缺点.
(一)git和svn之间的区别
svn相当于是一个云存储,必须要借助网络,才能够实时的更新和提交数据,版本放在了远程
git相当于是一个本地存储,在不提交和更新版本文件的时候,不需要借助网络,版本控制放在了本地
(二)git和svn初始的使用步骤(前提是已经安装了版本控制软件,建议360下载)
1.svn的步骤
- 建立你想变成版本控制的文件夹->cmd(管理员模式)执行svnadmin create 文件夹路径(这里要加入到环境变量)->svnserve -d -r 文件的路径
- 执行了svnserve -d -r会实时监控不要关闭这个窗口
- 完成了这些步骤后会在同级的文件中生成一个带有图标的svn版本控制,在这个文件里面就可以进行提交
- 创建两个文件后,右键提交
- 在没有配置权限的时候,没有提交的权限(下面会讲到)
2.git步骤
- 执行git init 把文件夹变成本地仓库->git config --list 可以查看当前用户的信息->git config --global user.name "用户名"->git config --global user.email "邮箱"
(三)svn权限的配置(匿名用户与授权用户)
1.单仓库匿名用户
-
conf/svnserve.conf
配置文件即可,把其中anno-access = read
前面的注释#
号给去掉,把read改为write,如下: - 此时配置完毕就能够成功把文件提交到版本库中了
2.单仓库授权用户的设置
需要修改仓库conf目录中的三个配置文件:svnserve.conf、passwd、authz
注意:这里在做检出时候必须是svn://127.0.0.1,否则会出错,而且有时候也要考虑到缓存的问题
(四)SVN冲突的解决
冲突出现的原因是:由于不同用户对一个文件的同一行的内容进行的编辑,所以会出现冲突,后提交的用户必须要解决冲突才可以提交.
解决的方法:1.强制的合并 2.提交前先更新数据
把多余的符号去除就可以强制合并了
(五)版本回退
- 这里的版本回退应该是挺简单的吧!
(六)部署多仓库
- 在这个仓库下面进行建立多个文件(注意要开启这个app的服务的监控)同时要把java两个文件进行变成仓库的操作svnadmin create D:\app 等
- 可以对应每个仓库进行检出数据
- 根据不同的用户的进行仓库权限设置(的开放)
(七)svn监管服务注册成window系统服务
以管理员的方式执行以下命令: sc create SVNService binpath= "D:\svn\server\bin\svnserve.exe --service -r D:\app\" start= auto
(八)svn中的钩子程序
抽象介绍:所谓钩子就是与一些版本库事件触发的程序,例如新修订版本的创建,或是未版本化属性的修改。每个钩子都会被告知足够多的信息,包括那是什么事件,所操作的对象,和触发事件的用户名。通过钩子的输出或返回状态,钩子程序能让工作继续、停止或是以某种方式挂起。
说的简单点,我们可以利用钩子在提交前或者是提交后做一些操作。如:
利用提交前的钩子让用户在提交代码前强制用户必须填写备注信息(了解)。
利用提交后的钩子把svn仓库代码实时同步到网站web目录(重点掌握,开发中使用较多)
修改两个文件就可以实现钩子事件
post-commit.bat内容为:
SET SVN="D:\svn\sever\bin\svn.exe"
SET DIR="D:\local.com\blog"
SVN update %DIR% --username dashen --password dashen123
2.后钩子
今天我们来聊聊svn的使用的更多相关文章
- 聊聊Unity项目管理的那些事:Git-flow和Unity
0x00 前言 目前所在的团队实行敏捷开发已经有了一段时间了.敏捷开发中重要的一个话题便是如何对项目进行恰当的版本管理.项目从最初使用svn到之后的Git One Track策略再到现在的GitFlo ...
- 从架构演进的角度聊聊Spring Cloud都做了些什么?
Spring Cloud作为一套微服务治理的框架,几乎考虑到了微服务治理的方方面面,之前也写过一些关于Spring Cloud文章,主要偏重各组件的使用,本次分享主要解答这两个问题:Spring Cl ...
- Spring Cloud Config(一):聊聊分布式配置中心 Spring Cloud Config
目录 Spring Cloud Config(一):聊聊分布式配置中心 Spring Cloud Config Spring Cloud Config(二):基于Git搭建配置中心 Spring Cl ...
- 02 SVN 与 Git 的优缺点
上一篇博客大致聊了聊关于版本控制系统的周边,这一篇我们就来继续唠唠作为近年来最受欢迎的两个版本控制系统的优缺点吧. 聊优缺点之前,先简单了解一下这两个这两个版本控制系统好了: 关于 SVN SVN 概 ...
- Mono为何能跨平台?聊聊CIL(MSIL)
前言: 其实小匹夫在U3D的开发中一直对U3D的跨平台能力很好奇.到底是什么原理使得U3D可以跨平台呢?后来发现了Mono的作用,并进一步了解到了CIL的存在.所以,作为一个对Unity3D跨平台能力 ...
- svn 常用命令总结
svn 命令篇 svn pget svn:ignore // 查看忽略项 svn commit -m "提交说明" // 提交修改 svn up(update) // 获取最新版本 ...
- svn常用命令
1.新建版本库 [root@localhost repos]# mkdir -p project [root@localhost repos]# svnadmin create project [ro ...
- 对Maven、gradle、svn、spring 3.0 fragment、git的想法
1.Maven Maven可以构建项目,采用pom方式配置主项目和其他需要引用的项目.同时可结合spring3.0的新特性web fragment. 从现实出发,特别是对于管理不到位,程序员整体素质 ...
- 电脑新建svn仓库
步骤1:安转svg: 注意事项: 安装的时候选择:Modify 安装到以下图片的步骤时: 黄色区域选择: 步骤2:新建svn仓库文件夹(本教程例子:D:\svn-5gpos),选择文件夹右键,点击下图 ...
随机推荐
- 大学jsp实验3include指令的使用
1.include指令的使用 (1)编写一个名为includeCopyRight.jsp的页面,页面的浏览效果如下: 要求“2016”这个值可以实现动态更新.请写出页面代码: <%@ page ...
- 华为Python 算法面试题
华为算法面试题 """ 算法题: 提供一个序列,完成对这个序列的分割.要求分割后的两个序列彼此差值最小 实现函数,返回两个序列 """ de ...
- 后台CRUD管理jqGrid 插件下载、使用、demo演示
jqGrid:demo?version=5.2.1download src: http://www.trirand.com/blog/ github:https://github.com/tonyto ...
- CodeForces 632C The Smallest String Concatenation//用string和sort就好了&&string的基础用法
Description You're given a list of n strings a1, a2, ..., an. You'd like to concatenate them togethe ...
- 微信小程序避坑指南
如果对小程序还不熟悉,建议先看下另一篇小程序简介 1. 基础库和微信版本对应关系 iOS 客户端版本 基础库版本 6.7.2 2.3.0 6.7.0 2.2.5 6.6.7 2.1.3 6.6.6 2 ...
- 【BZOJ5317】[JSOI2018]部落战争(凸包,闵可夫斯基和)
[BZOJ5317][JSOI2018]部落战争(凸包,闵可夫斯基和) 题面 BZOJ 洛谷 题解 很明显我们只需要两个凸包\(A,B\). 假设询问给定的方向向量是\(v\). 那么现在就是判断\( ...
- IO创建Socket通信中慎用BufferReader中的readLine()
在编写Socket的Demo的时候,在Server中使用BufferReader获取从客服端发送过来的内容 package cn.lonecloud.socket; import cn.loneclo ...
- jconsole 连接 wildfly 10 监控
1,远程wildfly服务器: 访问:http://211.100.75.242:9990 按照提示添加用户,重启后可以登录进入.成功. 2,省事做法.本地解压wildfly服务器,进入wildfly ...
- agc031
T1 题意:给你一个串,求所有子序列个数,满足没有相同字符.1e5,2s. 解:考虑一个合法的子序列.其中每个字母的出现位置都有(出现次数)种选择.还可以不选,要 + 1. 然后乘起来就做完了.如果变 ...
- 跟着underscore学防抖
前言 在前端开发中会遇到一些频繁的事件触发,比如: window 的 resize.scroll mousedown.mousemove keyup.keydown -- 为此,我们举个示例代码来了解 ...