从零开始SVN(2)--Eclipse、Subclipse、分支开发

文章目录

      • Eclipse使用 SVN 插件
        • 插件的选择、安装
          • Subclipse 的安装
        • 常规的操作
          • 分享工程(添加)
          • 图标含义
          • 检出
        • 解决冲突
        • 分支开发
          • 概念与作用
          • 创建分支
          • 切换分支
          • 合并分支
            • 分支合并到主干
            • 主干到分支
        • 权限管理
        • 历史记录

相关: 从零开始使用SVN(1)–服务端与命令行操作


Eclipse使用 SVN 插件

插件的选择、安装

Eclipse 可以使用的 SVN 插件在市面上主要有两种:

  • Subversive:Eclipse 团队开发的插件
  • Subclipse:Apache 的 SVN 团队开发的插件。

博主试过了,2020-3 版的 Eclipse 没有可以用的 Subversive 版本,所以在这里选择安装 Subclipse。

Subclipse 的安装
  • 在 Eclipse 中的应用市场安装:
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第1张图片

  • 搜索 Subclipse 并安装,一路默认 next,最后重启 Eclipse:
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第2张图片

  • 创建资源库位置,即配置 SVN 服务器地址:

    • 切换透视图
      从零开始SVN(2)--Eclipse、Subclipse、分支开发_第3张图片
    • 创建资源库位置
      从零开始SVN(2)--Eclipse、Subclipse、分支开发_第4张图片
    • 配置 SVN 服务器的 URL 地址
      从零开始SVN(2)--Eclipse、Subclipse、分支开发_第5张图片
  • 最后我们就可以看到服务器版本库中的内容:
    image-20200515120128305

某些文件不纳入版本控制

在 Window->Preferences->Team->Ignored Resources->Add Pattern 进行配置:
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第6张图片


常规的操作

基本的操作可以右键资源项目->Team->相关菜单项。

这里就演示下分享工程与检出工程。

分享工程(添加)
  1. 新建一个工程后,工程右键->Team->Share Project

  2. 版本控制工具选择 SVN
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第7张图片

  3. 选个一个已有资源库或者创建新的资源库地址
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第8张图片

  4. 跳转 Team Synhronize,右键工程进行提交
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第9张图片

  5. 服务端便可以看到我们上传的工程
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第10张图片


图标含义
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第11张图片
检出
  1. 在 Eclipse 中执行 import 操作
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第12张图片
  2. 确认资源库位置后,下一步选择工程相应的目录
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第13张图片
  3. 避免和本地项目名冲突,改名后 finish 检出项目
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第14张图片
  4. 工程项目上右键,将检出的项目转换为 maven 项目
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第15张图片

解决冲突

检出后本地有两个项目,相当于多个用户,而制造冲突与前文的方法类似,这里不再赘述。
冲突的产生

文件过时:
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第16张图片

更新文件后出现冲突:
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第17张图片

解决冲突

  1. 冲突文件->右键->Team->Edit Conficts(编辑冲突)
  2. 在界面编辑框中修改至满意后关闭界面(save)
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第18张图片
  3. 冲突文件->右键->Team->Mark as merged(标记已合并/标记为已解决)
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第19张图片
    编辑后选择第一个,未编辑过则可以按照需要选择其他项。
  4. 最后提交

分支开发

概念与作用

前文介绍的不使用分支是多人之间的协作,而分支开发是团队或小组间的协作。
在版本控制过程中,可以通过多个分支同时推进项目多个不同功能的开发,任何一个分支上功能开发失败都不会对其他分支造成影响。

创建分支

相关目录

  • trunk:主干
  • branches:分支
  • tags:存放项目开发过程中的里程碑代码

在创建分支之前,需要在版本库中创建相关目录:
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第20张图片

创建代码分支

先创建一个工程,添加到 trunk 中
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第21张图片

项目->右键->Team->分支/标记
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第22张图片

一路 next->finish。
在这里插入图片描述


切换分支

项目->右键->Team->切换
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第23张图片

最终:
image-20200516133843812


合并分支
  1. 创建两个分支内容:
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第24张图片

  2. 项目->右键->Team->合并
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第25张图片
    将某个分支或主线上提交的多个revision间的变化合并到另外一个分支上


分支合并到主干

Merge a range of revisions方式

主干项目右键合并,选择 Merge a range of revisions 方式

  • form 选择需要合并的分支
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第26张图片

  • 本地的主干会与该分支合并,然后将本地的主干提交
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第27张图片


Merge two different trees方式

主干项目右键合并,选择 Merge two different trees 方式

合并的时候以选择的分支版本为主,如果选择的主干版本与分支版本有不同的地方,合并时主干部分将被删除

  • from 选择主干,需要找到最后一次同步时的版本,如果从没有同步过(第一次合并),则选择创建分支时的版本。
  • to 选择要合并的分支,使用分支最新版本就行了。

由于前文主干与pay分支合并后有新的文件,所以主干需要选择之前的版本
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第28张图片

本地的主干会与该分支合并,然后将本地的主干提交:
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第29张图片


主干到分支

主干与分支同步开发,需要将主干新增与修改同步到分支中来。

Merge a range of revisions方式

直接选择主干的最新版本即可:
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第30张图片

如图,本地的pay分支同步到了主干与Skin分支合并后的文件 Skin.java 以及新建的文件 Main2.java:
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第31张图片


Merge two different trees方式

  • from 选择分支最新版本
  • to 选择主干最新版本
    从零开始SVN(2)--Eclipse、Subclipse、分支开发_第32张图片

如图,本地的skin分支同步到了主干与pay分支合并后的文件 Pay.java 以及新建的文件 Main2.java:
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第33张图片


权限管理

之前我们有在版本库中的 svnserve.conf 文件,修改过权限,使我们匿名的进行读写。

anon-access = write

//auth-access = write

//修改为如下

anon-access = none //设置后可查看历史记录

auth-access = write

还可以加入如下配置,指明配置文件:

password-db = passwd //指定设置用户名密码文件

authz-db = authz //分配权限的配置文件

之后我们就可以通过修改 passwd 文件设置用户名密码,以及通过 authz 文件进行权限的分配:
image-20200516174044534

passwd 文件

//官方的示例:

[users]

harry = harryssecret

sally = sallyssecret

//格式:用户名 = 密码

//以下用于测试

tom = 123456

jerry = 123123

authz文件

//官方的示例

[groups]

harry_and_sally = harry,sally

harry_sally_and_joe = harry,sally,&joe

//格式:用户组 = 用户,用户

//以下用于测试

mygroups = tom //用于测试

//======================================================

//官方例子

[/] //目录

harry = rw //格式:用户名 = 权限值

&joe = r //格式:@用户组 = 权限值

* = //除了授权的用户以外其他用户没有任何权限

//以下用于测试

@mygroups =rw

jerry = r

* =

保存以上的配置后,eclipse中重新连接就会需要我们输入用户名密码:
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第34张图片

使用 jerry 用户登陆,之后我们修改任意文件进行提交,就会出现权限不够的错误:
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第35张图片

而删除登陆过的用户信息,需要到如下目录的auth中删除相关文件:

C:\Users\MOKE\AppData\Roaming\Subversion\

最后我们测试 tom 用户,删除信息重新提交文件,会提示重新登陆:
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第36张图片

提交成功:
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第37张图片


历史记录

查看历史记录

项目/文件->右键->Team->显示资源历史记录(Show History):
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第38张图片

回到某一个历史记录
从零开始SVN(2)--Eclipse、Subclipse、分支开发_第39张图片

你可能感兴趣的:(工具,svn,Eclipse,开发分支,Subclipse,合并分支)