前提条件:服务器上已经安装好了docker服务
具体步骤:
1.找到docker中svn镜像
docker search svn //在docker上搜索svn镜像
2.拉取svn镜像 这里使用的svn镜像为elleflorio/svn-server
docker pull elleflorio/svn-server //拉取elleflorio/svn-server镜像
//执行上述命令后再执行docker images 查看是否拉取成功
3.使用一下命令启动容器
docker run --restart always --name svn -d -v /home/data/svn:/home/svn -p 3380:80 -p 3690:3690 elleflorio/svn-server
注:
/usr/svn/repo
为宿主机的文件目录,/var/opt/svn
为容器内的文件目录--restart always
命令可以实现容器在宿主机开机时自启动-p 3690:3690
表示将宿主机的3690端口映射到容器的3690端口,此端口为svn服务的默认端口,可以根据需要自行修改
4.创建仓库和账户
您需要设置用户名和密码才能通过 WebDav 协议访问,即通过svn client连接到仓库。您可以在主机上使用以下命令:
docker exec -t svn-server htpasswd -b /etc/subversion/passwd <username> <password>
要验证一切是否正常运行,请打开浏览器并连接到http://localhost/svn
. 系统应该要求您输入用户名和密码,如果正常,则会显示一个空文件夹(还没有存储库!)。
进入容器进行配置
docker exec -it svn /bin/sh //进入容器
svnadmin create /home/svn/repos //创建名称为repos的资源仓库
- 资源仓库配置,修改svnserve.conf
[general]
anon-access = none # 匿名用户不可读写,也可设置为只读 read
auth-access = write # 授权用户可写
password-db = passwd # 密码文件路径,相对于当前目录
authz-db = authz # 访问控制文件
realm = /var/opt/svn/svn # 认证命名空间,会在认证提示界面显示,并作为凭证缓存的关键字,可以写仓库名称比如svn
- 配置账号与密码,修改 passwd文件,格式为“账号 = 密码”
[users]
# harry = harryssecret
# sally = sallyssecret
admin = 123456
- 修改 authz文件
[groups]
owner = admin
[/] # / 表示所有仓库
admin = rw # 用户 admin 在所有仓库拥有读写权限
[svn:/] # 表示以下用户在仓库 svn 的所有目录有相应权限
@owner = rw # 表示 owner 组下的用户拥有读写权限
5.配置TortoiseSVN Client的访问权限问题:
5.1 在使用 TortoiseSVN在commit的过程中,可能会出现 Error: Access to '/svn/xxxxxxx/!svn/me' forbidden 类似的错误(xxxx代表你自己的仓库名称),这时需要修改:
首先进入容器:
docker exec -it svn-server /bin/sh
修改subversion-access-control文件,与authz修改类似
vi /etc/subversion/subversion-access-control
修改内容如下:
[groups]
admin = zhy,mxc #zhy,mxc 代表创建的用户名,用逗号分隔
[/]
@admin = rw
* = r
5.2 SVN提交代码时出现can't open file 'txn-current-lock' permission denied 的原因及解决方法:
方法一:更改文件夹权限(亲测可用)
chmod -R o+rw /home/svn
方法二:(未亲测)
sudo svnserve -d -r /var/svn