linux安装svn服务器的两种方式(转载)
操作环境:CentOS 7.2 64位第一种:采用压缩包安装:比如你们公司服务器上安装软件有自己的规定,一般会采用压缩包安装。第一步:SVN服务器端压缩包下载下载地址:http://mirrors.cnnic.cn/apache/subversion/我下载的是subversion-1.8.19版本,下载好的压缩包置于目录 /usr/local/java/svn 下(根据大家实际需要自行选择存放目
操作环境:CentOS 7.2 64位
第一种:采用压缩包安装:比如你们公司服务器上安装软件有自己的规定,一般会采用压缩包安装。
第一步:SVN服务器端压缩包下载
下载地址:http://mirrors.cnnic.cn/apache/subversion/
我下载的是subversion-1.8.19版本,下载好的压缩包置于目录 /usr/local/java/svn 下(根据大家实际需要自行选择存放目录)。
第二步:解压,进入解压后的文件
在/usr/local/java/svn目录下执行下面两个命令:
[]# tar -zxvf subversion-1.8.15.tar.gz
[]#cd subversion-1.8.19/
第三步:编译并安装
A.在/usr/local/java/svn/subversion-1.8.19目录下执行下面命令:
先执行命令:# ./configure,看看有没有报错,
(1)如果没有报错则跳过下面的B步骤;
(2)如果有报错则看下面的B步骤安装依赖包,每安装完一个依赖包,就要在# ./configure 命令后面追加 --with参数并再次运行加了with参数的configure命令。
如果我只安了一个apr依赖包,那么就执行命令:
[]#./configure --with-apr=/usr/local/apr命令;
如果我安了apr和apr-util,那么就执行命令:
[]#./configure --with-apr=/usr/local/apr
–with-apr-util=/usr/local/apr 命令;
如果下面的依赖包全安了,就执行下面的命令:
[]#./configure --with-apr=/usr/local/apr
–with-apr-util=/usr/local/apr
–with-serf=/usr/local/serf
–with-openssl
B.如果报错,提示缺少某某依赖包,缺什么就在此步B中找到相应依赖包下载下来放到/usr/local/java/svn/dependPackage目录下,解压并安装。:
1、 缺少apr模块(1.5.1)
官网URL:http://apr.apache.org/
安装命令:
[]# tar zxvf apr-1.5.1.tar.gz
[]# cd apr-1.5.1
[]# ./configure --with-apr=/usr/local/apr
[]# make && make install
2、 缺少apr-util模块(1.6.1)
官网URL:http://apr.apache.org/
安装命令:
[]# tar zxvf apr-util-1.6.1.tar.gz
[]# cd apr-util-1.6.1
[]# ./configure --with-apr=/usr/local/apr
[]# make && make install
3.如果报错:fatal error: expat.h: No such file or directory
解决方法如下:
yum install expat-devel
4、 sqlite-amalgamation-3230100
官网URL:http://www.sqlite.org/download.html
解压到subversion目录下,解压后目录名为sqlite-amalgamation:
[]# unzip sqlite-amalgamation-3230100.zip -d …/subversion-1.8.15
[]# mv …/subversion-1.8.15/sqlite-amalgamation-3230100 …/subversion-1.8.10/sqlite-amalgamation
5、 缺少zlib模块(1.2.11)
官方网站:http://www.zlib.net/
安装命令:
[]# tar zxvf zlib-1.2.11.tar.gz
[]# cd zlib-1.2.11
[]# ./configure
[]# make && make install
6、 缺少openssl模块(1.0.1h)
官方网站:http://www.openssl.org/
安装命令:
[]# tar zxvf openssl-1.0.1h.tar.gz
[]# cd openssl-1.0.1h
[]# ./config
[]# make &&make install
7、 缺少expat模块(2.1.0)
官方网站:http://sourceforge.net/projects/expat/files/expat/2.1.0/
安装命令:
[]# tar zxvf expat-2.1.0.tar.gz
[]# cd expat-2.1.0
[]# ./configure
[]# make &&make install
8、 缺少serf模块(1.2.1)
官网URL:http://serf.googlecode.com/files/serf-1.2.1.tar.bz2
由于google官网受限,很难下载该模块。CSDN共享的下载地址:
http://download.csdn.net/detail/attagain/8071513
说明:
(1)1.8版本之前的需要加neon,1.8版本之后弃用neon而改使用serf;
(2)这里使用的是serf-1.2.1,据subversion 1.8版本使用serf-1.3.0会有异常
安装命令:
[]# tar xjvf serf-1.2.1.tar.bz2
[]# cd serf-1.2.1
[]# ./configure
[]# make && make install
C.在/usr/local/java/svn/subversion-1.8.19目录下执行下面命令:
[]# make && make install
第四步:SVN版本库的建立
A.我选择的目录是 /home/svn/作为SVN版本库的根目录,命令为:
[]# mkdir /home/svn
B.比如,现在我有一个名为“project”的项目需要用SVN做版本管理,那么我可以在svn根目录下建立一个 /project目录,我最终目的想让项目托管到/project目录下。接下来我需要新建这个目录:/home/svn/project
,命令为:
[]# mkdir -p /home/svn/project
C.然后需要将/project目录设定为版本库,命令如下:
[]# svnadmin create /home/svn/project
D.设定/project目录为版本库后,会发现/project目录下会多出以下文件:
第五步:svn服务器的相关配置:
svn的配置主要就是对conf目录下的三个文件配置:svnserve.conf、passwd、authzs。
A.对着三个配置文件的讲解
a.svnserve.conf文件讲解
[general]配置段中配置行格式: <配置项> = <值> ,常用的配置项是以下5项:
(1)anon-access控制非鉴权用户访问版本库的权限。取值范围为”write”、”read”和”none”。即”write”为可读可写,”read”为只读,”none”表示无访问权限。
缺省值:read
(2)auth-access控制鉴权用户访问版本库的权限。取值范围为”write”、”read”和”none”。即”write”为可读可写,”read”为只读,”none”表示无访问权限。
缺省值:write
(3)password-db 指定用户名口令文件名。除非指定绝对路径,否则文件位置为相对conf 目录的相对路径。
缺省值:passwd
(4)authz-db 指定权限配置文件名,通过该文件可以实现以路径为基础的访问控制。除非指定绝对路径,否则文件位置为相对conf目录的相对路径。
缺省值:authz
(5)realm 指定版本库的认证域,即在登录时提示的认证域名称(就是个作为提示用的,不用太纠结)。
b.passwd文件讲解
用户名口令文件,该文件名在文件svnserve.conf中指定,缺省为同目录下的passwd。
该文件仅由一个[users]配 置段组成。
[users]配置段的配置行格式如下: <用户名> = <口令> ,注意:配置行中的口令是未经过任何处理的明文。
例:用户名口令文件conf/passwd的内容如下,配置了两个用户,用户名分别为”quanran”和”dongxuening”。其中”quanran”用户的口令为”111111”,”dongxuening”用户的口令为”222222”:
[users]
quanran = 111111
dongxuening = 222222
c.authzs文件讲解
权限配置文件,该文件名也在文件svnserve.conf中指定,缺省为同目录下的authz。
该配置文件由一个[groups]配置段和 若干个版本库路径权限段组成。
[groups]配置段中配置行格式如下:
<用户组> = <用户列表>
用户列表由若干个用户组或用户名构成,用户组或用户名之间用逗号”,”分隔,引用用户组时要使用前缀”@”(如:引用用户组”all”要使用字符 串”@all”)。
版本库路径权限段的段名格式如下:
[<版本库名>:<路径>]
如版本库abc路径/tmp的版本库路径权限段的段名为”[abc:/tmp]”。
可省略段名中的版本库名。若省略版本库名,则该版本库路径权限段对所有版本库中相同路径的访问控制都有效。如:段名为”[/tmp]”的版本库路径权限段 设置了所有引用该权限配置文件的版本库中目录”/tmp”的访问权限。
版本库路径权限段中配置行格式有如下三种:
<用户名> = <权限>
<用户组> = <权限>
- = <权限>
其中,”*”表示任何用户;权限的取值范围为”、’r’和’rw’,”表示对该版本库路径无任何权限,’r’表示具有只读权限,’rw’表示有读写权 限。
注意:每行配置只能配置单个用户或用户组。
例3:权限配置文件conf/authz的内容如下:
[groups]
g_admin = admin,zhangsan
[admintools:/]
@g_admin = rw
- =
[test:/home/zhangsan]
zhangsan = rw
- = r
在上述配置文件中,定义了一个用户组”g_admin”,该用户组包含用户”admin”和”zhangsan”。然后定义了2个版本库路径权限段。其中, 版本库”admintools”只有用户组”g_admin”可读写,其他用户无任何权限;版本库”test”中路径”/home/zhangsan”只有 用户”zhangsan”有读写权限,其他用户只有可读权限。
B.言归正传!开始配置!
(1)配置svnserve.conf
[general]
anon-access = none
auth-access = write
password-db = passwd
authz-db = authz
备注:vi命令编辑svnserve.conf,insert进入编辑模式,放开以上选项,ESC :wq保存。设置非鉴权用户无权访问、设置鉴权用户可读写、口令及权限配置参照conf目录下passwd和authz的配置。
重要提醒!!:首行不可以留空,要顶行,否则会造成SVN识别为配置错误。
(2)配置passwd
[users]
rokay = 123456
备注:配置了一个用户为“rokay”,密码为“123456”的用户。
(3)配置authz
[groups]
g_admin = rokay
[/]
@g_admin = rw
*=
备注:配置了一个管理员群组“g_admin”,包含用户“rokay”;
“[/]”表示对根目录“trunk”的权限配置。
配置了“g_admin”群组对于该目录下的权限为“rw“(读、写)权限。
- = 配置了除群组”g_admin“外的其他用户均无权访问。
注意:也可以用“,”分隔多个用户或者@+群组名称的方式配置多用户,参看上方说明。
(4)综上,就完成了对三个文件也就是svnserve的配置了。
第六步:启动svn服务
输入命令:# svnserve -d -r /home/svn
注意:/svn目录为版本库的根目录,所以路径仅到/svn即可。
此时,SVN服务器的配置以及版本库已经建立完成!
第七步:SVN Windows客户端访问
访问地址:svn://[服务器IP地址]/[项目名称];
例如:svn://123.206.73.117/project/
输入已授权的用户信息登录即可访问资源位置。
同样的,可以通过右击项目[team]—[share],输入以上URL将项目共享至新建的SVN版本库中。
注意:上述地址中没有”/svn”这一级目录,”/svn”为版本库根目录,不用输入!!!
第八步:新建多个版本库
若要在/svn目录下添加新的版本库,直接新建相应的目录,然后设置为版本库,最后配置即可,不需要重新运行svnserve -d -r /home/svn,也不需要把该命令应用到/svn目录下你所新建的目录,如果因为误操作执行了以上命令,会导致资源库不可用,再次运行svnserve -d -r /home/svn也会报:“不能绑定服务器套接字 地址已在使用”的错误字样“(若已至此,删除掉新建的资源库,并用ps -ef | grep svnserve查看进程,kill -9 [进程号] 杀掉,重新执行svnserve -d -r /home/svn,再次新建资源库,直接配置即可使用)
比如在/svn目录下另外新建一个project2的资源库,命令如下:
[]# mkdir -p /home/svn/project2
[]# svnadmin create /home/svn/project2
:# 在次配置当前版本库的三个配置文件:svnserve.conf、passwd、authzs。
(不需再运行svnserve -d -r /home/svn !!!)
第九步:一切搞定,OK啦!
=第二种:yum安装方式。优点:简单,一键安装,不用手动配置环境变量等。缺点:安装位置为yum默认=
一、yum安装subversion
1. 安装subversion yum install subversion
2. 查看安装版本,检查安装是否成功 svnserve --version ,我装的版本为 1.7.14
3. 查看安装位置 rpm -ql subversion
二、创建版本库
1.创建用于存放版本库的目录,比如我准备在/home下创建版本库 mkdir -p /home/svn/
2.创建svn版本库,指定为刚才创建的目录 svnadmin create /home/svn/porject
3.创建完后,版本库目录下会生成一些文件,进入conf目录下。conf目录中authz文件是权限控制文件,passwd是帐号密码文件,svnserve.conf是SVN服务配置文件。
修改svnserver.conf文件:
[general]
anon-access = none #匿名用户可读
auth-access = write #授权用户可写
password-db = passwd #使用哪个文件作为账号文件
authz-db = authz #使用哪个文件作为权限文件
4.修改passwd文件,加入用户,格式就是“用户名=密码”,如:
quanran = 11
dongxuening = 22
5.修改authz文件,加入用户权限:
[/]
quanran = rw
dongxuening = r
这就表示quanran 用户对版本库根目录有读写权限(即最高权限了),而dongxuening 用户对版本库目录只有读的权限。
6.svnserve.conf里面常用的配置有设置匿名用户(默认可读)、授权用户(默认读写)的读写权限,以及指定账号文件(默认passwd)、权限文件(默认authz)的路径等。看起来应该默认值就够了,但实际使用发现还是得手动把相关注释打开,不知道是什么原因。
7.启动svn版本库 svnserve -d -r /home/svn/
其中,-r的作用是设置根目录路径,比如我这样设置后在访问时输入svn://x.x.x.x/就会直接到我的svn目录下(当然在svn目录下是找不到版本库的),如果想访问版本库则输入svn://x.x.x.x/Code即可。
换句说话,如果启动版本库时命令为svnserve -d -r /home/svn/,则访问svn://x.x.x.x/就能直接到版本库内。
三、常见问题
1.注意打开端口的访问权限。svn服务的默认端口为3690,比如我部署在阿里云服务器上,必须先在阿里云控制台打开3690端口的外部访问权限。
2.关闭svn服务的方式是杀掉进程,kill pid或者pkill svnserve
————————————————
版权声明:以上文为CSDN博主「全冉」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_23167527/article/details/80182317
解决SVN 无法连接到服务器问题
问题描述:
1、由于目标计算机积极拒绝,无法连接
2、由于连接方在一段时间后没有正确答复或连接
解决方法
1、svn 未启动,启动svn: svnserve -d -r ‘svn的仓库路径’
2、防火墙原因,开放svn端口: 添加3690端口
问题描述
报No repository found in … …错误
解决方法
1、原因是svn指定运行仓库路径错误
2、查看svn进程:ps -aux|grep svn
root 28813 0.0 0.0 166804 936 ? Ss 11:50 0:00 svnserve -d -r /mnt/svn
root 29456 0.0 0.0 112640 960 pts/0 S+ 13:14 0:00 grep --color=auto svn
如果 svnserve -d -r /mnt/svn 指定的仓库路径与实际仓库路径不匹配,杀掉该进程后重新指定正确的仓库路径
3、本人服务器实际仓库路径是 /mnt/svn/repos,杀死进程:kill -9 28813
4、重新启动SVN,指定正确SVN仓库路径:svnserve -d -r /mnt/svn/repos
5、查看svn进程:ps -aux|grep svn
root 28813 0.0 0.0 166804 936 ? Ss 11:50 0:00 svnserve -d -r /mnt/svn/repos
root 29456 0.0 0.0 112640 960 pts/0 S+ 13:14 0:00 grep --color=auto svn
访问SVN成功!
————————————————
版权声明:本文为CSDN博主「止木」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/u011050607/article/details/79456915
linux操作防火墙,添加服务、端口
操作防火墙,添加或删除端口,需要root权限。
- 查看防火墙状态:systemctl status firewalld
active(running):开启状态,正在运行中
inactive(dead):关闭状态,未在运行 - 开启防火墙:systemctl start firewalld,没有任何提示,表示开启成功
- 关闭防火墙:systemctl stop firewalld
- 添加mysql服务到防火墙,并加载
firewall-cmd --permanent --zone=public --add-service=mysql
firewall-cmd --reload - 打开防火墙的udp 8089端口
firewall-cmd --zone=public --add-port=8089/udp --permanent
#添加端口(–permanent表示永久生效,没有此参数重启后失效)
firewall-cmd --reload 这个命令必须运行,才能加载成功 - 查看udp 8089端口是否添加成功,查询端口开启情况
firewall-cmd --zone=public --query-port=8089/udp
- 删除防火墙8086端口
firewall-cmd --zone=public --remove-port=8086/tcp --permanent
firewall-cmd --reload
更多推荐
所有评论(0)