前言:本文章根据有些公司对于项目管理,所以有些公司对于SVN使用有些挑剔,有些会使用GIT或者Github等等,这不我们公司使用的就是SVN,技术老大说要把Windows系统上的SVN项目迁移至公司Linux服务器上,顺便在Linux上面搭建SVN及配置SVN,小编在这里有一万句mp,第一次操作迁移至Linux服务器上,没办法搞呗,然后去网上查了一下,大部分的教程都是一样,没啥新意,但是有很多讲的教程信息不全,看到这里就想骂人,给人留这么多坑。经过我一天的研究,完美成功,下面就请大家来欣赏。

安装 SVN:

yum install subversion

创建svn仓库路径:

# cd /opt/svn/
# svnadmin create /opt/svn/test

创建成功后在 /opt/svn/test 会有相关文件夹 :

drwxr-xr-x 2 root root 4096 Mar 30 20:05 conf
drwxr-sr-x 6 root root 4096 Mar 30 20:05 db
-r--r--r-- 1 root root 2 Mar 30 20:05 format
drwxr-xr-x 2 root root 4096 Mar 30 20:05 hooks
drwxr-xr-x 2 root root 4096 Mar 30 20:05 locks
-rw-r--r-- 1 root root 229 Mar 30 20:05 README.txt

配置文件讲解:

上面的文件中 , 文件夹 conf 是用来存放配置文件的 :

authz 是权限控制文件
passwd 是帐号密码文件
svnserve.conf 是SVN服务配置文件

配置 authz:

### This file is an example authorization file for svnserve.
### Its format is identical to that of mod_authz_svn authorization
### files.
### As shown below each section defines authorizations for the path and
### (optional) repository specified by the section name.
### The authorizations follow. An authorization line can refer to:
###  - a single user,
###  - a group of users defined in a special [groups] section,
###  - an alias defined in a special [aliases] section,
###  - all authenticated users, using the '$authenticated' token,
###  - only anonymous users, using the '$anonymous' token,
###  - anyone, using the '*' wildcard.
###
### 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

#用户组
dev = dev
#项目用户名
bbt = yukai.li,test

# [/foo/bar]
# harry = rw
# &joe = r
# * =

# [repository:/baz/fuz]
# @harry_and_sally = rw
# * = r

#给予用户加入读写权限
[/]
@dev = rw
[/]
@bbt = rw

配置 passwd:

[root@bbt-dev conf]# more 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
test = 123456
yukai.li = 666666

修改配置 svnserve.conf,这里按照我配置修改就可以了:

#把这个几个前面#去掉就可以了,最后一个直接填写你创建的项目目录名
anon-access = one
auth-access = write
password-db = passwd
authz-db = authz
realm = test
[root@bbt-dev conf]# more svnserve.conf
### This file controls the configuration of the svnserve daemon, if you
### use it to allow access to this repository.  (If you only allow
### access through http: and/or file: URLs, then this file is
### irrelevant.)
### Visit http://subversion.tigris.org/ for more information.

[general]
### These options control access to the repository for unauthenticated
### and authenticated users.  Valid values are "write", "read",
### and "none".  The sample settings below are the defaults.
anon-access = one
auth-access = write
### The password-db option controls the location of the password
### database file.  Unless you specify a path starting with a /,
### the file's location is relative to the directory containing
### this configuration file.
### If SASL is enabled (see below), this file will NOT be used.
### Uncomment the line below to use the default password file.
password-db = passwd
### The authz-db option controls the location of the authorization
### rules for path-based access control.  Unless you specify a path
### starting with a /, the file's location is relative to the the
### directory containing this file.  If you don't specify an
### authz-db, no path-based access control is done.
### Uncomment the line below to use the default authorization file.
authz-db = authz
### This option specifies the authentication realm of the repository.
### If two repositories have the same authentication realm, they should
### have the same password database, and vice versa.  The default realm
### is repository's uuid.
realm = test

[sasl]
### This option specifies whether you want to use the Cyrus SASL
### library for authentication. Default is false.
### This section will be ignored if svnserve is not built with Cyrus
### SASL support; to check, run 'svnserve --version' and look for a line
### reading 'Cyrus SASL authentication is available.'
# use-sasl = true
### These options specify the desired strength of the security layer
### that you want SASL to provide. 0 means no encryption, 1 means
### integrity-checking only, values larger than 1 are correlated
### to the effective key length for encryption (e.g. 128 means 128-bit
### encryption). The values below are the defaults.
# min-encryption = 0
# max-encryption = 256
[root@bbt-dev conf]#

启动服务:

# svnserve -d -r /opt/svn/test

 查看SVN进程:

# ps -ef|grep svn
root 12538 1 0 14:40 ? 00:00:00 svnserve -d -r /opt/svn/test
#或者直接用这个命令查看;
[root@bbt-dev bbt]# ps -aux
root       6122  0.0  0.0 152416   864 ?        Ss   Sep21   0:00 svnserve -d -r /opt/svn/test
#这样表示已启动成功,再启动的时候你只需要启动你创建的beibeitou这个项目目录就好;

客户端连接:

使用 TortoiseSVN , 输入地址svn://192.168.0.204:3690/即可 , 再输入用户名和密码就能访问了
(注:那个端口加不加都行了,我个人测试了一下可以不用添加,另外解释一下为什么地址开头是svn,是因为
这个表示Linux服务器上定义的一个区别,用来区分http表示Windows上的svn,小编个人是这么认为的,如大家想知道,可以去研究一下)

 停止重启SVN:

# killall svnserve     //停止
# svnserve -d -r /opt/svn/test   // 启动

导入项目源代码:

# svn import [源路径][目标版本库路径] -m [日志信息]//例如:
svn import /home/work/ file:///svn/project1/trunk/ -m "Initial import"
#不过我这里没有这样操作使用,可以看看继续操作,因为感觉那样来回操作很麻烦;

接下来是我个人导入项目源码的方式,我是直接使用SVN客户端方式导入,我认为那样比较安全,速度还是比较安全,你只需要把个人项目从SVN拉到本地电脑上,之后连接用客户端连接我们创建好的svn服务器,不多说了请大家看图:

1、首先桌面随便创建一个文件夹,选中右键然后选中版本库浏览器,输入地址

centos7服务器迁移工具 linux服务器整体迁移_用户名

2、确定后,就会弹出让你输入用户名和密码,这里小编认为最好不要保存密码

centos7服务器迁移工具 linux服务器整体迁移_bc_02

3、确定密码后,就会弹出下面这个页面;

centos7服务器迁移工具 linux服务器整体迁移_用户名_03

4、我们刚搞好的SVN服务器里面,这个里面是空的,所以你只需要选择左边的那个地址然后右键,直接新创建一个文件名,之后选中新创建的文件夹,然后右键选中加入文件夹,然后找到你拉下来的项目,然后确定就OK了,导入完后,个人可以直接checkOut一下就知道了

centos7服务器迁移工具 linux服务器整体迁移_bc_04

 

linux搭建配置SVN,eclipse连接时遇到的问题

到这里,小编还没讲完,因为搞好这些,我以为就完事了,因为我公司统一使用的eclipse开发,所以eclipse插件还是个问题,我在直接新建立资源位置的时候发现直接会返回这个错误Eclipse中的Subversion版本控制工具出现Malformed network data的问题,然后小编当场就蒙了,第一次遇到这个问题,我便上网查了很久后,都不可以,最后小编发现了一个牛掰的博客,我试了一下果然OK了,下面我给大家分享出来。

Eclipse安装SVN插件

使用SVN进行项目的版本管理是非常流行的操作,这篇博客将描述Eclipse安装SVN的方法(Linux安装服务器端的请参考CentOS安装SVN)。

从菜单栏依次打开 Help - Install New Software,然后在弹出的窗口点击Add,在Location里面输入如下地址,获取最新的SVN插件,如果需要其他版本,可以在 https://github.com/subclipse/subclipse/wiki 查找。

Subclipse - https://dl.bintray.com/subclipse/releases/subclipse/latest/

Name可以随便写,可以写Subversion,然后点击确定,等到获取了所有的插件列表后,勾选这些插件,点击下一步,然后接受协议,一步一步安装就好了。

centos7服务器迁移工具 linux服务器整体迁移_centos7服务器迁移工具_05

centos7服务器迁移工具 linux服务器整体迁移_centos7服务器迁移工具_06


安装完成后,需要打开SVN视图,在菜单栏依次点击 Window - Show View - Other,然后选择 SVN - SVN资源库,在资源库空白处右键单击,选择新建 - 资源库位置。然后依次填写信息即可。

centos7服务器迁移工具 linux服务器整体迁移_用户名_07

centos7服务器迁移工具 linux服务器整体迁移_svn_08

centos7服务器迁移工具 linux服务器整体迁移_用户名_09

centos7服务器迁移工具 linux服务器整体迁移_centos7服务器迁移工具_10

到此完结Linux建立SVN配置连接,全部OK了,真的废了小编N个脑细胞