linux svn 访问路径环境下svn安装路径多少

使用yum安装非常简单:
yum install subversion
我们这里在/home下建立一个名为svn的仓库(repository),以后所有代码都放在这个下面,创建成功后在svn下面多了几个文件夹。
[root@localhost /]# cd /home
[root@localhost home]# mkdir svn
[root@localhost home]# svnadmin create /home/svn
[root@localhost home]# ls svn
README.txt
我们这里特别关注一下conf文件夹,这个是存放配置文件的
[root@localhost home]# cd svn/conf
[root@localhost conf]# ls
svnserve.conf
authz 是权限控制文件
passwd 是帐号密码文件
svnserve.conf 是SVN服务配置文件
接下来我们依次修改这3个文件。
配置passwd
[root@localhost conf]# vi passwd
test1=123456
test2=123456
上面的例子中我们创建了2个用户,一个test1,一个test2
[root@localhost conf]# vi authz
liuxianan=rw
上面配置的含义是,liuxianan对/home/svn/下所有文件具有可读可写权限,test只有只读权限,除此之外,其它用户均无任何权限,最后一行*=很重要不能少。
拓展:使用用户分组
这个我一般不用,但是记录下来。
还是这个文件:
[root@localhost conf]# vi authz
group1 = liuxianan
group2 = test1,test2
@group1 = rw
@group2 = r
上面配置中创建了2个分组,分组1的用户可读可写,分组2的用户只读。
格式说明:
版本库目录格式:
[:/项目/目录]
配置svnserve.conf
[root@localhost conf]# vi svnserve.conf
打开下面的5个注释
anon-access = read #匿名用户可读
auth-access = write #授权用户可写
password-db = passwd #使用哪个文件作为账号文件
authz-db = authz #使用哪个文件作为权限文件
realm = /home/svn # 认证空间名,版本库所在目录
最后一行的realm记得改成你的svn目录
打开注释时切记前面不要留有空格,否则可能有问题(网上说的,我没有亲测)
启动与停止
[root@localhost conf]# svnserve -d -r /home/svn(启动)
[root@localhost conf]#killall svnserve(停止)
上述启动命令中,-d表示守护进程, -r 表示在后台执行。停止还可以采用杀死进程的方式:
[root@localhost conf]# ps -ef|grep svnserve
00:00:00 svnserve -d -r /home/svn
0 22:05 pts/0
00:00:00 grep svnserve
[root@localhost conf]# kill -9 4908
最后来个总的截图:
客户端连接
这里使用TortoiseSVN,输入地址svn://你的IP 即可,不出意外输入用户名和密码就能连接成功了。
默认端口3690,如果你修改了端口,那么要记得加上端口号。
总的来说,如果你不需要杂七杂八的权限配置只是自己一个人用的话,安装配置还是比较简单的,并不像网上说的那么麻烦,我按照网上的方法一次性成功了。
扩展:yum安装路径
以svn为例:
# rpm -qa | grep subversion
subversion-1.6.11-15.el6_7.x86_64
# rpm -ql subversion-1.6.11-15.el6_7.x86_64
/usr/share/doc/subversion-1.6.11
/usr/share/doc/subversion-1.6.11/BUGS
/usr/share/doc/subversion-1.6.11/CHANGES
rpm -qa 查询所有安装的rpm包,可以配合grep命令。
rpm -qi 查询某个具体包的介绍。
rpm -ql 列出某个具体包的所有文件
rpm几个默认安装路径:
一些设置文件放置的目录
一些可执行文件
/usr/lib64
一些程序使用的动态函数库
/usr/share/doc
一些基本的软件使用手册与帮助文档
/usr/share/man
一些man page文件
阅读(...) 评论()&&|&& &&|&& &&|&&
Linux下SVN服务器的搭建与配置
13:33:34 && 阅读:62930&&
  SVN站在更高层次上对现在的安全产品,从系统和控制的角度进行了&有机&和&无隙&的整合。
  SVN是一个安全虚拟网络系统,它将系统整体的信息安全功能均衡合理地分布在不同的子系统中,
  使各子系统的功能得到最大限度的发挥,子系统之间互相补充,系统整体性能大于各子系统功能之和,用均衡互补的原则解决了&木桶原理&的问题。
  SVN能在跨接Internet, Intranet, Extranet间的网络所有端点实现全面的安全,而且还能提供基于企业策略的信息管理机制以充分有效地利用有限的带宽。SVN可以满足各种企业VPN的要求,通过为公司内部网络、远程和移动用户、分支机构和合作伙伴提供基于Internet的安全连接。所以,我们可以将SVN看成是VPN、防火墙、基于企业策略的信息管理软件集成在一起的Internet安全的综合解决方案。在这样一个网络系统中,所有互联网服务器端和客户端都是安全的,并有一个信息管理机制以不断地通过这个外部网络环境动态地分析及满足客户的特定带宽需求。SVN提供了目前基于网络实现的eBusiness 应用的安全服务,它包含:
  对多种应用进行全面的安全认证;
  支持多种认证及PKI
  功能强大并对用户透明的通讯加密;
  面向用户的集中安全策略管理;
  统一跨接Internet、Intranet、Extranet的通讯。
  完整的SVN体系结构应包括以下部分:
  带有防火墙的VPN网关,它是一个将防火墙和VPN技术紧密结合的网关产品;
  SVN安全远程客户端软件包,一个功能强大的VPN客户端软件,支持台式机用户、远程用户和移动用户,具有集中化管理的个人防火墙功能和VPN用户的安全认证功能;
  SVN证书管理模块,一个用于SVN的完整PKI解决方案,它将完善的CA和LDAP目录服务器技术集成在一起;
  SVN硬件加密卡,可以通过硬件技术实现功能强大的各种算法以提高VPN的速度和性能;
  SVN智能带宽管理模块,一个基于企业策略的带宽管理解决方案,可以智能地管理有限的带宽资源,以确保用于企业重要应用的VPN性能可靠;
  SVN冗余管理模块,通过冗余网关集群和防火墙VPN内的SVN冗余模块,对执行重要任务的VPN和防火墙应用在出现故障时实现无缝切换。
  自动地址转换模块,一个自动管理IP地址和命名的解决方案,通过提供IP地址服务的跟踪和集中化管理,确保可靠地控制地址分配和提高TCP/IP管理效率;
  SVN安全服务器软件包,专门保护单个应用服务器安全的VPN网关软件,它可以保护进行敏感操作的服务器免受攻击和未授权的访问,使客户端建立与服务器间的安全认证和支持交换加密数据的连接;
  SVN安全客户端软件包,它将基于状态检测的防火墙和基于IPSec的VPN客户端软件集成在客户端机器上,通过提供集中管理的个人防火墙和对所有企业VPN用户的安全认证,增强客户端机器的安全性。它与  SVN安全远程客户端软件功能相比,增强了客户端的安全功能,如访问控制和安全初始化控制等。
Linux下SVN服务器的搭建与配置
下载最新的svn压缩包http://subversion.tigris.org/downloads/subversion-1.4.5.tar.gz
//解压SubVersion安装包 (root用户进行下面的操作)
# tar xvzf subversion-1.4.5.tar.gz
//进入解压后的目录
# cd Subversion-1.4.5
//配置subversion安装
#./configure --with-apxs=/usr/local/apache2/bin/apxs --prefix=/usr/local/subversion
--with-apr=/usr/local/apache2 --with-apr-util=/usr/local/apache2 --with-ssl --with-zlib
--enable-maintainer-mode
# make install
//创建库文件所在的目录 (svnroot用户进行下面的操作)
# mkdir /home/svnroot/repository
//进入subversion的bin目录
# cd /usr/local/subversion/bin
//创建仓库&test&
# ./svnadmin create /home/svnroot/repository/test
# cd /home/svnroot/repository/test
//看看是不是多了些文件,如果是则说明Subversion安装成功了
# cd /usr/local/subversion/bin
//这条语句将把路径/home/user/import下找到的文件导入到你创建的Subversion 仓库中去,
//提交后的修订版为1。
# ./svn import /home/user/import
//不让其他人有该目录的权限
# chmod 700 /home/svnroot/repository
修改Apache配置文件
# cd /usr/local/apadche2/bin
//启动Apache
# ./apachect1 start
# vi /usr/local/apache2/conf/httpd.conf
&& //在最下面添加
&& LoadModule dav_svn_module modules/mod_dav_svn.so
&& LoadModule authz_svn_module modules/mod_authz_svn.so
&& &Location /svn&
&& DAV svn
&& SVNParentPath /home/svnroot/repository/ //svn父目录
&& AuthzSVNAccessFile /home/svnroot/repository/authz.conf //权限配置文件
&& AuthType Basic //连接类型设置
&& AuthName &Subversion.zoneyump& //连接框提示
&& AuthUserFile /home/svnroot/repository/authfile //用户配置文件
&& Require valid-user //采用何种认证
&& &/Location&
&& //其中authfile是通过&htpasswd [&c] /home/svnroot/repository/authfile username password&来创建的
&& //&Require valid-user&告诉apache在authfile中所有的用户都可以访问。如果没有它,
&& //则只能第一个用户可以访问新建库
6. 权限管理
1)增加用户
# htpasswd [-c] /home/svnroot/repository/authfile wooin
//第一次设置用户时使用-c表示新建一个用户文件。回车后输入用户密码,完成对用户的增加
# htpasswd authfile 用户名(加入新的用户)
2)权限分配
# vi /home/svnroot/repository/authz.conf
&& [test:/] //这表示,仓库test的根目录下的访问权限
&& wooin = rw //test仓库wooin用户具有读和写权限
&& bao = r //test仓库bao用户具有读权限
&& [test2:/] //test2仓库根目录下的访问权限
&& wooin = r //wooin用户在test2仓库根目录下只有读权限
&& bao = //bao用户在 test2仓库根目录下无任何权限
&& [/] //这个表示在所有仓库的根目录下
&& * = r //这个表示对所有的用户都具有读权限
&& #[groups] //这个表示群组设置
&& #svn1-developers = wooin, bao //这个表示某群组里的成员
&& #svn2-developers = wooin
&& #[svn1:/]
= rw //如果在前面加上@符号,则表示这是个群组权限设置
将这个设置完成后。重启Apache,就可以通过
http://localhost/svn/test
这个URL来访问仓库了,当然,受权限的限制,必须是合法用户才能访问且具有相应的权限
7. 一些备忘:
1. svn checkout http://localhost/svn/hello.world
2. svn commit 时的默认编辑器的环境变量$SVN_EDITOR=vi需要手动设定,用kate好像有问题
3. 如果linux的登录用户名密码都和svn的其中一个用户名密码相同时,在checkout的时候不会要求输 入用户名密码直接就可以checkout出来。比如:linux有个用户wooin,svn也有一个用户wooin,并且密码 都是一样的,当用wooin登录linux后,执行checkout,可以直接提取出源码文件,不用输入认证信息。
4. 在svn使用过程中牵扯到几种权限:文件系统的权限,linux系统权限,svn用户的权限,apache进程的权限。
文件系统的权限,linux系统权限:这里相同的意思,就是平时大家使用linux时文件夹和文件的访问权限。在 svn建立仓库,文件夹,配置文件的时候用svnroot用户,并将仓库权限设置为700,不允许其他用户直接通过 文件系统查看,只能由svnroot进行管理。
apache进程的权限:因为所有跟仓库传输的操作都是通过apache进程进行的,所以即使你给svn用户设置了 很大的权限,但是apache进程没有访问仓库或者相关文件的权限也没有用,apache进程的权限设置在 /usr/local/apache2/conf/httpd.conf 文件中配置,找到文件中的这两行:
User daemon # 将daemon改为svnroot,让apache进程以svnroot的身份运行
Group daemon
svn用户的权限:就是在repository/authz.conf文件中设置的权限信息,是svn用来管理仓库访问权限的。
5. svn服务器设置有两种方式:http 和 svnserve。这里介绍的是http方法
6. 在/etc/profile的结尾设置一些svn启动时要做的工作 # start apache server for svn
/usr/sbin/apachectl start
export SVN_EDITOR=vi
7. APR libraries 安装 SVN 的时候最好指定 --with-apr= 和 --with-apr-util= 参数到 Apache 安装的根目录
(ServerRoot)下,而不是使用缺省的 SVN 安装包中自带的 apr 。否则如果你安装的 Apache
版本不同有可能导致 APR 库不匹配,出现类似:
Can't set position pointer in file '/svn/test/db/revs/1': Invalid argument 的错误。
16:30 -- 比如说如果你安装的是apache 2.2.0版本,就需要在编译安装svn的时候指定
--with-apxs和--with-apr参数到你的apache2.2.0安装目录下:
./configure --divfix=${subversionInstallFolder} /
--with-apxs=${apacheInstallFolder}/bin/apxs /
--with-apr=${apacheInstallFolder} /
--with-apr-util=${apacheInstallFolder} /
--with-ssl /
--with-zlib /
--enable-maintainer-mode
转自:/fengjian2000/blog/item/98ad781fc106ac.html
后参与讨论
来吧!这里永远都充满阳光!
阅读:5514
阅读:6142
阅读:6983
阅读:8246系统环境:CentOS-6.3
安装方式:yum install (源码安装容易产生版本兼容的问题)安装软件:系统自动下载SVN软件
检查已安装版本
#检查是否安装了低版本的SVN
rpm -qa subversion
#卸载旧版本SVN
yum remove subversion
一.安装SVN
yum -y install subversion
检验已经安装的SVN版本信息
svnserve --version
代码库创建
SVN软件安装完成后还需要建立SVN库
mkdir -p /www/svndata
svnadmin create /www/svndata/test
执行上面的命令后,自动建立svndata库,查看/www/svndata/test 文件夹发现包含了conf, db,format,hooks, locks, README.txt等文件,说明一个SVN库已经建立。
配置代码库
进入上面生成的文件夹conf下,进行配置
cd /www/svndata/test/conf
用户密码passwd配置
cd /www/svndata/test/conf
vim passwd
修改passwd为以下内容:
# harry = harryssecret
# sally = sallyssecret
cqh=123456
权限控制authz配置
目的是设置哪些用户可以访问哪些目录,向authz文件追加以下内容:
#设置[/]代表根目录下所有的资源
服务svnserve.conf配置
vim svnserve.conf
追加以下内容:
#匿名访问的权限,可以是read,write,none,默认为read
anon-access=none
#使授权用户有写权限
auth-access=write
#密码数据库的路径
password-db=passwd
#访问控制文件
authz-db=authz
#认证命名空间,subversion会在认证提示里显示,并且作为凭证缓存的关键字
realm = My First Repository
svnserve -d -r /www/svndata
查看SVN进程
[root@localhost conf]# ps -ef|grep svn|grep -v grep
00:00:00 svnserve -d -r /www/svndata
检测SVN 端口
[root@localhost conf]# netstat -ln |grep 3690
0 0.0.0.0:3690
停止重启SVN
[root@localhost password]# killall svnserve
[root@localhost password]# svnserve -d -r /www/svndata // 启动
SVN服务已经启动,使用客户端测试连接。
客户端连接地址:svn://xxx.xxx.xxx.xxx/test
用户名/密码: cqh/123456
测试创建文件夹等操作。
二.设置钩子自动更新
实现SVN与WEB同步,可以CO一个出来,也可以直接用自动更新web目录的方法,我们要在svn版本库中配置钩子来实现,就是创建一个post-commit的配置文件,对其进行简单的配置,简简单单的四步就可以实现Linux下SVN自动更新web目录配置。 第一步:建立你的web程序目录
mkdir /var/www/html/test
进入你建立的web程序目录(svn checkout可以简写为co)
svn checkout svn://localhost/svntest //不重命名文件夹,直接在当前目录下检出
svn checkout svn://localhost/svntest test //检出文件并且重命名文件夹
&第二步:在项目库的 hooks/ 目录下新建 post-commit 文件 【钩子脚本】
添加脚本内容如下
export LANG=en_US.UTF-8
SVN=/usr/bin/svn
#这里配置的是svn安装bin目录下的svn文件
WEB=/var/www/html/test
#要更新的目录
$SVN update $WEB --username cqh --password 123456
chown -R www:www
其中SVN=右边改成 svn 命令位置 WEB=右边改成你实际的web目录
第三步:让post-commit有执行的权限
chmod a+x post-commit
第四步:这里就已经完成了,第四步就是测试了。
说明: export LANG=en_US.UTF-8是为了解决svn post commit 中文乱码,设置本地化编码,因为我的系统为UTF8编码,其实SVN默认就是UTF-8编码,如果编码是GBK的话不设置将会出现错误,而执行不成功,错误标识为
svn: Can't convert string from native encoding to 'GBK'
/usr/bin/svn update --username cqh --password 123456 /var/www/html/test 执行更新操作 如果提示:
post-commit hook failed (exit code 255) with no output
赋予post-commit文件可执行权限 如果您的默认编码就是UTF-8的,要上传中文文件,先将文件另存为UTF-8格式在提交
阅读(...) 评论()linux下svn客户端安装及环境配置
linux下svn客户端安装及环境配置
一、svn客户端安装.
如果所在的linux机器上没有安装svn客户端,则首先安装svn客户端:(注意要使用root权限)
1. subversion-1.5.9.tar.bz2&
subversion-deps-1.4.3.tar.bz2
tar zxpvf subversion-1.5.9.tar.gz
tar xvfj subversion-deps-1.5.9.tar.bz2
解压这两个文件(不要乱了顺序),此时在当前目录下会出现subversion-1.5.9文件夹,
3. 进入subversion-1.5.9文件夹:
# cd subversion-1.5.9
#./configure
# make #编译
ps: 我第一次在安装后执行编译命令报错了:
make: *** [subversion/libsvn_ra_dav/libsvn_ra_dav-1.la] 错误 1
最后换了一个版本的subversion就好了 但是这两个记得配套
install&&&&&&
安装好客户端之后, 默认安装目录是/usr/local/subversion-1.5.9.
4. 将svn命令链接到/usr/local/bin目录下(需要root权限):
ln &s /usr/local/subversion/bin/svn /usr/local/bin
测试是否已经可以在用户目录下使用svn:
svn help 如果出现命令列表,则表示已经链接成功。&
svn客户端安装成功
5.做到这里基本svn的安装就ok了,下面我们来配置svn
1.建立版本库目录(这个和安装目录请区分开,以下讲的是版本库)
[root@DB2 subversion-1.5.9]# mkdir -p /opt/svndata/game
2 建立svn版本库
[root@DB2 subversion-1.5.9]# svnadmin create
/opt/svndata/game/
执行此命令后svn自动在repos目录下添加必须的配置文件.
[root@DB2 subversion-1.5.9]# ls /opt/svndata/game/
conf db format hooks locks README.txt
注意:版本库不同于一般的文件夹, 直接在操作系统上新建文件无法被SVN识别,
必须使用import等命令将文件导入版本库.此为svn内部指令,create用于新建版本库。请使用svn
help查看详细说明。
修改版本库配置文件
[root@DB2 conf]# vi /opt/svndata/game/conf/svnserve.conf
各参数功能在配置文件的注释中有说明, 此处配置如下:
anon-access = none # 使非授权用户无法访问
auth-access = write # 使授权用户有写权限
password-db = passwd # 指明密码文件路径
authz-db = authz # 访问控制文件
realm = /opt/svndata/game #
认证命名空间,subversion会在认证提示里显示,并且作为凭证缓存的关键字。
其它采用默认配置. 各语句都必须顶格写, 左侧不能留空格, 否则会出错.
指令简介:这是svn配置文件的格式,请按照以上格式书写。
4&&& 配置用户
[root@DB2 conf]# vi /opt/svndata/game/conf/passwd
插入如下内容
user = 123456
root = 123456
可以添加多个,此为用户名密码对。
5&&& 配置权限
[root@DB2 conf]# vi /opt/svndata/game/conf/authz
插入以下内容&
列出对各用户的授权。包括只读r,读写rw。没有列出的用户,则不允许访问。还可以对用户分组,具体请参考svn手册
6&&& 启动svn
[root@DB2 conf]# svnserve -d -r /opt/svndata/game/
指令简介:此指令用于启动svn服务,-d指明以守护模式运行,svn自动在3690端口监听。3690是默认端口,可以使用“--
listen-port=”或者“--listen-host=”来指定其它
端口。-r选项用来指定svn服务的根目录,这样用户就可以使用相对路径访问,而不用提供完整路径。
7. 检查端口
[root@DB2 conf]# netstat -ntlp|grep 3690
tcp&&&&&&&
0.0.0.0:3690&&&&&&&&&&&&&&&
0.0.0.0:*&&&&&&&&&&&&&&&&&&
LISTEN&&&&&
15087/svnserve
到此svn搭建配置完毕,可以在客户端进行连接使用。
三、导入所需svn地址的工程
执行命令:
svn --username=用户名 --password 密码 co svn地址&
/root/svn/(目标目录)
已投稿到:
以上网友发言只代表其个人观点,不代表新浪网的观点或立场。

我要回帖

更多关于 linux svn安装路径 的文章

 

随机推荐