zoukankan      html  css  js  c++  java
  • 版本控制工具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:mysvnproconf】目录中的内容,所有相关配置都在此目录里面;

      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更加好用!!!

  • 相关阅读:
    使用docker部署Asp.net core web应用程序
    Docker 常用命令参考
    CentOS 系列安装 Docker
    在IIS上部署你的ASP.NET Core项目
    【POJ1742】Coins
    【CH5105】Cookies
    【NOIP2008】传纸条
    【CH5102】Mobile Service
    【CH1401】兔子与兔子
    【CH5101】LCIS
  • 原文地址:https://www.cnblogs.com/Mufasa/p/11201469.html
Copyright © 2011-2022 走看看