版本控制工具SVN学习

 

教学视频链接:https://edu.aliyun.com/course/83?spm=5176.10731334.0.0.778e6580zC0Ri0

版本控制工具SVN学习

1,SVN的简介

  在实际的项目开发之中一定不可能只有一个人完成项目【微型项目除外】,一定是多人开发进行的,如果是多人开发,就一定有可能造成修改的冲突。最初的版本控制工具是CVS【Linux下发展起来后移植到Windows下】,但是后来在CVS进行项目管理的过程之中会产生大量的历史无用文件,所以现在的开发在CVS之后都开始使用SVN了,也被很多公司来使用。使用版本控制工具可以有效的针对于你的项目中的代码进行管理,以及冲突的解决。

  但是不得不说SVN也有自己的局限性的,如果在一个项目团队之中开发,在SVN里面所保存的项目代码,【只能够被本地所管理】。而且SVN使用了客户端服务器模式,也就是说如果需要使用SVN一定要搭建有服务器,而后要单独配置客户端。也就是说CVS、SVN如脱离网络,那么就无法进行版本控制,所以现在最好用的是Git【Github推荐使用的工具】。

图1 SVN服务器与开发者的关系图

2,搭建SVN服务器端

   如果要想搭建SVN服务器端【最好将各种杀毒软件卸载】,必须要有单独的服务器端安装软件。SVN软件安装完成,但是需要对其进行配置才可以使用。

  ①需要准备出一个工作目录,假设:【e:\mysvnpro】为整个项目的工作目录;

  ②此时的【e:\mysvnpro】目录只是一个单独的空目录,并不是一个svn认可的目录,所以需要初始化此工作目录,

svnadmin create e:\mysvnpro

  初始化之后会自动在此目录之中保存一些列的配置文件。

  ③修改【e:\mysvnpro\conf】目录中的内容,所有相关配置都在此目录里面;

  svnserve.conf【服务器整体配置文件】、authz【授权、认证】、passwd【用户名与密码】、hooks-env.tmpl【钩子脚本环境配置文】

图2 svn配置文件目录conf中内容

  I、编辑【svnserve.conf】文件:

anon-access = read
auth-access = write
password-db = passwd
authz-db = authz
realm = My First Repository

  II、编辑【passwd】文件设置可以使用的用户信息:

rdrc_2017202120089 = Mufasa

  III、编辑【authz】文件设置权限:

 1 [groups]
 2 # harry_and_sally = harry,sally
 3 # harry_sally_and_joe = harry,sally,&joe
 4 
 5 [/]
 6 rdrc_2017202120089=rw
 7 
 8 # [/foo/bar]
 9 # harry = rw
10 # &joe = r
11 rdrc_2017202120089=rw
12 * =
13 
14 # [repository:/baz/fuz]
15 # @harry_and_sally = rw
16 * = r

  以上配置完成可以直接使用rdrc_2017202120089用户就可以进行服务器的连接控制了。

 

  ④启动SVN服务:

svnserve -d -r e:\mysvnpro

  启动之后命令行窗口不要关闭。???

3,配置SVN客户端

  由于以后的大部分的项目都在Eclipse中完成,所以将直接在eclipse里面实现客户端的配置处理操作。如果要想在Eclipse里面使用客户端操作的工具,那么必须要保证有相应的插件工具完成。

  ①如果从标准的安装方式应该选择软件更新模式:

    ·【Help】→【Install New Software】→【add】加入SVN插件,但是应该中国的【墙】导致不一定可以成功

图3 Eclipse下的插件标准安装流程

图4 加载插件

  ②直接将插件包覆盖Eclipse插件包中的文件;

4,项目发布与检出

   SVN服务器和客户端都已经配置完成了,那么下面就需要进行项目的发布处理。在SVN的开发之中,必须有一个项目的发布者 ,之后才有项目的开发者。

  ①要保证创建一个你需要发布的项目;

  ②在项目上选择鼠标右键,而后选择共享项目;

图5 项目共享

  ③选择要共享的服务器类型,本次使用的是SVN【免费】;

  ④要求输入SVN路径;

    ·需要你的ip地址支持【ipconfig】:192.168.0.32

    ·SVN的连接地址变为:svn://192.168.0.32

图6 成功初发布项目

  项目发布完成并不意味着你的代码已经提交给服务器了。

图7 只提交自己修改的文件【注意注释】

  如果代码被正确提交则显示如下:

 

图8 正确提交显示

  但是如果要是有其他开发者,则需要服务器端取得这个项目代码。而对于开发者而言,则需要通过SVN服务器取得项目的初期代码。打开一个新的Eclipse【工作区不同】,随后进行导入的处理操作。

  ⑤【Flie】→【Import】→【SVN】→【】

  由于是第一次连接SVN服务器(而且也是新的工作区),所以我们需要自己输入SVN的地址:svn://192.168.0.32,到此所有的开发者都可以检出SVN服务器上的项目信息。

  ⑥更新版本库;先选择【更新】→【提交】

5,冲突解决

   既然是多人开发,那么就有可能两个人同时修改了一个文件的内容,那么此时如果都进行了提交,就有可能产生冲突。

  ①如果现在在你需要修改某些代码之前,请最好做出一个【更新】处理;

  ②如果真的多人修改了同一个文件,并且同时提交,那么一定会出现错误

    ·第二个开发者修改了代码并且提交到了服务器端;

    ·此时第一个开发者也准备提交代码,那么一定会有冲突产生,并且会在代码中标记冲突产生位置。

    ·那么应该由最后一个开发者手工修改冲突文件;但是修改完成之后你还是无法提交,因为需要做一个【解决冲突】的标记-【标记为解决】

6,总结

  这些工具就是一个配置的问题,而且你还必须会配置,工作之中都用这样的管理软件。但是Git更加好用!!!

 

posted on 2019-07-17 15:54  周健康  阅读(373)  评论(0编辑  收藏  举报

导航