赞
踩
Subversion(SVN) 是一个开源的版本控制系統, 也就是说 Subversion 管理着随时间改变的数据。 这些数据放置在一个中央资料档案库(repository) 中。 这个档案库很像一个普通的文件服务器, 不过它会记住每一次文件的变动。 这样你就可以把档案恢复到旧的版本, 或是浏览文件的变动历史。
repository(源代码库): 源代码统一存放的地方
Checkout(提取): 当你手上没有源代码的时候,你需要从repository checkout一份
Commit(提交):当你已经修改了代码,你就需要Commit到repository
Update (更新): 当你已经Checkout了一份源代码, Update一下你就可以和Repository上的源代码同步,你手上的代码就会有最新的变更
日常开发过程其实就是这样的(假设你已经Checkout并且已经工作了几天):Update(获得最新的代码) -->作出自己的修改并调试成功 --> Commit(大家就可以看到你的修改了) 。
如果两个程序员同时修改了同一个文件呢, SVN 可以合并这两个程序员的改动,实际上SVN管理源代码是以行为单位的,就是说两个程序员只要不是修改了同一行程序,SVN都会自动合并两种修改。如果是同一行,SVN 会提示文件 Conflict, 冲突,需要手动确认。
(1)目录版本控制
CVS 只能跟踪单个文件的历史, 不过 Subversion 实作了一个 “虚拟” 的版本控管文件系统, 能够依时间跟踪整个目录的变动。 目录和文件都能进行版本控制。
(2)真实的版本历史
自从CVS限制了文件的版本记录,CVS并不支持那些可能发生在文件上,但会影响所在目录内容的操作,如同复制和重命名。除此之外,在CVS里你不能用拥有同样名字但是没有继承老版本历史或者根本没有关系的文件替换一个已经纳入系统的文件。在Subversion中,你可以增加(add)、删除(delete)、复制(copy)和重命名(rename),无论是文件还是目录。所有的新加的文件都从一个新的、干净的版本开始。
(3)自动提交
一个提交动作,不是全部更新到了档案库中,就是不完全更新。这允许开发人员以逻辑区间建立并提交变动,以防止当部分提交成功时出现的问题。
(4)纳入版本控管的元数据
每一个文件与目录都附有一組属性关键字并和属性值相关联。你可以创建, 并儲存任何你想要的Key/Value对。 属性是随着时间来作版本控管的,就像文件內容一样。
(5)选择不同的网络层
Subversion 有抽象的档案库存取概念, 可以让人很容易地实作新的网络机制。 Subversion 可以作为一个扩展模块嵌入到Apache HTTP 服务器中。这个为Subversion提供了非常先进的稳定性和协同工作能力,除此之外还提供了许多重要功能: 举例来说, 有身份认证, 授权, 在线压缩, 以及文件库浏览等等。还有一个轻量级的独立Subversion服务器, 使用的是自定义的通信协议, 可以很容易地通过 ssh 以 tunnel 方式使用。
(6)一致的数据处理方式
Subversion 使用二进制差异算法来异表示文件的差异, 它对文字(人类可理解的)与二进制文件(人类无法理解的) 两类的文件都一视同仁。 这两类的文件都同样地以压缩形式储存在档案库中, 而且文件差异是以两个方向在网络上传输的。
(7)有效的分支(branch)与标签(tag)
在分支与标签上的消耗并不必一定要与项目大小成正比。 Subversion 建立分支与标签的方法, 就只是复制该项目, 使用的方法就类似于硬连接(hard-link)。 所以这些操作只会花费很小, 而且是固定的时间。
(8)Hackability
Subversion没有任何的历史包袱; 它主要是一群共用的 C 程序库, 具有定义完善的API。这使得 Subversion 便于维护, 并且可被其它应用程序与程序语言使用。
[root@localhost ~]# yum install -y subversion [root@localhost ~]# mkdir /svn [root@localhost ~]# svnadmin create /svn/ [root@localhost ~]# ll /svn/ 总用量 8 drwxr-xr-x. 2 root root 76 10月 12 10:45 conf drwxr-sr-x. 6 root root 233 10月 12 10:45 db -r--r--r--. 1 root root 2 10月 12 10:45 format drwxr-xr-x. 2 root root 231 10月 12 10:45 hooks drwxr-xr-x. 2 root root 41 10月 12 10:45 locks -rw-r--r--. 1 root root 246 10月 12 10:45 README.txt [root@localhost ~]# cd /svn/conf/ [root@localhost conf]# ll 总用量 20 -rw-r--r--. 1 root root 1080 10月 12 10:45 authz //控制权限 -rw-r--r--. 1 root root 309 10月 12 10:45 passwd -rw-r--r--. 1 root root 4375 10月 12 10:45 svnserve.conf //仓库配置文件 [root@localhost conf]# vim passwd [users] user1=123456 user2=123456 user3=123456 /配置仓库文件 [root@localhost conf]# vim svnserve.conf [general] anon-access = none #指定匿名用户权限 auth-access = write #指定认证用户权限 password-db = passwd #指定用户密码文件 authz-db = authz #指定用户权限文件 realm = /svn #指定对用的仓库文件(绝对路径) [root@localhost conf]# vim authz [groups] # harry_and_sally = harry,sally # harry_sally_and_joe = harry,sally,&joe # [/foo/bar] # harry = rw # &joe = r [/] // 不要忘记这个! user1 = rw user2 = rw user3 = rw # * = /启动SVN [root@localhost conf]# svnserve -d -r /svn /停掉svn [root@localhost conf]# ps -aux | grep svn root 2109 0.0 0.0 185116 1248 ? Ss 02:09 0:00 svnserve -d -r /svn root 7237 0.0 0.0 112728 980 pts/0 S+ 03:22 0:00 grep --color=auto svn [root@localhost conf]# kill -9 2109 /查看端口 [root@localhost conf]# ss -antl State Recv-Q Send-Q Local Address:Port Peer Address:Port Process LISTEN 0 128 0.0.0.0:3690 0.0.0.0:*
在Windows使用SVN服务的话,需要下载一个TortoiseSVN客户端软件,安装好软件后在本地电脑创建一个工作目录,右键该目录选择checkout,checkout就是把SVN服务器上的文件下载到本地工作目录内的操作
可以下载语言包
如果你喜欢用命令行操作,请务必记得勾选command line client tool为will be install on local hard driver,不用命令行的跳过这一步。
然后一路next即可安装。安装完毕后,在任意地方右键查看快捷菜单。发现TortoiseSVN即表示安装成功。
如果勾选了安装命令行工具,那么输入命令SVN,有如下提示也表示安装成功
安装完语言包之后,可以右键进入setting设置。
但是有时候你已经在本地建立好了项目,需要把你项目推到SVN上,此时应怎么做呢?
右键选择版本库浏览器。
在相应目录下,右键,加入文件/加入文件夹,选择相应目录即可。
比如我现在有个项目叫test,我想把它传到SVN上。
先把他放到对应的目录。
显示提交完成就成功
假如项目已经在服务器的仓库里,那么现在你要做的就是把它检出到本地。
首先创建一个空文件夹。在空文件夹内右键,选择SVN检出。
此时会弹出一个对话框让你输入账号密码,输入你的账号密码即可。记得勾选保存认证,不然每次操作都会让你输入。
等几分钟就可以检出完毕。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。