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

一. 服务器安装和配置

  1. 安装ssh server和subversion
    yum install -y openssh-server subversion

  2. 建立svn用户,此用户为ssh登录帐号,再建立用户主目录并设置权限
    useradd svn
    cd /home/svn

  3. 建立 subversion repository
    mkdir /var/svn-repos
    svnadmin create /var/svn-repos/topcity
    chown -R svn:svn /var/svn-repos/topcity

  4. 为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

  1. 编辑 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
注意上述内容和原来公钥的内容应该在同一行中

  1. 修改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

  1. 导入项目到svn:

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

  1. 在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就是。

  1. 首先把上面生成的私key svnuser.key 复制到windows上,再用puttygen.exe转成putty用的key文件。
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 ) ) )

  1. TortoiseSVN内配置:

TortoiseSVN -> Settings -> Network
选择TortoiseSVN安装目录下面的TortoisePlink.exe文件

  1. checkout

先打开putty连上服务器
再用TortoiseSVN检出:url:svn+ssh://[email protected]/topcity

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

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

三.linux客户端配置

  1. 在用户目录生成.subversion:
    svn co

  2. 复制服务器端生成的私key过来到这目录
    cd .subversion
    cp ../svnuser.key .

  3. 配置config文件
    vi config
    在[tunnels]内增加一行:
    ssh = /usr/bin/ssh -l svn -i /home/top_city/.subversion/svnuser.key

4)检出:
svn checkout svn+ssh://192.168.1.10/topcity

更新命令是:
cd topcity
svn up

你可能感兴趣的:(svn+ssh方式svn服务器和客户端的配置)