本文摘自:http://hi.baidu.com/farmerluo/item/e7d9d72d098afc0a42634abb

我们最近一个项目用的那几台服务器都是客户给的,但是管理非常严格,只给我们开了22及80端口,搞得我们更新程序只能用sftp方式,很不方便,让他们开svn端口也不肯,让我们用svn+ssh方式。

那就只能用svn+ssh方式了,不得不说svn+ssh很不方便,非常折腾。在这里记录下配置过程。

一. 服务器安装和配置

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

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

6) 修改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

7) 导入项目到svn:

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

8) 在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文件。

点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 ) ) )

3) TortoiseSVN内配置:

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

4) checkout

先打开putty连上服务器
再用TortoiseSVN检出:url:svn+ssh://svn@192.168.1.10/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服务器和客户端的配置[转载]的更多相关文章

  1. ssh方式与服务器建立连接

    package com.ustcinfo.cinas.pmng.util; import java.io.BufferedReader; import java.io.InputStream; imp ...

  2. TortoiseSVN使用svn+ssh协议连接服务器时重复提示输入密码

    当使用svn+ssh协议连接svn服务器时,ssh会提示请求认证,由于不是svn客户端程序来完成ssh的认证,所以不会缓存密码. 而svn客户端通常会建立多个版本库的连接,当密码没有缓存的时候,就会重 ...

  3. 基于svn+ssh:访问svn的部署以及客户端配置

    1.安装ssh sudo apt-get install ssh 2.安装subversion sudo apt-get install subversion 3.为参与项目开发的成员建立用户帐户 s ...

  4. DNS的服务器和客户端的配置

    内网环境Linux发行版本均采用centos为主,centos下DNS服务端的搭建步骤如下: DNS master节点搭建步骤: 安装组件: yum install bind;      yum in ...

  5. Linux NFS服务器的安装与配置(转载)

    一.NFS服务简介 NFS 是Network File System的缩写,即网络文件系统.一种使用于分散式文件系统的协定,由Sun公司开发,于1984年向外公布.功能是通过网络让不同的机器.不同的操 ...

  6. Windows 7下 搭建 基于 ssh 的sftp 服务器

    Windows  xp 下 搭建 基于  ssh 的sftp 服务器,服务器端可以用 freesshd,F-secure server等,filezilla server不可用,之前傻乎乎的用file ...

  7. 在Ubuntu6.06 在搭建SVN服务器及在windows建立svn+ssh客户端 (续)

    接上篇.本篇主要介绍windows下建立svn+ssh客户端. 9.在windows下安装svn客户端,则需安装“TortoiseSVN”.“Puttygen”和“Pageant”    9.1.下载 ...

  8. 在Ubuntu6.06 在搭建SVN服务器及在windows建立svn+ssh客户端

    部门现在使用的Linux系统是Ubuntu6.06,内核版本为2.6.15-57-386.由于系统比较老,所有用网上介绍的方法搭建SVN服务器经常出错,所以参考文章[1],将自己的搭建过程记录下. 1 ...

  9. Windows安装SVN服务器和客户端

    我的操作系统版本是windows10 64位.接下来我会先介绍SVN服务器的安装,然后再介绍安装SVN客户端,并进行测试. 下载 首先我们需要到官网上去下载svn服务器程序. [svn官网地址] (h ...

随机推荐

  1. SQL Server类型的对应关系

    bit bool tinyint byte smallint short int int bigint long real float float double money decimal datet ...

  2. iOS开发app启动原理及视图和控制器的函数调用顺序

    main()函数是整个程序的入口,在程序启动之前,系统会调用exec()函数.在Unix中exec和system的不同在于,system是用shell来调用程序,相当于fork+exec+waitpi ...

  3. MyEclipse/Eclipse新建项目并且部署到服务器(tomcat)下

    1新建项目:file/new/web project/项目名/ok 2部署到tomcat下:tomcat右单机>>add/remove/选择项目/添加/完成(tomcat下有新建的项目) ...

  4. MySql索引简介

    从"找"到B+树 索引是用来查找的. 折半查找是一种很优秀的方式.适合于 范围查找,固有缺点就是需要元素是有序的.二叉搜索树就是对折半查找的一种基础的实现. 但二叉搜索树当遇到特殊 ...

  5. tcp转发

    Proxy.java package com.dc.tcp.proxy; import java.io.IOException; import java.net.ServerSocket; impor ...

  6. man curl_easy_setopt(原创)

    中文翻译: curl_easy_setopt(3) libcurl 手册 curl_easy_setopt(3) 名称 curl_easy_setopt -curl的设置选项概要 #include & ...

  7. SOCKS 5协议详解(转)

    笔者在实际学习中,由于在有些软件用到了socks5(如oicq,icq等),对其原理不甚了解,相信很多朋友对其也不是很了解,于是仔细研读了一下rfc1928,觉得有必要译出来供大家参考. 1.介绍: ...

  8. Linux上的常用软件

    zsh (fish): a new shell oh my zsh: zsh's conf file apvlv: pdf viewer(vim style) autojump: quick 'cd'

  9. Java重点之小白解析--浅谈数据流形式图片上载

    文档上载,上载也不知道哪个大神(混球)起的名字,读起来怪怪的,反正平时我只读上传. 闲话少说,直入主题.先等等这两天做文件上传,都快把宝宝折磨疯了,不会呀,各种查呀,最可悲的是废了老大功夫学会了传送文 ...

  10. WIN32_LEAN_AND_MEAN宏

    网上说: 不加载MFC所需的模块. 用英语解释:Say no to MFC 如果你的工程不使用MFC,就加上这句,这样一来在编译链接时,包括最后生成的一些供调试用的模块时,速度更快,容量更小. 我们经 ...