百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

svn 安装配置及web管理端 svn安装方法

yuyutoo 2024-11-02 15:22 4 浏览 0 评论

一:安装包方式

搭建svn服务器

centos 7.4 搭建svn服务器

1.安装

yum -y install subversion

2.创建svn版本库目录

svnadmin create /root/svn

cd /data/Svn

svnadmin create .

3.进入conf目录(该svn版本库配置文件)

authz文件是权限控制文件

passwd是帐号密码文件

svnserve.conf SVN服务配置文件

4.设置帐号密码

vi passwd

在[users]块中添加用户和密码,格式:帐号=密码,如dan=dan

如:

SvnUser = Svn@2019

5.设置权限

vi authz

在末尾添加如下代码:

[/]

dan=rw

w=r

意思是版本库的根目录dan对其有读写权限,w只有读权限

5.修改svnserve.conf文件

vi svnserve.conf

打开下面的几个注释:

anon-access = read #匿名用户可读

auth-access = write #授权用户可写

password-db = passwd #使用哪个文件作为账号文件

authz-db = authz #使用哪个文件作为权限文件

realm = svn # 认证空间名,版本库所在目录

6.启动svn版本库

svnserve -d -r /root/svn --listen-port 8088

svnserve -d -r /data/svn --listen-port 8088

7.在windows上测试

svn://192.168.10.32:8088

输入账号密码

二:svn 配置密码加密

svn 配置密码加密

yum -y install subversion

yum install cyrus-sasl-md5 -y

svnadmin create /svndata/svn/kaiser

#svnserve -d --listen-port 8888 -r /svndata/svn/kscore

1.配置文件

svnserve.conf

修改Svn库下conf/的svnserve.conf内容

[general]

anon-access = none

auth-access = write

authz-db = authz

realm = svnjiami

[sasl]

use-sasl = true

min-encryption = 1

max-encryption =1

注释:# password-db = passwd这行保持注释掉的状态,不使用passwd文件。变量 min-encryption 和 max-encryption 控制服务器所需要的加密强度。要完全禁用加密,就将这 2 个变量的值都设为 0。要启用简单的数据校验(例如,为了防止篡改和保证数据的完整,不加密),就将这 2 个值都设为 1。如果你想允许(但不强制)加密,将最小值设为 0,最大值设为任意位数。要强制加密,将这 2 个值设为大于 1 的数字。在前面的例子中,我们要求客户端至少进行 128 位加密,但是不大于 256 位加密

/etc/sasl2/svn.conf

pwcheck_method: auxprop

auxprop_plugin: sasldb

sasldb_path: /data/svn/sasldb

mech_list: DIGEST-MD5

建立用户(meng.txt 用户密码)

saslpasswd2 -c -f /data/svn/sasldb -u meng ks -p

交互式创建:(输入密码2次)

saslpasswd2 -c -f /data/svn/sasldb -u meng ks -p

查看用户账号:

sasldblistusers2 -f /data/svn/sasldb

删除用户

saslpasswd2 -d -f /data/svn/sasldb -u meng ks

简单文件

[general]

anon-access = none

auth-access = write

password-db = passwd

authz-db = authz

[sasl]

saslpasswd2 -c -f /svndata/svn/sasldb -u kaiser $1 -p

三:svnWebUI

svnWebUI管理工具

1.拉取镜像

docker pull cym1102/svnwebui:latest

2.启动容器

docker run -itd -v /home/svnWebUI:/home/svnWebUI --privileged=true -p 6060:6060 -p 3690:3690 cym1102/svnwebui:latest

注意:

  1. 需要映射6060端口与3690端口, 6060为web网页端口, 3690为svn默认端口.
  2. 容器需要映射路径/home/svnWebUI:/home/svnWebUI, 此路径下存放项目所有数据文件, 包括数据库, 配置文件, 日志等, 升级镜像时, 此目录可保证项目数据不丢失. 请注意备份.

四:svnadminv2.0

SVNAdmin2 - 基于web的SVN管理系统

适用于:快速部署看效果

docker run -d --name svnadmintemp -p 80:80 -p 3690:3690 --privileged witersencom/svnadmin:2.5.3

#适用于:新用户正式使用

1.启动一个临时的容器用于复制配置文件出来

docker run -d --name svnadmintemp --privileged witersencom/svnadmin:2.5.3 /usr/sbin/init

2.把配置文件复制到本机的 /home/svnadmin 目录

cd /home/
docker cp svnadmintemp:/home/svnadmin ./
docker cp svnadmintemp:/etc/httpd/conf.d ./svnadmin/
docker cp svnadmintemp:/etc/sasl2 ./svnadmin/

3.删除掉临时容器

docker stop svnadmintemp && docker rm svnadmintemp

4.启动正式的容器

docker run -d -p 80:80 -p 3690:3690 \
-v /data/svnadmin/:/home/svnadmin/ \
-v /data/svnadmin/conf.d/:/etc/httpd/conf.d/ \
-v /data/svnadmin/sasl2/:/etc/sasl2/ \
--privileged \
--name svnadmin \
witersencom/svnadmin:2.5.3

svnadmin_docker.yaml

version: '2.4'
services:
  svnadmin:
    container_name: svnadmin
    image: witersencom/svnadmin:2.5.3
    volumes:
      - /data/svnadmin/:/home/svnadmin/
      - /data/svnadmin/conf.d/:/etc/httpd/conf.d/
      - /data/svnadmin/sasl2/:/etc/sasl2/
      - /etc/localtime:/etc/localtime:ro
    privileged: true
    ports:
      - "8080:80"
      - "3690:3690"
    networks:
      - monitor
    restart: 'always'
    extra_hosts:
      - "svn.meta.com:192.168.10.14"      
networks:
  monitor:
    external: true

nginx 仅配置http

nginx_docker.yaml

version: '3.8'
services:
  nginx:
    image: nginx:1.22.1
    container_name: nginx
    volumes:
      - /data/nginx/conf:/etc/nginx/conf.d
      - /data/nginx/logs:/var/log/nginx
      - /data/nginx/ssl:/etc/nginx/ssl
      - /etc/localtime:/etc/localtime:ro
    ports:
      - "80:80"
      - "443:443"
    networks:
      - monitor 
networks:
  monitor:
    external: true
    name: monitor

#/data/nginx/conf/svn.meta.com.conf
server {
    #listen       443 ssl;
    listen       80;
    server_name  svn.meta.com;

    access_log  /var/log/nginx/svn.meta.com.access.log  main;
    error_log   /var/log/nginx/svn.meta.com.error.log   notice;

    #ssl_certificate     /etc/nginx/ssl/meta.com.pem;
    #ssl_certificate_key  /etc/nginx/ssl/meta.com.key;

    client_max_body_size 200m;

    location / {
        proxy_pass http://192.168.10.14:8080;
    }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
}

#server {
#    listen       80;
#    server_name  svn.meta.com;
#    return 301 https://svn.meta.com$request_uri;
#}

#进程


5.进入容器内进行文件授权

docker exec -it svnadmin bash
chown -R apache:apache /home/svnadmin

6.UI访问

默认账号密码:admin / admin


#备份

svnadmin dump test > test.dump

#恢复

还原会清空SVN仓库的原有数据

svnadmin load test < test.dump

##数据恢复,

#数据备份,/home/svnadmin/backup/

#数据路径,/home/svnadmin/rep/

#权限及配置相关,/home/svnadmin/authz,/home/svnadmin/httpPasswd,/home/svnadmin/svnadmin.db



svnadmin create umiArt

svnadmin load /home/svnadmin/rep/umiArt < rep_umiArt_20230613113809.dump


1. 导出:
svnadmin dump F:/workspace/Shanfeng/fireweb >fireweb
2. 创建新目录:
svnadmin create ./opt/svn/fireweb
3. 导入:
svnadmin load /opt/svn/fireweb </opt/fireweb
4. 重新定位svn地址到新地址

启动svn服务:
svnserve -d -r /opt/svn
停止svn服务:
killall svnserve

#add by shiye 2023.06.13

3 3 * * * cd /data/backup;/bin/sh svnbak.sh >>/dev/null 2 >&1

四:其他web网页版本工具

iF.SVNAdmin,Submint

相关推荐

【Socket】解决UDP丢包问题

一、介绍UDP是一种不可靠的、无连接的、基于数据报的传输层协议。相比于TCP就比较简单,像写信一样,直接打包丢过去,就不用管了,而不用TCP这样的反复确认。所以UDP的优势就是速度快,开销小。但是随之...

深入学习IO多路复用select/poll/epoll实现原理

Linux服务器处理网络请求有三种机制,select、poll、epoll,本文打算深入学习下其实现原理。0.结论...

25-1-Python网络编程-基础概念

1-网络编程基础概念1-1-基本概念1-2-OSI七层网络模型OSI(开放系统互联)七层网络模型是国际标准化组织(ISO)提出的网络通信分层架构,用于描述计算机网络中数据传输的过程。...

Java NIO多路复用机制

NIO多路复用机制JavaNIO(Non-blockingI/O或NewI/O)是Java提供的用于执行非阻塞I/O操作的API,它极大地增强了Java在处理网络通信和文件系统访问方面的能力。N...

Python 网络编程完全指南:从零开始掌握 Socket 和网络工具

Python网络编程完全指南:从零开始掌握Socket和网络工具在现代应用开发中,网络编程是不可或缺的技能。Python提供了一系列高效的工具和库来处理网络通信、数据传输和协议操作。本指南将从...

Rust中的UDP编程:高效网络通信的实践指南

在实时性要求高、允许少量数据丢失的场景中,UDP(用户数据报协议)凭借其无连接、低延迟的特性成为理想选择。Rust语言凭借内存安全和高性能的特点,为UDP网络编程提供了强大的工具支持。本文将深入探讨如...

Python 网络编程的基础复习:理解Socket的作用

计算机网络的组成部分在逻辑上可以划分为这样的结构五层网络体系应用层:应用层是网络协议的最高层,解决的是具体应用问题...

25-2-Python网络编程-TCP 编程示例

2-TCP编程示例应用程序通常通过“套接字”(socket)向网络发出请求或者应答网络请求,使主机间或者一台计算机上的进程间可以通信。Python语言提供了两种访问网络服务的功能。...

linux下C++ socket网络编程——即时通信系统(含源码)

一:项目内容本项目使用C++实现一个具备服务器端和客户端即时通信且具有私聊功能的聊天室。目的是学习C++网络开发的基本概念,同时也可以熟悉下Linux下的C++程序编译和简单MakeFile编写二:需...

Python快速入门教程7:循环语句

一、循环语句简介循环语句用于重复执行一段代码块,直到满足特定条件为止。Python支持两种主要的循环结构:for循环和while循环。...

10分钟学会Socket通讯,学不会你打我

Socket通讯是软硬件直接常用的一种通讯方式,分为TCP和UDP通讯。在我的职业生涯中,有且仅用过一次UDP通讯。而TCP通讯系统却经常写,正好今天写了一个TCP通讯的软件。总结一下内容软件使用C#...

Python 高级编程之网络编程 Socket(六)

一、概述Python网络编程是指使用Python语言编写的网络应用程序。这种编程涉及到网络通信、套接字编程、协议解析等多种方面的知识。...

linux网络编程Socket之RST详解

产生RST的三个条件:1.目的地为某端口的SYN到达,然而该端口上没有正在监听的服务器;2.TCP想取消一个已有的连接;3.TCP接收到一个根本不存在的连接上的分节;现在模拟上面的三种情况:cl...

ABB机器人编程实用技巧,多项案例

...

Python中实现Socket通讯(附详细代码)

套接字(socket)是一种在计算机网络中进行进程间通信的方法,它允许不同主机上的程序通过网络相互通信。套接字是网络编程的基础,几乎所有的网络应用程序都使用某种形式的套接字来实现网络功能。套接字可以用...

取消回复欢迎 发表评论: