svn服务器搭建-SuSE Linux Enterprise Server 11 SP3

svn存储版本数据也有2种方式:
1.bdb;
2.fsfs。
因为BDB方式在服务器中断时,有可能锁住数据(搞ldap时就深受其害,没法根治),所以还是FSFS方式更安全一点,我也选择这种方式。
下载相关软件
wget http://subversion.tigris.org/downloads/subversion-1.6.6.tar.gz
wget http://subversion.tigris.org/downloads/subversion-deps-1.6.6.tar.gz
二 解压两个包:
  1.在此之前,我已经创建了一个用户svnroot专门用来安装管理svn的,就解压在/root/sur/local/svn/目录下
  
     tar zxvf subversion-1.6.6.tar.gz
tar zxvf subversion-deps-1.6.6.tar.gz

  2. 编译安装 

  1.  ./configure --prefix=/root/usr/local/svn/subversion-1.6.6 --without-berkeley-db 2.   3. //prefix指定安装的目录,without-berkeley-db表明不使用berkeley数据库  4.   5. //在这一步有可能不成功,是因为有一些依赖的软件没装,具体见下面“遇到的问题”  6.   7. make  8.   9. make install  

  3.添加环境变量

  1. 查看是否安装成功  2.   3. /root/usr/local/svn/subversion-1.6.6/bin/svnserve --version  4.   5. //如果出现SVN的版本则证明安装成功 

  

  1. 可以在/etc/profile中添加  2.   vi /etc/profile3. export PATH=$PATH:/root/usr/local/svn/subversion-1.6.6/bin  4. 添加后保存退出5. 修改完成后,使用source /etc/profile 命令进行更新;
  1. 在看看配置的环境起作用了没有 svnserve --version

  错误汇总

1、 configure: error: We require OpenSSL; try --with-openssl
  1. 错误提示需要安装openssl,所以我就安装了一个openssl,安装方法如下:  2.   3.   4. cd /root/usr/local/ssl5.   6. tar -zxvf openssl-1.0.0a.tar.gz  7.   8. cd openssl-1.0.0a  9.   10. ./config  11.   12. ./config -t  13.   14. make depend  15.   16. make  17.   18. make test  19.   20. make instal  21.   22. 安装之后会在/usr/local下生成一个ssl目录,配置SVN时加上openssl路径  23.   24.  ./configure --prefix=/root/usr/local/svn/subversion-1.6.6 --without-berkeley-db --with-openssl=/usr/local/ssl   

  2./usr/local/ssl/lib/libssl.a: could not read symbols: Bad value  

  1. 加上–without-serf  	2.  ./configure --prefix=/root/usr/local/svn/subversion-1.6.6 --without-berkeley-db --with-openssl=/usr/local/ssl -without-serf

 

  三 建立仓库

  1. 创建目录
  1. mkdir  -p  /root/usr/local/svn/svndata/inc  2.   3. 加上参数P,是如果没有父目录则自动创建  4.   5. 注意: /root/usr/local/svn/svndata在这里将是所有仓库的根目录,innc是其中的一个仓库。 

  2. 创建仓库

  1. svnadmin create  /root/usr/local/svn/svndata/inc 2.   3. 这里使用SVN将inc建立为仓库。则在inc文件夹里会生成一系列对于inc仓库相应的配置文件

四 配置仓库

    1. 查看创建仓库后的文件

进入/svndata/inc/conf,会发现有几个配置文件  

    2. 修改svnserve.conf

  1. vi svnserve.conf  2.   3. 打开这个配置文件,可以看到很多配置项已经注释掉了,只需要按下面这几项修改就可以了  4.   5. [general]  6.   7. anon-access = none  8.   9. auth-access = write  10.   11. password-db = passwd  12.   13. authz-db=authz  

  3. 目录控制文件authz (or叫权限控制文件)

  1. vi authz  2.   3. 默认是没有配置的,要参照下面示例来配置  4.   5. [groups]  6.   7. admin = svnadmin  8.   9. [repos1:/]  10.   11. @admin = rw  12.   13. svnadmin = rw  14.   15. 上面的配置权限控制文件的配置格式如下:  16.   17. [groups]  18.   19. <用户组名> = <用户1>,<用户2>, ……  20.   21. [<版本库>:/项目/目录]  22.   23. @<用户组名> = <权限>  24.   25. <用户名> = <权限>  26.   27. 其中,方框号内部分可以有多种写法:  28.   29. /,表示根目录及以下。根目录是svnserve启动时指定的,我们指定为/root/usr/local/svn/svndata		    这样,/就是表示对全部版本库设置权限。  30.   31. inc:/,表示对版本库1设置权限  32.   33. inc2:/occi,表示对版本库2中的occi项目设置权限  34.   35. inc2:/occi/aaa,,表示对版本库2中的occi项目的aaa目录设置权限  36.   37. 权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。  

  4. 修改用户密码文件passwd

  1. vi passwd  2.   3. 默认也是没有配置任何用户的,可按下面配置示例配置  4.   5. [users]  6.   7. svnadmin = 123456  8.   9. 用户密码的配置格式:  10.   11. [users]  12.   13. <用户1> = <密码1>  14.   15. <用户2> = <密码2>  16.   17. 注意:这里的配置文件,除了注释外每行都必须顶行,否则又会报错了。 

  五 启动SVN

  1. svnserve -d -r /root/usr/local/svn/svndata  2.   3. -d表示在后台运行,-r表示后台执行 4.   5. 注意:这里是/root/usr/local/svn/svndata,并非/root/usr/local/svn/svndata/inc  。这是SVN使所有仓库根目录都生效的命令,并非某个仓库。这里必须注意。  

  六 基本测试

  1. svn co svn://ip/inc2.   3. checkout的时候,会要求输入用户名密码,只有配置了的用户才能验证通过 

  七 端口开放

    手动修改:

  1. vi  /etc/sysconfig/SuSEfirewall22.   3. #TCP端口的情况:4. 5. FW_SERVICES_EXT_TCP="3306 3690"6. 7. 防火墙设置的生效:8.    SuSEfirewall2 restart
在windows 下 测试能不能访问:telnet ip 端口

  客户端访问

通过客户端进行访问,svn服务默认端口是:3390
地址如下:
svn://ip:3690/inc/
注意:
不要在浏览器中通过http的方式进行访问,如下地址:http://ip:3690/tshop/
那样肯定是不行的,因为你没有配置http的服务,上面是安装独立的SVN服务器

转载于:https://www.cnblogs.com/PuShaobin/p/6047931.html

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

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

相关文章

Swift 2.0初探:值得注意的新特性

转眼间&#xff0c;Swift已经一岁多了&#xff0c;这门新鲜、语法时尚、类型安全、执行速度更快的语言已经渐渐的深入广大开发者的心。我同样也是非常喜爱这门新的编程语言。 今年6月&#xff0c;一年一度的WWDC大会如期而至&#xff0c;在大会上Apple发布了Swift 2.0&#xff…

Android 自定义WebView弹窗及屏蔽弹窗

额&#xff0c;还是那个WebView的问题&#xff0c;内核已换成腾讯X5内核&#xff0c;所以接下来的内容会有一些X5内核的方法。但我们的H5是不能改的&#xff0c;还是只有委屈我们自己。先看看H5自带的弹窗 这样子的弹窗在不同的手机上呈现的可能是不同的效果&#xff0c;效果不…

【图像处理】——Python实现two_pass方法来进行连通域的提取

目录 一、相关知识 1、two_pass算法思想 2、并查集算法 二、自定义的two_pass算法

C++ 多线程使用future传递异常

如果 std::async 调用的函数抛出异常&#xff0c;那么这个异常会被存储在值的位置&#xff0c;同时 future 变为 ready ,如果调用 get() 会重新抛出存储的异常。 Note: 标准并没有指定原来的异常对象是被重新抛出或者拷贝后抛出&#xff0c;不同的编译器会做不同的选择。 对于 …

期货黄金与现货黄金比较

现货黄金与期货黄金是目前市场上最热门的黄金投资方式&#xff0c;与国内任何的金融投资品相比&#xff0c;都具有一定的优势。 其实金投网小编觉得现货黄金与期货黄金最主要的不同点是这个&#xff1a;期货黄金做的是国内市场&#xff0c;同股票市场一样&#xff0c;里面有庄家…

DNS域传送漏洞

0x00 相关背景介绍 Dns是整个互联网公司业务的基础&#xff0c;目前越来越多的互联网公司开始自己搭建DNS服务器做解析服务&#xff0c;同时由于DNS服务是基础性服务非常重要&#xff0c;因此很多公司会对DNS服务器进行主备配置而DNS主备之间的数据同步就会用到dns域传送&#…

封装之--通过类中公有方法访问私有成员变量

如何在ClassB中访问ClassA的私有成员变量&#xff1f;&#xff08;典型的封装案例&#xff09; 通过在ClassA中定义公有的成员方法&#xff0c;然后&#xff0c;在ClassB中通过ClassA的对象调用ClassA中的公有方法&#xff0c;来访问ClassA中的私有成员变量。 转载于:https://w…

匹配物镜放大倍数与相机像元尺寸

通常来说&#xff0c;相机内部的CCD或者CMOS传感器上都有感光阵列&#xff0c;由一个一个的感光元件构成&#xff0c;每一个感光元件负责完成光电转换的过程。简单理解&#xff0c;一个感光元件可以认为就是一个像素(pixel)或像元(pel)。像元具有一定尺寸&#xff0c;如果像的尺…

2016/11/10 kettle概述

ETL(Extract-Transform-Load&#xff0c;即抽取&#xff0c;转换&#xff0c;加载)&#xff0c;数据仓库技术&#xff0c;是用来处理将数据从来源&#xff08;以前做的项目&#xff09;经过抽取&#xff0c;转换&#xff0c;加载到达目的端&#xff08;正在做的项目&#xff09…

【深度学习】——非极大值抑制(nms/soft-nms)

目录 一、相关概念 1、iou 1&#xff09;理论计算 2&#xff09;Python代码&#xff08;代码参考yolov3模型util.py文件&#xff09; 2、nms 1)基本思路 2&#xff09;标准nms和soft-nms 3&#xff09;Python代码实现&#xff08;yolov3中util.py文件&#xff0c;增加了…

移动服务安全现状分析!

2019独角兽企业重金招聘Python工程师标准>>> 由于Android开源的环境&#xff0c;导致Android的整体环境都存在很多不安全的因素&#xff0c;同时用户在移动APP客户端的便捷应用&#xff0c;也给用户带来了巨大的安全隐患。未经过移动服务安全加固的APP存在被静态反编…

封装不同类模板的随机数生成器

最近准备刷题&#xff0c;打算简单封装下随机数生成器&#xff0c;方便产生测试数据。C11的STL提供了很多分布类型&#xff0c;我比较常用的是均匀分布&#xff0c;均匀分布的值有两种类型&#xff0c;一类是整数&#xff0c;另一类是浮点数&#xff0c;STL根据值的类型定义了两…

Log4j详细设置说明

1. 动态的改变记录级别和策略&#xff0c;即修改log4j.properties,不需要重启Web应用&#xff0c;这需要在web.xml中设置一下。2. 把log文件定在 /WEB-INF/logs/ 而不需要写绝对路径。3. 可以把log4j.properties和其他properties一起放在/WEB-INF/ &#xff0c;而不是Class-Pat…

【机器学习】——卷积神经网络(Keras)修改学习率(定值+自适应)

目录 1、直接获取现有模型的学习率 2、打印显示学习率 3、调整学习率 1&#xff09;1.LearningRateScheduler 2&#xff09;ReduceLROnPlateau 利用tensorflow的Keras模块我们可以建立我们自己定义的卷积神经网络模型&#xff0c;但是一般不会触碰到学习率这个问题&#x…

使用Docker构建你的第一个服务

1. 感受一下Docker的便捷 项目源码 https://github.com/MoonShining/dockernize-grape-helloworld clone下来以后运行,cd到项目目录下&#xff0c;运行 docker build -t api-sample . docker run -p 8080:8080 api-sample:latest 复制代码就可以访问localhost:8080看到效果了. …

MyEclipse连接MySQL

在官网http://www.mysql.com/downloads/下载数据库连接驱动 本文中使用驱动版本为mysql-connector-java-5.1.40 一、创建一个java测试项目MySQLConnectorsTest 在项目下穿件一个lib文件夹用来存放MySQL驱动包。 右键驱动包build path进行add添加操作&#xff0c;打开Referenced…

在Windows系统中配置Google AddressSanitizer

Google AddressSanitizer简介 AddressSanitizer (ASan) 是 C 和 C 的内存错误检测软件&#xff0c;它可以检测&#xff1a; 释放指针后继续使用堆缓冲区溢出栈缓冲区溢出全局缓冲区溢出返回后继续使用在范围之外继续使用初始化顺序的bug内存泄漏 在 Windows 系统中&#xff…

【剑指offer】——求出一个正整数的质数因子(Python)

目录 一、题目描述 二、思路 1、短除法 2、平方根法 一、题目描述 功能:输入一个正整数&#xff0c;按照从小到大的顺序输出它的所有质因子&#xff08;重复的也要列举&#xff09;&#xff08;如180的质因子为2 2 3 3 5 &#xff09; 最后一个数后面也要有空格 输入描述…

Python字符串笔录

python字符串操作实方法&#xff0c;包括了几乎所有常用的python字符串操作&#xff0c;如字符串的替换、删除、截取、复制、连接、比较、查找、分割等 1、去空格及特殊符号 >>> s 123 >>> s.strip() # 去除所有空格123 >>> s1 123 >>&…