linux svn+ssh,svn+ssh方式svn服务器和客户端的配置

这篇博客详细介绍了如何在Linux服务器上安装和配置SSH SVN服务器,包括创建用户、设置权限、创建仓库、配置SSH公钥以及启用权限控制。同时,提供了Windows和Linux客户端的配置步骤,包括使用Putty和TortoiseSVN进行连接和检出。整个过程旨在实现安全的代码版本控制和自动化更新。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一. 服务器安装和配置

安装ssh server和subversion

yum install -y openssh-server subversion

建立svn用户,此用户为ssh登录帐号,再建立用户主目录并设置权限

useradd svn

cd /home/svn

建立 subversion repository

mkdir /var/svn-repos

svnadmin create /var/svn-repos/topcity

chown -R svn:svn /var/svn-repos/topcity

为svnuser建立SSH公钥和私钥,svnuser就是以后用来操作的svn用户,注意它并不是linux系统用户

ssh-keygen -t rsa -b 1024 -f svnuser.key

这里可以输密码,也可以不输密码,如果是希望代码提交后,自动更新到运行环境的话,光用key方便点。否则建议根据提示输入密码,此时在当前目录下会生成二个文件,svnuser.key私钥和svnuser.key.pub公钥

mkdir /home/svn/.ssh

cat svnuser.key.pub >> /home/svn/.ssh/authorized_keys

chown -R svn:svn /home/svn/.ssh

编辑 authorized_keys 文件,在相应公钥内容的开头处加入:

vi /home/svn/.ssh/authorized_keys

command="/usr/bin/svnserve -t -r /var/svn-repos/ --tunnel-user=svnuser",no-port-forwarding,no-pty,no-agent-forwarding,no-X11-forwarding

注意上述内容和原来公钥的内容应该在同一行中

修改repository配置,并启用authz权限控制

vi /var/svn-repos/topcity/conf/svnserve.conf

在general小节中,加入三行内容

anon-access = none

auth-access = write

authz-db = /var/svn-repos/topcity/conf/authz

配置authz文件

vi /var/svn-repos/topcity/conf/authz

增加二行内容

[topcity:/]

svnuser = rw

导入项目到svn:

svn import web svn+ssh://192.168.1.10/topcity -m "initial import"

在svn服务器上配置自动更新(有需要的话):

cd /var/svn-repos/topcity/hooks

cp post-commit.tmpl post-commit

chown svn:svn post-commit

chmod a+x post-commit

vi post-commit

把其它注释掉,在最后加上:

/var/svn-repos/topcity/hooks/svnsshup.exp

服务器配置OK了,下面看看客户端应该怎么使用。

二.windows客户端配置

在windows环境下,svn+ssh方式需要用到三个软件:puttygen.exe,putty.exe,TortoiseSVN。在哪下载我就不多说了,google就是。

首先把上面生成的私key svnuser.key 复制到windows上,再用puttygen.exe转成putty用的key文件。

b2ae435a9da5

image.png

点Load选中svnuser.key,然后再点save private key,保存一个svnuser.ppk的文件。

2)在putty内配置:

Connection -> SSH -> Auth 选中刚刚转好的ppk文件

Connection -> SSH -> Data 的Auto-login username输入svn。

把Session内输入hostname和session name保存,我这边输的都是192.168.1.10。

然后打开这个Session,如果显示下面这样的提示,说明就成功了。

Authenticating with public key "imported-openssh-key"

Server refused to allocate pty

( success ( 1 2 ( ANONYMOUS EXTERNAL ) ( edit-pipeline svndiff1 absent-entries ) ) )

TortoiseSVN内配置:

TortoiseSVN -> Settings -> Network

选择TortoiseSVN安装目录下面的TortoisePlink.exe文件

checkout

先打开putty连上服务器

再用TortoiseSVN检出:url:svn+ssh://svn@192.168.1.10/topcity

注意url内的192.168.1.10并不是指ip地址,而是在putty内配置的session名。

能正常checkout出来就说明ok了。

三.linux客户端配置

在用户目录生成.subversion:

svn co

复制服务器端生成的私key过来到这目录

cd .subversion

cp ../svnuser.key .

配置config文件

vi config

在[tunnels]内增加一行:

ssh = /usr/bin/ssh -l svn -i /home/top_city/.subversion/svnuser.key

更新命令是:

cd topcity

svn up

为了提高Subversion的通信安全性,你可以通过配置svn+ssh来实现加密传输。首先,需要确保你的服务器支持SSH协议。然后,你可以在服务器上设置SSH公钥认证,具体步骤如下: 参考资源链接:[增强Subversion安全:svn+ssh与Apache+SSL](https://wenku.youkuaiyun.com/doc/6odwnqfbxx?spm=1055.2569.3001.10343) 1. 在Subversion服务器上为用户生成SSH密钥对: `ssh-keygen -t rsa -b 2048`(回车键选择默认路径,或者指定一个路径) 2. 将生成的公钥添加到用户的`~/.ssh/authorized_keys`文件中,以便用户可以通过SSH认证。 3. 在客户端配置Subversion使用svn+ssh协议,需要将客户端的公钥复制到服务器用户的`~/.ssh/authorized_keys`文件中。 4. 在Subversion的配置文件`svnserve.conf`中进行如下设置: - 设置`password-db`指向用户认证信息文件。 - 如果使用的是authz_svn模块,还需要设置`authz-db`指向权限文件。 5. 确保`authz`文件中正确设置了用户权限,如: ``` [/] linuxing = rw root = r ``` 这样`linuxing``root`用户就可以分别对版本库进行读写读操作。 6. 启动svnserve服务,并指定配置文件的路径,例如: `svnserve -d -r /path/to/repos --config-file=/path/to/svnserve.conf` 7. 最后,用户可以使用svn+ssh协议连接Subversion服务器,命令如下: `svn co svn+ssh://username@serverip/path/to/repos` 通过以上步骤,你可以为Subversion服务器启用svn+ssh加密传输,并确保通过SSHsvnserve的双重认证机制来保护数据安全。这种方法不仅可以防止数据在传输过程中被截获,还可以确保只有拥有适当SSHSubversion权限的用户才能访问版本库。 为了深入了解Subversion的安全配置更多安全实践,我推荐你阅读《增强Subversion安全:svn+ssh与Apache+SSL》。该资料提供了详细的配置指南案例分析,不仅帮助你理解实施svn+ssh,还涵盖了Apache服务器的SSL配置,是提高Subversion安全性的必备资源。 参考资源链接:[增强Subversion安全:svn+ssh与Apache+SSL](https://wenku.youkuaiyun.com/doc/6odwnqfbxx?spm=1055.2569.3001.10343)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值