代码管理平台SVN部署实战
2018/04/20 12:40:36 来源:Linux社区 作者:liuleis

一、SVN 介绍

Subversion(SVN) 是一个开源的版本控制系統, 管理着随时间改变的数据。 这些数据放置在一个中央资料档案库(repository) 中。 这个档案库很像一个普通的文件服务器, 不过它会记住每一次文件的变动。 这样你就可以把档案恢复到旧的版本, 或是浏览文件的变动历史。

二、SVN关键概念

repository(源代码库):源代码统一存放的地方

Checkout(提取):当你手上没有源代码的时候,你需要从repository checkout一份

Commit(提交):当你已经修改了代码,你就需要Commit到repository

Update (更新):当你已经Checkout了一份源代码, Update一下你就可以和Repository上的源代码同步,你手上的代码就会有最新的变更

实际工作开发场景:

日常开发过程其实就是这样的(假设你已经Checkout并且已经工作了几天):Update(获得最新的代码) -->作出自己的修改并调试成功 --> Commit(大家就可以看到你的修改了) 。

如果两个程序员同时修改了同一个文件呢, SVN可以合并这两个程序员的改动,实际上SVN管理源代码是以行为单位的,就是说两个程序员只要不是修改了同一行程序,SVN都会自动合并两种修改。如果是同一行,SVN会提示文件Confict, 冲突,需要手动确认。

三、SVN 的主要功能

1.目录版本控制
CVS 只能跟踪单个文件的历史, 不过 Subversion 实作了一个 "虚拟" 的版本控管文件系统, 能够依时间跟踪整个目录的变动。 目录和文件都能进行版本控制。

2.真实的版本历史
自从CVS限制了文件的版本记录,CVS并不支持那些可能发生在文件上,但会影响所在目录内容的操作,如同复制和重命名。除此之外,在CVS里你不能用拥有同样名字但是没有继承老版本历史或者根本没有关系的文件替换一个已经纳入系统的文件。在Subversion中,你可以增加(add)、删除(delete)、复制(copy)和重命名(rename),无论是文件还是目录。所有的新加的文件都从一个新的、干净的版本开始。

3.自动提交
一个提交动作,不是全部更新到了档案库中,就是完全不更新。这允许开发人员以逻辑区间建立并提交变动,以防止当部分提交成功时出现的问题。

4.纳入版本控管的元数据
每一个文件与目录都附有一組属性关键字并和属性值相关联。你可以创建, 并儲存任何你想要的Key/Value对。 属性是随着时间来作版本控管的,就像文件內容一样。

5.选择不同的网络层
Subversion 有抽象的档案库存取概念, 可以让人很容易地实作新的网络机制。 Subversion 可以作为一个扩展模块嵌入到Apache HTTP 服务器中。这个为Subversion提供了非常先进的稳定性和协同工作能力,除此之外还提供了许多重要功能: 举例来说, 有身份认证, 授权, 在线压缩, 以及文件库浏览等等。还有一个轻量级的独立Subversion服务器, 使用的是自定义的通信协议, 可以很容易地通过 ssh 以 tunnel 方式使用。

6.一致的数据处理方式
Subversion 使用二进制差异算法来异表示文件的差异, 它对文字(人类可理解的)与二进制文件(人类无法理解的) 两类的文件都一视同仁。 这两类的文件都同样地以压缩形式储存在档案库中, 而且文件差异是以两个方向在网络上传输的。

7.有效的分支(branch)与标签(tag)
在分支与标签上的消耗并不必一定要与项目大小成正比。 Subversion 建立分支与标签的方法, 就只是复制该项目, 使用的方法就类似于硬连接(hard-link)。 所以这些操作只会花费很小, 而且是固定的时间。

8.Hackability
Subversion没有任何的历史包袱; 它主要是一群共用的 C 程序库, 具有定义完善的API。这使得 Subversion 便于维护, 并且可被其它应用程序与程序语言使用。

四、SVN安装部署

1.安装svn

yum install -y subversion

2.创建svn版本库目录,注意创建的这个目录是个空目录

[root@localhost ~]# mkdir -p /data/svnroot/myproject
[root@localhost ~]# ls  /data/svnroot/myproject/
[root@localhost ~]#

3.初始化创建的目录

[root@localhost ~]# svnadmin create /data/svnroot/myproject/
[root@localhost ~]# ls !$
ls /data/svnroot/myproject/
conf  db  format  hooks  locks  README.txt
[root@localhost ~]# cd !$/conf
cd /data/svnroot/myproject//conf
[root@localhost conf]# ls
authz  passwd  svnserve.conf

说明:

authz:是权限配置文件
passwd:用户密码文件
svnserve.conf:svn代码管理主配置文件

编辑authz配置文件

##
### A match can be inverted by prefixing the rule with '~'. Rules can
### grant read ('r') access, read-write ('rw') access, or no access
### ('').

[aliases]
# joe = /C=XZ/ST=Dessert/L=Snake City/O=Snake Oil, Ltd./OU=Research Institute/CN=Joe Average

[groups]    ##这个模块是定义对代码仓库操作权限的用户组,不同的用户具有不同的操作权限
# harry_and_sally = harry,sally
# harry_sally_and_joe = harry,sally,&joe

# [/foo/bar]
# harry = rw
# &joe = r
# * =
admins = liu,user1  ##定义admins这个用户组,组内有两个用户分为别liu,user1
[/]    ##中括号里面“/”表示 /data/svnroot/myproject/目录
@admins =rw  ##admins这个用户组对代码项目目录具有读写权限
* = r    ##其他用户组只具备读权限

[myproject:/]  ##这里用来定义/data/svnroot/目录下有多个项目代码的时候
user1 = rw

编辑 passwd ,定义用户名和密码

### This file is an example password file for svnserve.
### Its format is similar to that of svnserve.conf. As shown in the
### example below it contains one section labelled [users].
### The name and password for each user follow, one account per line.

[users]
# harry = harryssecret
# sally = sallyssecret
liu = liu_!(!@#
user1 = user1!@#
user2 = user2!@#

编辑svnserve.conf ,在[general]增加如下配置

[general]
anon-access = none    ##匿名用户没有任何权限
auth-access = write  ##被授权用户具有写权限
password-db = passwd  ##授权用户的密码存放位置
authz-db = authz  ##指定权限控制文件
realm = /data/svnroot/myproject  ##定义对哪个项目目录生效

4.启动svn服务

[root@server-1 conf]# svnserve -d -r /data/svnroot/
[root@server-1 conf]# ps aux |grep svnserver
root    18670  0.0  0.0 112660  976 pts/0    S+  14:54  0:00 grep --color=auto svnserver
[root@server-1 conf]# netstat -nlp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address          Foreign Address        State      PID/Program name   
tcp        0      0 0.0.0.0:3690            0.0.0.0:*              LISTEN      18592/svnserve     

五、如何配置SVN客户端(Linux)

1.安装SVN客户端软件

[root@client ~]# yum install -y subversion

2.SVN客户端检出操作和提交操作

[root@client ~]# mkdir svntest
[root@client ~]# cd svntest/
[root@client svntest]#  svn checkout svn://10.71.11.1/myproject --username=user2  ##注意,这条命令实现从svn服务端10.71.11.1上检出项目程序代码,使用user2这个用户和密码
Authentication realm: <svn://10.71.11.1:3690> /data/svnroot/myproject
Password for 'user2':

-----------------------------------------------------------------------
ATTENTION!  Your password for authentication realm:

  <svn://10.71.11.1:3690> /data/svnroot/myproject

can only be stored to disk unencrypted!  You are advised to configure
your system so that Subversion can store passwords encrypted, if
possible.  See the documentation for details.

You can avoid future appearances of this warning by setting the value
of the 'store-plaintext-passwords' option to either 'yes' or 'no' in
'/root/.subversion/servers'.
-----------------------------------------------------------------------
Store password unencrypted (yes/no)? yes
Checked out revision 0.
[root@client svntest]# ls  ##成功将远端服务上的项目程序代码拉到本地,就可以修改代码
myproject

那么如何把本地修改的代码上床到SVN服务端呢?

常见错误01:

[root@client ~]# cd svntest/
[root@client svntest]# ls
myproject
[root@client svntest]# touch svntest01
[root@client svntest]# ls
myproject  svntest01
[root@client svntest]# svn add svntest01
svn: E155007: '/root/svntest' is not a working copy

原因分析:因为从SVN服务端检出的目录是/myprojec,因此必须进入到这个目录下向SVN服务端提交本地修改的代码

常见错误02

[root@client svntest]# cd myproject/
[root@client myproject]# ls
[root@client myproject]# touch test01
[root@client myproject]# ls
test01
[root@client myproject]# svn add test01
A        test01
[root@client myproject]# svn commit -m "add test01"
svn: E170001: Commit failed (details follow):
svn: E170001: Authorization failed

查看工作副本中的状态

[root@client myproject]# svn status
A      fstab
A      test01

此时fstab的状态为A,它意味着这个文件已经被成功地添加到了版本控制中。

为了把 fstab存储到版本库中,使用 commit -m 加上注释信息来提交。

本文永久更新链接地址https://www.linuxidc.com/Linux/2018-04/151974.htm


9

本栏最新