天天看点

linux与 windows环境的Subversion版本控制企业架构搭建之svn+ssh

1、前言

1.1、需求和目的

公司要求引入版本管理服务器对两大对象进行管理:

1)针对windows环境的开发人员的源代码做版本控制。

2)针对linux服务器的配置文件做版本控制。

本章将使用svn+ssh协议的方式完成文件的版本控制。

1.2、系统架构模式描述

1)linux的服务器端

服务器端通过ssh协议提供版本控制服务(port:tcp22)

2)linux&windows的客户端

linux以配置文件版本控制客户端的角色出现

windows以开发者版本控制客户端的角色出现

2、理论部分

SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS、CVS,它采用了分支管理系统,它的设计目标就是取代CVS。互联网上很多版本控制服务已从CVS迁移到Subversion。

3、实践部分

3.1、主机信息

svnSer:

ipaddress=10.168.0.176

hostname=svnSer

linux client:

ipaddress=10.168.0.8

hsotname=client

windows Client:

ipaddress=10.168.0.x

hostname=will2

3.2、yum包的安装

In svnSer & Linux Client

1

<code>yum -y </code><code>install</code> <code>subversion</code>

其他包安装:

<code>yum -y </code><code>install</code> <code>tree</code>

3.3、linux服务端、客户端的配置

3.3.1、step1

In svnSer:

定义仓库文件夹:

2

3

<code>svnadmin create </code><code>/var/local/svn</code>

<code>ls</code> <code>/var/local/svn</code>

<code>tree </code><code>/var/local/svn</code>

注意"revprops"节点(版本控制内容)

3.3.2、step2

定义权限控制

4

5

6

7

<code>ll </code><code>/var/local/svn</code>

<code>groupadd -g 5000 svngroup</code>

<code>chgrp</code> <code>-R svngroup </code><code>/var/local/svn</code>

<code>ll </code><code>/var/local/svn/db/</code>

<code>chmod</code> <code>g+w -R </code><code>/var/local/svn/db/</code>

<code>chmod</code> <code>o= -R </code><code>/var/local/svn/db/</code>

定义只有svngroup组对“/var/local/svn/db/”有写的权限,其他用户没有任何权限

3.3.3、step3

定义svn用户

8

9

10

<code>useradd</code> <code>stan</code>

<code>echo</code> <code>willp | </code><code>passwd</code> <code>--stdin will</code>

<code>useradd</code> <code>natasha</code>

<code>echo</code> <code>natashap | </code><code>passwd</code> <code>--stdin natasha</code>

<code>usermod</code> <code>-G svngroup will</code>

<code>usermod</code> <code>-G svngroup natasha</code>

<code>#usermod -aG svngroup will</code>

<code>#usermod -aG svngroup natasha</code>

<code>id</code> <code>will</code>

<code>id</code> <code>natasha</code>

3.3.4、step4

检查文件目录权限

<code>ll -d </code><code>/var/local/svn</code>

确认组只有读权限

<code>ll -d </code><code>/var/local/svn/db</code>

确认组有读写权限

确认文件有读写权限

3.3.5、step5

上传文件测试

1)配置需要的环境变量:

<code>su</code> <code>- will</code>

<code>vim ~/.bashrc</code>

输入如下内容:

<code>export</code> <code>EDITOR=</code><code>vi</code>

2)创建测试源:

<code>cp</code> <code>-r </code><code>/etc/</code> <code>/home/will/</code>

<code>tree </code><code>/home/will/etc</code>

<code>cd</code> <code>/home/will/</code>

<code>svn </code><code>import</code> <code>etc/ </code><code>file</code><code>:</code><code>///var/local/svn/etc</code>

输入:

<code>i</code>

<code>import</code> <code>svn etc v1</code>

<code>#ESC键</code>

<code>:wq</code>

3.3.6、step6

下载测试

<code>rm</code> <code>-rf etc/</code>

<code>svn checkout </code><code>file</code><code>:</code><code>///var/local/svn/etc</code>

<code>tree etc/</code>

3.3.7、step7

In Client:

建立测试用户并配置环境变量

<code>useradd</code> <code>will</code>

<code>echo</code> <code>willpw | </code><code>passwd</code> <code>--stdin will</code>

<code>echo</code> <code>natashapw | </code><code>passwd</code> <code>--stdin natasha</code>

配置需要的环境变量:

<code>svn checkout svn+</code><code>ssh</code><code>:</code><code>//10</code><code>.168.0.176</code><code>/var/local/svn/etc</code>

输入svnSer服务器端will的用户密码(注意不是本机的will用户密码)

3.3.8、step1

检查下载的文件

3.3.9、step9

设置自动认证

1)ssh-keygen生成一对秘钥

<code>ssh</code><code>-keygen</code>

以上一直回车就好

2)把公钥复制给svnSer

<code>ssh-copy-id -i ~/.ssh/id_rsa.pub will@</code><code>10.168</code><code>.</code><code>0.176</code>

输入svnSer服务器端stan的用户密码(注意不是本机的stan用户密码)

3)测试自动认证

<code>rm</code> <code>-rf etc</code>

<code>ls</code>

3.3.10、step10

In svnSer

版本信息更新测试

1)新svn文件

vim编辑/home/will/etc/sysconfig/network

更改前:

<code>HOSTNAME=svn.cmdschool.org</code>

更改后:

<code>HOSTNAME=svn001.cmdschool.org</code>

更改以上参数

2)上传svn文件

<code>cd</code> <code>/home/will/etc</code>

<code>svn commit</code>

<code>modify network</code>

3.3.11、step11

In Client

客户端下载svn文件

1)先检查客户端配置文件

<code>cat</code> <code>/home/will/etc/sysconfig/network</code>

2)更新svn文件

<code>svn update</code>

3)检查svn更新结果

3.3.12、step12

客户端下载某个版本的svn文件

1)清理当前的svn文件

<code>cd</code> <code>..</code>

2)检出选定的版本svn文件

<code>svn checkout -r 1 svn+</code><code>ssh</code><code>:</code><code>//10</code><code>.168.0.176</code><code>/var/local/svn/etc</code>

以上检出版本1的文件

3.3.13、step13

客户端svn文件更新

增加一个新文件

<code>echo</code> <code>"test"</code> <code>&gt; </code><code>/home/will/etc/test</code><code>.txt</code>

3)上传新文件

<code>svn add </code><code>/home/will/etc/test</code><code>.txt</code>

<code>cd</code> <code>/home/will/etc/</code>

<code>Client add </code><code>file</code> <code>to svnSer</code>

3.3.14、step14

svn文件删除

1)svn文件的删除

<code>svn del </code><code>/home/will/etc/test</code><code>.txt</code>

<code>del </code><code>test</code><code>.txt </code><code>file</code>

2)客户端检出删除的结果

<code>ls</code> <code>/home/will/etc/test</code><code>.txt</code>

3.3.15、step16

svn文件重命名

1)重命名

<code>cd</code> <code>/home/will/etc/sysconfig/</code>

<code>svn </code><code>mv</code> <code>network network.save</code>

<code>mv</code> <code>filename</code>

2)客户端检出重命名的结果

<code>ls</code> <code>/home/will/etc/sysconfig/network</code><code>.save</code>

3)svn版本回滚

<code>svn update -r 3</code>

以上回滚到第3版本

3.3.16、step16

简化日志输入

<code>svn update -r 4</code>

<code>svn commit -m </code><code>"r to v4"</code>

3.3.17、step17

svn日志查看

<code>svn log</code>

3.4、windows客户端的配置

3.4.1、step1

In window Client:

设置公钥认证:

1)下载putty

<a href="http://the.earth.li/~sgtatham/putty/latest/x86/putty.zip" target="_blank">http://the.earth.li/~sgtatham/putty/latest/x86/putty.zip</a>

解压到D盘根目录:

<a href="http://s3.51cto.com/wyfs02/M02/75/96/wKiom1Y8m42SU646AAIP9ga_i68806.jpg" target="_blank"></a>

2)生成公钥和私钥

<a href="http://s3.51cto.com/wyfs02/M00/75/96/wKiom1Y8nDbSy7AKAAFGwWFCcEA942.jpg" target="_blank"></a>

注:以上需要在界面上移动鼠标(笔者超级奇怪,刚才是没有看清楚!)

3)保存公钥和私钥到“d:\putty”

<a href="http://s3.51cto.com/wyfs02/M01/75/93/wKioL1Y8n0nD6B-fAAJ1lqBbFWw379.jpg" target="_blank"></a>

保存结果如下:

<a href="http://s3.51cto.com/wyfs02/M02/75/93/wKioL1Y8n4fxWF4CAAKE6_JABM4920.jpg" target="_blank"></a>

3.4.2、step2

测试公钥认证:

1)把公钥复制到服务器端:

<a href="http://s3.51cto.com/wyfs02/M00/75/97/wKiom1Y80WvxvrqjAAC2yMFCJIc533.jpg" target="_blank"></a>

2)设置认证的公钥:

IN svnSer:

执行如下命令将公钥加入到认证文件:

<code>cat</code> <code>/home/will/pubkey</code> <code>&gt;&gt; </code><code>/home/will/</code><code>.</code><code>ssh</code><code>/authorized_keys</code>

vim编辑/home/will/.ssh/authorized_keys

编辑前:

<a href="http://s3.51cto.com/wyfs02/M01/75/97/wKiom1Y81PrCwZG1AANIrWLzmpk907.jpg" target="_blank"></a>

以上光标处开始共9行,保留第3-8行,其余删除,并将3-8行合并为一行。

编辑后:

<a href="http://s3.51cto.com/wyfs02/M01/75/94/wKioL1Y81T2AYp3AAAM_FoXxqYk802.jpg" target="_blank"></a>

以上加入头部“ssh-rsa”与尾部客户“用户名@主机名”即“[email protected]

注:以上加入公钥方法本人觉得麻烦,windows到linux有更好的方法请告知我!

3)添加认证所需的私钥

In windows Client:

<a href="http://s3.51cto.com/wyfs02/M02/75/94/wKioL1Y80vqRLjD2AAHzj8ycuAI751.jpg" target="_blank"></a>

4)设置测试信息

<a href="http://s3.51cto.com/wyfs02/M02/75/97/wKiom1Y80objZ1rHAAIMpFgDxvU256.jpg" target="_blank"></a>

见到如下信息表示公钥认证成功:

<a href="http://s3.51cto.com/wyfs02/M02/75/97/wKiom1Y81oWQf9k-AACc4NSRgqs976.jpg" target="_blank"></a>

3.4.3、step3

下载并安装svn

1)下载并安装

下载地址:

<a href="http://tortoisesvn.net/downloads.html" target="_blank">http://tortoisesvn.net/downloads.html</a>

由于windowsn的安装都是无师自通,本教程省略,安装完成图例如下:

<a href="http://s3.51cto.com/wyfs02/M01/75/96/wKiom1Y8nPbh4rZ1AAF3kGwkfWo187.jpg" target="_blank"></a>

文件夹邮件菜单图例:

<a href="http://s3.51cto.com/wyfs02/M02/75/96/wKiom1Y8nZHhoHNiAAECEKxVEjI887.jpg" target="_blank"></a>

以上两张图证明svn安装成功

3.4.4、step4

设置svn认证:

右键单击要检出到的文件夹-&gt;TortoiseSVN -&gt; Settings -&gt; Network

1)样例一

公钥认证

并添加如下公钥认证样例:

<code>"C:\Program Files\TortoiseSVN\bin\TortoisePlink.exe"</code> <code>-l will -i D:\putty\privatekey.ppk</code>

详细如下:

<a href="http://s3.51cto.com/wyfs02/M01/75/95/wKioL1Y83uSSRKkoAAL4PmMZUjs919.jpg" target="_blank"></a>

常用参数:

-pw 输入登录svn服务器的密码

-l  输入登录svn服务器的用户名

-i  输入认证的私钥

2)样例二

公钥认证显式用户名和密码自动登录样例(不安全):

"C:\Program Files\TortoiseSVN\bin\TortoisePlink.exe" -pw password -l username

3)样例三

手动键入密码的样例(太麻烦):

<code>"C:\Program Files\TortoiseSVN\bin\TortoisePlink.exe"</code> <code>-l username</code>

3.4.5、step5

检出记录

<a href="http://s3.51cto.com/wyfs02/M01/75/E8/wKioL1ZEk3CAjGTzAADWBeExRdw069.png" target="_blank"></a>

如上图所示:

文件夹单击[SVN Checout]

<a href="http://s3.51cto.com/wyfs02/M00/75/E8/wKioL1ZEk2yzszD1AABHYkUwk8M804.png" target="_blank"></a>

填入检出路径:"svn+ssh://[email protected]/var/local/svn/etc"

以上内容意义:

协议:svn+ssh://

用户名:will

路径:10.168.0.176/var/local/svn/etc

<a href="http://s4.51cto.com/wyfs02/M02/75/EA/wKiom1ZEkyOinvg-AACNlI7g2Yc562.png" target="_blank"></a>

文件检出中……

本文转自 tanzhenchao 51CTO博客,原文链接:http://blog.51cto.com/cmdschool/1710315,如需转载请自行联系原作者

继续阅读