Stars: 202
Forks: 46
Pull Requests: 1
Issues: 27
Watchers: 6
Last Updated: 2023-08-23 03:48:02
基于web的SVN管理系统,支持HTTP协议、SVN协议、支持LDAP认证、Docker部署
License: GNU General Public License v3.0
Languages: Vue, JavaScript, EJS, Less, PHP, Shell, CSS, HTML
SVNAdmin2 是一款通过图形界面管理服务端SVN的web程序。
正常情况下配置SVN仓库的人员权限需要登录到服务器手动修改 authz 和 passwd 两个文件,当仓库结构和人员权限上了规模后,手动管理就变的非常容易出错,本系统能够识别人员和权限并提供管理和拓展功能。
SVNAdmin2 支持SVN协议检出、HTTP协议检出,并且支持两种协议之间互相切换,支持docker部署或源码部署。
SVNAdmin2 支持进行LDAP的接入,进而达到使用原有的人员架构和分组规则的目的。
问题求助、功能建议、更新计划、SVN技术讨论,可加QQ群:633108141
项目演示地址:http://svnadmin.witersen.com (管理人员/admin/admin)
系统截图
docker > CentOS7 > CentOS8 > Rocky > Ubuntu>...........
Windows下如有需求,可使用 docker 版本
PHP版本:[php5.5 , php8.2] (开发基于php7.4所以推荐使用php7.4)
数据库:SQLite、MySQL
Subversion:1.8+
ps:镜像默认托管在docerhub,如果速度不佳,可以选择国内路线(docker pull registry.cn-hangzhou.aliyuncs.com/witersencom/svnadmin:[镜像版本号])
此方式可快速部署程序体验效果,数据不存储在宿主机,生产环境使用请看3.2
docker run -d --name svnadmintemp -p 80:80 -p 3690:3690 --privileged witersencom/svnadmin:2.5.6
docker run -d --name svnadmintemp --privileged witersencom/svnadmin:2.5.6 /usr/sbin/init
/home/svnadmin
目录cd /home/
docker cp svnadmintemp:/home/svnadmin ./
docker cp svnadmintemp:/etc/httpd/conf.d ./svnadmin/
docker cp svnadmintemp:/etc/sasl2 ./svnadmin/
docker stop svnadmintemp && docker rm svnadmintemp
docker run -d -p 80:80 -p 3690:3690 \
-v /home/svnadmin/:/home/svnadmin/ \
-v /home/svnadmin/conf.d/:/etc/httpd/conf.d/ \
-v /home/svnadmin/sasl2/:/etc/sasl2/ \
--privileged \
--name svnadmin \
witersencom/svnadmin:2.5.6
docker exec -it svnadmin bash
chown -R apache:apache /home/svnadmin
ps: 2.4.3 及之前的用户要注意目录挂载多了 conf.d sasl2 升级之前要提前复制出来
svnadmin = web系统 + 后台进程,因此安装注意噢
yum install -y zip unzip wget vim which
yum install -y cyrus-sasl cyrus-sasl-lib cyrus-sasl-plain
yum install -y epel-release yum-utils
rpm -Uvh https://mirrors.aliyun.com/remi/enterprise/remi-release-7.rpm
yum-config-manager --enable remi-php74
yum install -y php php-common php-cli php-fpm php-mysqlnd php-mysql php-pdo php-process php-json php-gd php-bcmath php-ldap php-mbstring
yum install -y httpd mod_dav_svn mod_ldap
systemctl start httpd
systemctl enable httpd
yum install -y cronie at
#启动atd(如果 ps aux | grep -v 'grep' | grep atd 的结果为空需要执行)
atd
#启动crond(如果 ps aux | grep -v 'grep' | grep crond 的结果为空需要执行)
crond
cd /var/www/html/ && wget https://gitee.com/witersen/SvnAdminV2.0/releases/download/2.5.6/2.5.6.zip
unzip 2.5.6.zip
cd /var/www/html/server/
chown -R apache:apache /var/www/html/
#选项1
php install.php
cd /var/www/html/server
#选项1或选项2
php install.php
chown -R apache:apache /home/svnadmin
手动启动后台进程(启动方式一)
#pwd
#/var/www/html/server/
#后台运行
nohup php svnadmind.php start >/dev/null 2>&1 &
#后台运行后输入exit退出一下 保证后台稳定运行
exit
#停止后台
php svnadmind.php stop
#调试模式
php svnadmind.php console
通过系统管理启动后台进程(启动方式二)
[Unit]
Description=SVNAdmin
After=syslog.target network.target
[Service]
Type=simple
ExecStart=/usr/bin/php /var/www/html/server/svnadmind.php start
[Install]
WantedBy=multi-user.target
#启动
systemctl daemon-reload
systemctl start svnadmind
#查看状态
systemctl status svnadmind
#加入开机自启动
systemctl enable svnadmind
安装方式跟手动部署类似,只是宝塔系统了很多可视化操作很方便
sudo apt-get update
sudo apt-get install -y apache2
sudo apt-get install -y php
sudo apt-get install -y php-cli
sudo apt-get install -y php-fpm
sudo a2enmod proxy_fcgi setenvif
sudo systemctl restart apache2
sudo a2enconf php7.2-fpm
sudo systemctl reload apache2
sudo apt-get install -y php-json
sudo apt-get install -y php7.2-mysql
sudo apt-get install -y php-mysql
sudo apt-get install -y sqlite3
sudo apt-get install -y php7.2-sqlite
sudo apt-get install -y php-gd
sudo systemctl restart apache2
sudo apt-get install -y subversion subversion-tools
cd /var/www/html
wget xxx.zip
unzip xxx.zip
#选项2
sudo server/install.php
chown -R apache:apache /home/svnadmin/
su root
nohup php server/svnadmind.php start &
确认之前SVN仓库的版本,如果是1.8+则无需担心,如果是1.8以下,则需要简单升级下仓库
安装本系统
执行 php server/install.php 使用内置的功能重新配置你的Subversion
将已有的一个或多个SVN仓库移动到 /home/svnadmin/rep/ 目录下
在导航SVN仓库中执行同步列表,即可识别SVN仓库
注意:如果你原来是一个仓库一套配置文件的方式,则还需要按照截图的方式稍微调整下你的配置文件。因为现在是多个仓库一套配置文件的管理方式。
系统中使用了一些多进程的方案,而这在Windows下实现需要花费更多的时间
短期内没有支持Windows部署的计划
Windows下使用可通过docker版本
#使用sqlite数据库
yum install -y sqlite-devel
cd /home/svnadmin
sqlite3 svnadmin.db
.header on
.mode column
select * from admin_users;
例如:
在 /home/svnadmin/templete/initStruct/01 下面配置第一个仓库结构模板
在 /home/svnadmin/templete/initStruct/02 下面配置第二个仓库结构模板
如果在web中创建时,如何选用默认的 /home/svnadmin/templete/initStruct/02 下面的仓库结构模板?
【解决方案】
由于时间问题,开发时并没有对此功能做更多的详细开发,因此只预留了配置文件层面的修改途径,后续会将仓库模板功能加入到web配置,无需手动命令行管理
可以通过修改 config/svn.php 中的 templete_init_struct_01 值来修改
注意配置自定义仓库模板的位置
通常的位置在 /home/svnadmin/templete/initStruct/01 下面
而不是在项目代码相关的位置
【出现问题原因】
svn的用户量和权限配置数量增加,超过了默认值
【解决方案】
修改 config/daemon.php 文件中的参数
确定以下两点
1、你的 ldap 服务器地址和端口真实有效
2、安装 svnadmin2 的机器确实可以通过 ldap 端口与你的 ldap 服务所在服务器通信
然后检查 svnadmin2 所在机器的 selinux 配置,通常 selinux 会禁止 http 连接 ldap
执行:
getsebool -a | grep ldap
如果得到以下结果:
httpd_can_connect_ldap --> off
证明需要我们手动开启 httpd_can_connect_ldap 这个选项
执行以下指令允许连接即可
setsebool -P httpd_can_connect_ldap=1
以上情况为 selinux 开启可能出现的,当关闭 selinux 后以上配置不再起作用
这种情况通常是因为源码安装过程中,少装了有关ldap 的模块或依赖,建议详细看文档
这种情况下通常是因为你的 Base DN 配置问题
假设
你的 base dn 填写为:dc=witersen,dc=com
你的 Attributes 填写为: cn
然后你过滤出用户:blue
那么 blue 作为一个 SVN 用户来登录系统的时候,系统会将 cn=blue,dc=witersen,dc=com 来作为用户 blue 的完整 dn 并且结合用户输入的密来一起请求 ldap 服务器进行校验,所以如果 blue 用户的真实 dn 是 cn=blue,ou=devGroup,dc=witersen,dc=com 就会造成同步成功登录失败的情况
参考文章:https://www.witersen.com/?p=1844
其中关于如何对接LDAP作了详细解释