Linux SVN 服务器需先安装 Subversion,配置仓库路径、用户权限等,通过
Linux系统上搭建SVN服务器,能够为团队提供集中的版本控制服务,方便代码的管理和协作,以下是详细的搭建步骤:
安装SVN软件
- Ubuntu/Debian系统:使用apt-get命令进行安装,首先更新软件包列表,然后执行安装命令。
sudo apt-get update
sudo apt-get install subversion
- CentOS/RHEL系统:使用yum或dnf命令进行安装,对于较新的CentOS版本,可能需要使用dnf命令替代yum。
sudo yum install subversion
或sudo dnf install subversion
- 验证安装:安装完成后,可以通过以下命令查看SVN版本号,确认安装成功。
svn --version
创建SVN仓库
- 选择存储位置:创建一个目录用于存放SVN仓库,建议选择一个具有足够磁盘空间、良好I/O性能且易于备份的位置,在/home目录下创建Subversion目录。
sudo mkdir /home/Subversion
- 创建仓库:使用svnadmin命令在指定目录下创建一个新的SVN仓库,创建一个名为myproject的仓库。
svnadmin create /home/Subversion/myproject
- 创建成功后,进入myproject目录,可以看到conf、db、format、hooks、locks和README.txt等文件。
配置SVN访问权限
- 编辑svnserve.conf文件:进入仓库的conf目录,编辑svnserve.conf文件,取消注释并修改以下行:
anon-access = none
:表示禁止匿名用户访问。auth-access = write
:表示授权用户具有读写权限。password-db = passwd
:指定用户名口令文件,即passwd文件。authz-db = authz
:指定权限配置文件,即authz文件。realm = /home/Subversion/myproject
:指定认证域,即仓库的根目录。
- 添加SVN用户:打开conf/passwd文件,添加SVN用户,每行格式为“用户名=密码”,
john = password123
mary = 123456
。
- 配置用户权限:编辑authz文件,设置用户的访问权限,为用户john和mary设置读写权限:
[/]
:表示根目录。john = rw
mary = rw
。
启动SVN服务器
- 启动命令:使用以下命令启动SVN服务器,其中参数“-d”表示以守护进程的方式启动,“-r”指定版本库的根目录。
svnserve -d -r /home/Subversion
- 检查是否运行:可以使用ps aux|grep svnserve命令查看SVN服务器是否正在运行,或者使用netstat -tuln | grep 3690命令检查服务器是否在监听3690端口。
客户端连接测试
- 安装客户端工具:在本地计算机上安装适用于操作系统的SVN客户端工具,如TortoiseSVN(Windows)或svn命令行工具(Linux、macOS和Windows)。
- 检出仓库:选择一个本地目录作为SVN工作副本,使用以下命令检出仓库并创建本地工作副本:
svn checkout svn://服务器IP或主机名/仓库路径
。
为了实现更灵活的权限管理和更方便的服务器管理,还可以进行以下拓展配置:
设置自启动
- 创建systemd服务单元文件:在/lib/systemd/system/目录下创建一个名为svnserve.service的文件,内容如下:
[Unit]
Description=Subversion protocol daemon
After=syslog.target network.target
[Service]
Type=forking
EnvironmentFile=/etc/sysconfig/svnserve
ExecStart=/usr/bin/svnserve --daemon --pid-file=/run/svnserve/svnserve.pid $OPTIONS
[Install]
WantedBy=multi-user.target
。
- 使配置生效:执行以下命令使服务单元文件生效,并设置SVN服务开机自启。
sudo systemctl daemon-reload
sudo systemctl enable svnserve.service
。
防火墙配置
- firewalld防火墙:对于使用firewalld的系统,使用以下命令开放3690端口。
sudo firewall-cmd --permanent --add-service=telnet
sudo firewall-cmd --permanent --add-port=3690/tcp
sudo firewall-cmd --reload
。
- iptables防火墙:对于使用iptables的系统,使用以下命令添加规则允许传入的TCP流量通过3690端口,并保存规则到配置文件中。
sudo iptables -I INPUT -p tcp --dport 3690 -j ACCEPT
sudo iptables-save | sudo tee /etc/sysconfig/iptables
sudo systemctl restart iptables
。
日志查看配置
- 编辑svnserve.conf文件:设置anon-access为none,防止未授权访问日志。
anon-access = none
。
- 编辑authz文件:添加权限,使所有用户都能查看日志。
[/]
* = r
。
以下是搭建过程中常见问题及解答:
FAQs
- 问题:SVN服务器启动后,客户端无法连接,可能是什么问题?
- 解答:可能的原因有以下几点,一是防火墙未开放3690端口,需要按照上述防火墙配置步骤开放端口;二是SVN服务器未正确启动,可使用ps aux|grep svnserve和netstat -tuln | grep 3690命令检查服务器状态和端口监听情况;三是客户端连接地址或用户名密码错误,需仔细检查连接地址、用户名和密码是否正确。
- 问题:如何为不同的项目设置不同的用户访问权限?
- 解答:可以在authz文件中进行配置,首先在文件中定义用户组,groups]部分定义admin组和dev组,每个组包含对应的用户,然后在相应的项目路径下设置用户组的权限,如[/]表示仓库根目录,可在此设置根目录的权限,@admin = rw表示admin组用户对根目录具有读写权限,@dev = r表示dev组用户对根目录具有只读权限,对于特定项目的路径,如[project1:/],可以在这里设置project1项目的权限。
各位小伙伴们,我刚刚为大家分享了有关linux svn 服务器搭建的知识,希望对你们有所帮助。如果您还有其他相关问题需要解决,欢迎随时提出哦!
原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/10410.html