Linux(Centos6.5)下安装svn服务器,并通过http访问

简介:

linux安装svn其实很容易,个人觉得难就难在配置上,反复配置,琢磨,查找相关资料,总算是成功了。。

安装:

  1. 安装svn,一般情况下,选择yum方式安装还是比较简单的。

[root@moshi ~] # yum -y install mod_dav_svn
#会自动安装mod_dav_svn及其依赖包:mod_dav_svn-1.6.11-9,neon-0.29.3-2,pakchois-0.4-3.2,subversion-1.6.11-9


直接安装这个就能把svn服务器直接KO了。

2.安装httpd

 [root@moshi ~]# yum -y install httpd

一般情况下,linux服务器是有httpd服务的,你可以检查下,如果没有则安装。

检查方法:

 [root@moshi ~]# vi /etc/httpd/conf.d/subversion.conf


安装完svn后看是否有该目录&文件,如果存在则不需要安装httpd了。

3.安装完SVN,接下来就是配置了。

配置:

1、配置svn仓库

#创建svn目录
[root@moshi ~] # mkdir -p /home/svn/repos1  #仓库1
[root@moshi ~] # mkdir -p /home/svn/repos2  #仓库2
#可以任意配置,任意指定你喜欢的目录
#建立svn版本库
[root@moshi ~] # svnadmin create /home/svn/repos1
[root@moshi ~] # svnadmin create /home/svn/repos2
#有多少个仓库就执行多少次该命令,只需要换最后的名字即可


2、修改SVN版本库配置文件

 [root@moshi ~]# vi /home/svn/repos1/conf/svnserve.conf

修改文件结果如下:

[general]
anon-access = none    
auth-access = write
password-db = /home/svn/conf/pwd.conf    #指向用户配置文件
authz-db = /home/svn/conf/authz.conf     #指向权限配置文件
realm = repos1                           #指向svn仓库地址

备注:其他仓库配置和该配置相同,只需要修改仓库路径。

3.配置svn用户和权限

[root@moshi ~] # vim /home/svn/conf/pwd.cof
[root@moshi ~] # vim /home/svn/conf/authz.conf
#这是2个步骤,我这里为更好的阅读,写在一起
1.配置用户
由于这个配置是我自定义的,所以要先vim创建该文件,也可以用其他方式创建。
[root@moshi ~] # vim /home/svn/conf/pwd.conf
#保存退出
[root@moshi ~] # htpasswd -c /home/svn/conf/pwd.conf admin
#根据提示输入密码,第一个用户才需要加-c,后面的用户不需要-c
[root@moshi ~] # htpasswd /home/svn/conf/pwd.conf test
[root@moshi ~] # vi /home/svn/conf/pwd.conf
在用户最上方加上[users]



加上[users]这一步是很重要的,因为用htpasswd的方式加用户会覆盖掉[users],所以每次加完用户需要回去补一下该节点

2.配置权限
[root@moshi ~] # vim /home/svn/conf/authz.conf
文件内容如下:
[groups]
admin=user1,user2
test=user3
[/]
@admin=rw
[repos1:/]
user3=r


解释:[groups]为组定义,可以在该组下加很多用户,以,分割,

但是该用户数据必须在/homd/svn/conf/pwd.conf中定义好,

[/]表示根目录以下的权限定义

[repos1:/]表示仓库下的权限定义

如果要分项目,则以此规则类推:

如:[repos1:/aaa]则表示仓库下的aaa项目的权限定义。

@admin 表示admin这个组下的用户权限。

user1=r 表示user1这个用户的权限。

权限类型:r,w,rw 分别表示只读,只写,读写如果是user1= 这种空情况则表示没有

OK,到此svn配置完成。我们可以把默认的配置文件删除。

[root@moshi ~] # rm -rf /home/svn/repos1/conf/passwd
[root@moshi ~] # rm -rf /home/svn/repos2/conf/authz
##多个仓库则删除多个仓库对应的文件即可

4.建立启动svn的用户

[root@moshi ~] # useradd svn                    #如果提示svn账户已存在,则执行以下命令
[root@moshi ~] # passwd svn                     ##根据提示修改下密码,不能过于简单,可使用常用密码
[root@moshi ~] # chown -R svn:svn /home/svn/    ##允许用户svn访问版本库
[root@moshi ~] # chmod –R o+rw /home/svn        ##解决windows检出提交提示/home/svn/db/txn-current-lock’错误

5.配置svn的端口

 [root@moshi ~]# vi /etc/httpd/conf/httpd.conf

找到

#Listen 12.34.56.78:80这一行,

Listen 9999  ##9999就是svn的端口,默认是80,你可以修改成你自己想要的。不建议使用默认80端口

5.配置httpd

 [root@moshi ~]# vi /etc/httpd/conf.d/subversion.conf

修改文件内容为:

<Location /svn>

    DAV svn

    SVNListParentPath on

    SVNParentPath /home/svn

    AuthType Basic

    AuthName "Authorization"

    AuthUserFile /home/svn/conf/pwd.conf                    ##对应你的用户配置文件

    AuthzSVNAccessFile /home/svn/conf/authz.conf      ##对应你的权限配置文件

    Require valid-user

</Location>

保存退出!

重启httpd服务。

[root@moshi ~] # service httpd restart
停止 httpd:                                               [确定]
正在启动 httpd:                                           [确定]

出现以上字样,表名httpd的配置已经成功启动成功。

6.启动svn

 [root@moshi ~]# svnserve -d -r /home/svn/

7.查看svn服务是否正常

[root@moshi ~] # ps aux|grep svn
##出现以下内容说明svn服务已经成功启动
root      8610  0.0  0.0 152864   740 ?        Ss   11:25   0:00 svnserve -d -r /home/svn/repos1/
root     13128  0.0  0.0 103252   876 pts/0    S+   14:00   0:00 grep svn

8.进入浏览器访问。

在浏览器中输入:服务器Ip+端口+httpd配置中的<Location /svn>。

如:http://192.168.1.1:9999/svn


本文转自 转身撞墙角 51CTO博客,原文链接:http://blog.51cto.com/chentianwang/1690077

相关文章
|
2月前
|
Shell Linux 网络安全
宝塔服务器面板部署安装git通过第三方应用安装收费怎么办—bash: git: command not found解决方案-优雅草卓伊凡
宝塔服务器面板部署安装git通过第三方应用安装收费怎么办—bash: git: command not found解决方案-优雅草卓伊凡
474 3
宝塔服务器面板部署安装git通过第三方应用安装收费怎么办—bash: git: command not found解决方案-优雅草卓伊凡
|
3月前
|
Ubuntu 安全 关系型数据库
安装MariaDB服务器流程介绍在Ubuntu 22.04系统上
至此, 您已经在 Ubuntu 22.04 系统上成功地完成了 MariadB 的标准部署流程,并且对其进行基础但重要地初步配置加固工作。通过以上简洁明快且实用性强大地操作流程, 您现在拥有一个待定制与使用地强大 SQL 数据库管理系统。
286 18
|
3月前
|
Ubuntu 安全 关系型数据库
安装MariaDB服务器流程介绍在Ubuntu 22.04系统上
至此, 您已经在 Ubuntu 22.04 系统上成功地完成了 MariadB 的标准部署流程,并且对其进行基础但重要地初步配置加固工作。通过以上简洁明快且实用性强大地操作流程, 您现在拥有一个待定制与使用地强大 SQL 数据库管理系统。
294 15
|
3月前
|
弹性计算 安全 Linux
使用阿里云服务器安装Z-Blog博客网站流程,新手一键部署教程
本教程教你如何在阿里云99元服务器上,通过宝塔Linux面板一键部署Z-Blog博客。基于CentOS 7.9系统,从远程连接、安装宝塔面板、开放端口到部署Z-Blog全流程详解,操作简单,新手也能轻松搭建个人博客网站。
461 13
|
4月前
|
弹性计算 安全 Linux
阿里云服务器ECS安装宝塔Linux面板、安装网站(新手图文教程)
本教程详解如何在阿里云服务器上安装宝塔Linux面板,涵盖ECS服务器手动安装步骤,包括系统准备、远程连接、安装命令执行、端口开放及LNMP环境部署,手把手引导用户快速搭建网站环境。
|
7月前
|
安全 网络协议 Linux
Linux网络应用层协议展示:HTTP与HTTPS
此外,必须注意,从HTTP迁移到HTTPS是一项重要且必要的任务,因为这不仅关乎用户信息的安全,也有利于你的网站评级和粉丝的信心。在网络世界中,信息的安全就是一切,选择HTTPS,让您的网站更加安全,使您的用户满意,也使您感到满意。
213 18
|
7月前
|
网络安全 开发者
如何解决HTTPS协议在WordPress升级后对网站不兼容的问题
以上就是解决WordPress升级后HTTPS协议对网站的不兼容问题的方法。希望能把这个棘手的问题看成是学校的管理问题一样来应对,将复杂的技术问题变得更加有趣和形象,并寻觅出解决问题的方式。希望你的网站能在新的学期得到更好的发展!
213 19
|
7月前
|
JSON 安全 网络协议
HTTP/HTTPS协议(请求响应模型、状态码)
本文简要介绍了HTTP与HTTPS协议的基础知识。HTTP是一种无状态的超文本传输协议,基于TCP/IP,常用80端口,通过请求-响应模型实现客户端与服务器间的通信;HTTPS为HTTP的安全版本,基于SSL/TLS加密技术,使用443端口,确保数据传输的安全性。文中还详细描述了HTTP请求方法(如GET、POST)、请求与响应头字段、状态码分类及意义,并对比了两者在请求-响应模型中的安全性差异。
715 20
|
7月前
|
安全 网络协议 算法
HTTP/HTTPS与SOCKS5协议在隧道代理中的兼容性设计解析
本文系统探讨了构建企业级双协议隧道代理系统的挑战与实现。首先对比HTTP/HTTPS和SOCKS5协议特性,分析其在工作模型、连接管理和加密方式上的差异。接着提出兼容性架构设计,包括双协议接入层与统一隧道内核,通过协议识别模块和分层设计实现高效转换。关键技术部分深入解析协议转换引擎、连接管理策略及加密传输方案,并从性能优化、安全增强到典型应用场景全面展开。最后指出未来发展趋势将更高效、安全与智能。
268 1
|
监控 安全 搜索推荐
设置 HTTPS 协议以确保数据传输的安全性
设置 HTTPS 协议以确保数据传输的安全性