1.SVN是什么
svn是Subversion的简称,是一个开源的代码版本控制系统,svn就是用于多人共同开发同一个项目,达到资源共用目的工具。
版本控制是什么?
版本控制(Revision control)是指对软件开发过程中各种程序代码、配置文件及说明文档等文件变更的管理。可记录每个版本的信息,方便问题追踪。同时版本控制还支持并行开发,可有效的提高开发效率。
为什么要使用SVN?
1.项目备份方便,节省硬盘空间;
2.记录每个版本,方便追溯历史纪录。
3.多人协作开发,共享数据;
4.细节化的权限控制,便于管理员掌控项目整体。
2.Svn服务端和客户端获取方式
服务端:https://www.visualsvn.com/server/download/
客户端:https://tortoisesvn.net/downloads.html
安装完后,在任意一个文件夹下面右键,如果出现下面这个,就说明安装成功了
3.svn工作流程和架构图;
3.1 svn工作方式:
(svn工作流程图)
3.2 svn架构图:
(svn架构图)
4.操作svn服务器的2种方式
4.1 command-line 命令行方式;
4.2 GUI-client图形界面方式;
4.2.1 svn服务连接方式:
(1) internet网络连接:
apache服务器;
svn服务器;
(2) local 本地连接:
4.2.2 svn数据存储方式:
文件方式:FSFS(推荐使用)
数据库方式:BerkeleyDB(伯克利DB)
5.svn服务器目录结构、用户和权限;
5.1 目录结构:
Repositories 仓库:存放被svn管理的项目文件,可以存放源码,文档等;
Users 用户:创建和编辑用户;
Groups 权限组:创建和编辑用户组;
打开VisualAVN Server步骤:在SVN服务器的安装目录下进入bin文件夹,双击VisualAVN Server.msc即可弹出VisualAVN Server窗口。
5.2 创建仓库:
标准文件夹结构:
branches 分支:如果需要测试新技术,或者大范围修改,将主干代码拷贝到分支中进行,测试无误后可以合并到主干中;
tags 发布:发布版本要放到tags中;
trunk 主干:主要开发目录;jia
创建仓库,命名为helloSvn:
创建项目,命名为dev:
5.3 创建用户:每个开发人员都需要拥有自己的svn账号;
右键【Users】-【Create User...】,比如创建三个用户siki,lain,lijiang
5.4 创建组:为每个部门配置不同的权限,便于管理;
5.5 分配权限:在仓库或者目录中为用户/组分配权限;
右键【Group】-【Create Group...】,比如创建2个组admin,javaEE-Team
同理:创建组javaEE-Team:
此时,就可以给项目helloSVN分配权限了,右键【helloSVN】-
6.svn常用操作:
6.1 checkout 检出:
初次下载 - 第一次连接svn服务器时候需要下载对应仓库的数据(如果仓库中有数据的话);
比如现在让文件夹siki连接SVN服务器,方式如下
然后siki文件夹下面就有文件了
6.2 add 新增:
新增数据到svn服务器;
比如在trunk文件夹下面新建一个Item.java文件,将此文件添加到SVN服务器:
现在再commit到SVN服务器:
提交成功显示如下界面:
现在我们来到SVN服务器,按F5刷新,可以看到trunk目录下有了Item.java文件了!
6.3 update 更新:
更新数据 - 检查svn服务器中的数据是否与本地的数据一致,如果不一致就下载改变/新增部分,同时不会删除本地数据;
比如在另一个lijaing文件夹下面更新SVN服务器的数据,同样要先在lijiang文件夹里面右键【SVN checkout...】
现在我们去siki/dev/trunk目录中打开Item.java,会发现还没有name属性
此时我们右键【update】更新一下就可以了,就会有name属性了
6.4 delete 删除:
删除svn的数据(需要搭配commit命令);
比如删除siki/dev/trunk目录下的Item.java文件,选中【Item.java】-【TortoiseSVN】-【Delete】,然后还没完,一定要记得commit!!!
6.5 revert 回滚:
将指定版本的代码回滚到本地,如要提交到服务器需要搭配commit命令;
然后可以看到Item.java已经被回滚到文件夹里了,同样此时一定要记得commit!!!
commit提交:
6.6 代码冲突:
在多人同时开发一个类,提交的时候容易出现代码冲突,也可以理解为版本冲突;
比如siki和lijiang同时修改并更新Item.java文件,siki给Item.java添加一个price属性,lijiang给Item.java添加一个num属性。siki先提交,然后lijiang再提交时就会提示是否update,选择确定update,然后lijiang/dev/trunk里面就会有四个文件,
siki给Item.java增加price属性:
lijiang给Item.java增加num属性:
7.其他操作:
7.1 按照版本检出;
右键【TortoiseSVN】-【show log】
选择保存地址即可
7.2 账号保存与注销;
在需要注销账号的文件夹里面右键【TortoiseSVN】-【settings】-【Saved Data】-【Clear all】,
7.3 代码对比工具;
可以高亮显示不同版本文件的不同之处
7.4 下载指定版本号的文件;
比如新来一个队友,要使用某个文件的旧版本
SVN,安装,SVN,基本操作
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。