linux 搭建svn服务器的方法步骤
一:安装svn
yum install -y subversion
二:创建仓库
1:创建仓库目录
mkdir -p /var/project/test
2:创建仓库
svnadmin create /var/project/test
创建成功后,在/var/project/test目录下如下目录:
drwxr-xr-x. 2 root root 51 1月 30 13:26 conf
drwxr-sr-x. 6 root root 4096 1月 30 13:26 db
-r--r--r--. 1 root root 2 1月 30 13:26 format
drwxr-xr-x. 2 root root 4096 1月 30 13:26 hooks
drwxr-xr-x. 2 root root 39 1月 30 13:26 locks
-rw-r--r--. 1 root root 229 1月 30 13:26 README.txt
conf目录下是svn的配置目录,其中包括:
-rw-r--r--. 1 root root 1080 1月 30 13:26 authz #权限控制
-rw-r--r--. 1 root root 309 1月 30 13:26 passwd #密码管理
-rw-r--r--. 1 root root 3090 1月 30 13:26 svnserve.conf #SVN服务进程配置
三:svn配置
1:权限配置(/var/project/test/conf/authz)
#用户分组(admin->管理员,development ->开发 other->其他)
[groups]
admin = test1 #管理员用户test1
development = test2,test3 #开发用户test2,test3
other = test4,test5,test6 #其他用户test4,,test5,test6
#权限配置
[/]
@admin = rw #管理员读写权限
@development = rw #开发读写权限
@other = r #其他读权限
test7 = rw #test7用户读写权限
2:密码配置(/var/project/test/conf/passwd)
#密码配置,格式为用户名=密码,密码为明文
[users]
test1 = test1
test2 = test2
test3 = test3
test4 = test4
test5 = test5
test6 = test6
test7 = test7
3:SVN服务进程配置(/var/project/test/conf/svnserve.conf)
[general]
anon-access = none #匿名用户无权访问
auth-access = write #认证用户可读写
password-db = passwd #指定用户认证密码文件
authz-db = authz #指定权限配置文件
四:启动svn服务(默认端口号3690)
复制代码 代码如下:
svnserve -d -r /var/project #-d 服务后台运行 -r 指定工作目录,/var/project表示指定工作目录,注意不能指定仓库名地址(/var/project/test)
指定端口启动svn
svnserve -d -r /var/project --listen-port 3691
五:关闭防火墙,或开启指定端口号
1:关闭防火墙
systemctl stop firewalld
2:开启指定防火墙
#开启3690端口
firewall-cmd --zone=public --add-port=3690/tcp --permanent
#刷新配置
firewall-cmd --reload
六:客户端连接并上传文件
windows上连接svn
1:新建一个目录,右击选择svn 检出
2:在版本库上填写linux的svn地址 svn://ip:3690/仓库名 (这里的仓库名不是/var/project/test而是/test)
2:填写用户名密码
这时候我们可以看到此目录下生成了一个.svn文件,说明我们已经连接上了linux上的svn服务器
3:上传文件
现在我们新建一个test.txt文件,在里面随便填一些信息
(1)右击选择add
然后选择test.txt文件,点击确定,这时候我们会看到test.txt文件上会多了一个加号
(2):上传
右击选择提交
填写备注选择要上传的文件后点击确定
这时候我们可以看到test.txt文件上的加号会变成绿色的对号,表示上传成功
但是这时候我们发现我们在/var/project/test目录下根本就没有找到我们上传的文件,这是为什么呢?难道我们没有上传成功, 这是由于把文件上传到SVN版本库后,上传的文件不再以文件原来的格式存储,而是被svn以它自定义的格式压缩成版本库数据,存放在版本库中,svn服务器版本库有两种格式,一种为FSFS,一种为BDB 这时候我们就需要在linux中实现检出
4:检出
svn checkout svn://192.168.11.201/test /data/test #svn://192.168.11.201/test表示需要检出的仓库地址 /data/test表示需要检出到哪个目录下
这是我们可以在/data/test目录下看到我们之前在客户端上传的文件,但是现在问题又来了,我们在客户端上传文件之后,不可能每次都在服务器进行检出操作吧,那么如何进行自动检出呢?
5:自动检出配置
在/var/project/test/hooks目录下新建一个post-commit文件,post-commit文件添加内容为:
#!/bin/sh
REPOS="$1" #仓库
REV="$2" #版本号
export.UTF-8 #编码
SVN=/usr/bin/svn #svn地址
WEB=/data/test #要更新的项目目录
$SVN update $WEB --username test1 --password test1 #--username test1表示设置用户名 --password test1表示设置密码
将post-commit设置为可执行
chmod +x /var/project/test/hooks/post-commit
到此自动检出配置完成,不过注意,第一次的时候需要手动检出,之后就不需要了,到此linux搭建svn服务器完成
以上就是本文的全部内容,希望对大家的学习有所帮助。
- JavaWeb项目之电话本,两个版本,以及总结反思
- 工作中问题记录
- Java导出数据生成Excel表格
- Layui常见问题
- layui动态设置下拉框数据,根据后台数据设置选中
- BCryptPasswordEncoder加密及判断密码是否相同
- 两个HTML,CSS布局实例
- cors解决Web跨域访问问题
- Java之集合初探(二)Iterator(迭代器),collections,打包/解包(装箱拆箱),泛型(Generic),comparable接口
- IIS中实现HTTPS的自动跳转
- Windows Server下IIS安装PHP+MySql环境
- Python玩机器学习简易教程
- 腾讯云服务器搭建个人博客教程
- Ubuntu下安装Nginx+PHP+MySql环境
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- PS常用命令之文件和目录操作
- 快速掌握并发编程---synchronized篇(上)
- PS常用命令之WmiObject操作
- 『爬虫四步走』手把手教你使用Python抓取并存储网页数据!
- 快速掌握并发编程---synchronized篇(下)
- pivottablejs|在Jupyter中尽情使用数据透视表!
- 快速掌握并发编程---锁优化篇
- 弄懂这 6 个问题,拿下 Python 生成器!
- 快速掌握并发编程---线程阻塞与唤醒
- DOM优化之重绘和回流
- 本地储存之 Cookie、webStorage、indexedDB
- 使用DocumentFragment优化DOM操作
- 事件的防抖和节流
- JS事件循环之宏任务和微任务
- 小程序生成图片并保存