• SVN的介绍和使用


    1.SVN介绍

      SVN是Subversion的简称,是一个自由开源的版本控制系统。
      Subversion将文件存放在中心版本库里,这个版本库很像一个普通的文件服务器,不同的是,它可以记录每一次文件和目录的修改情况,

      这样就可以借此将数据恢复到以前的版本,并可以查看数据的更改细节

    2.SVN基本概念

      

       怎样让系统允许用户共享信息,而不会让他们因意外而互相干扰?

        复制-修改-合并方案(Subversion默认的模式)
          在这种模型里,每一个客户读取项目配置库建立一个私有工作副本——版本库中文件和目录的本地映射。用户并行工作,
          修改各自的工作副本,最终,各个私有的复制合并在一起,成为最终的版本,这种系统通常可以辅助合并操作,但是最终要靠人工去确定正误。

        锁定-修改-解锁方案
          在这样的模型里,在一个时间段里配置库的一个文件只允许被一个人修改。 此模式不适合软件开发这种工作。

    3.SVN使用

      SVN是一种集中式管理代码的版本控制系统,原理就是把代码都保存到一个固定的位置(仓库),每次从这个位置拷贝更新代码,进行编辑;
      再把修改后的代码提交到该目录中。多人协作开发也是如此。因此需要一个类似Oracle或者Mysql的服务器,
      用于保存和管理库文件(要保存的代码等文件)的服务端——VisualSVN Server。
      还需要一个用户的操作端,用于提交更新检出代码,常用的有idea的Svn插件,以及TortoiseSVN(小乌龟)。

      SubVersion 官网:http://subversion.apache.org/packages.html#windows 可以在这里下载 VisualSVN

      服务器端VisualSVN安装与创建仓库

        

        

        查找 visualSVN Server Manager 应用打开图形化管理界面

         

       VisualSVN创建工程目录

        

       VisualSVN 权限控制

        创建用户

        

        

         创建组

        

        分配权限

        

      客户端TortoiseSVN安装与使用

        TortoiseSVN是一个基于windows系统的svn客户端图形化界面

        Tortoise SVN下载:和 VisualSVN 一样,也是在 SubVersion 官网

        

         Tortoise SVN安装:安装后需要重启电脑

        

         Tortoise SVN 常用操作

          浏览仓库

          

           checkout

          

          

           add:意思是添加到svn服务器

          

           commit

          

           

           

           update:更新操作,可以将svn服务器上的内容更新到本地

          

           更新到历史版本

          

           

           delete:标记删除操作,本地文件会删除,我们需要进行提交,才能真正从服务器删除

          

           导入与导出

           

            Import将本地资源导入到svn服务器
            Export导出项目,和checkout的区别,它不存在.svn隐藏文件

          冲突问题与解决

            多个用户同时操作同一个文件时,就可能产生冲突情况。

            发生冲突产生后如何解决,我们可以采用手动Merge,解决冲突后,重新commit.

            发生冲突后会产生的文件:
              

                HelloWorld.java 它是服务器上的文件与本地文件合并
                HelloWorld.java.mine 本地修改后的文件
                HelloWorld.java.r4 修改前的文件
                HelloWorld.java.r5 对方修改后的文件

            解决冲突:

              

  • 相关阅读:
    第二阶段冲刺第七天,6月6日。
    第二阶段冲刺第六天,6月5日。
    第二阶段冲刺第五天,6月4日。
    第二阶段冲刺第四天,6月3日。
    第二阶段冲刺第三天,6月2日。
    第二阶段冲刺第二天,6月1日。
    垃圾收集器与内存分配策略(1)
    OutOfMemoryError异常
    对象访问
    java内存区域与内存溢出异常(2)
  • 原文地址:https://www.cnblogs.com/roadlandscape/p/12326241.html
Copyright © 2020-2023  润新知