CentOS 6.3上SVN安装过程及使用手册

简介:

一、 SVN 简介

    Subversion(SVN) 是一个开源的版本控制系統, 也就是说 Subversion 管理着随时间改变的数据。 这些数据放置在一个中央资料档案库 (repository) 中。这个档案库很像一个普通的文件服务器, 不过它会记住每一次文件的变动。 这样你就可以把档案恢复到旧的版本, 或是浏览文件的变动历史。

 

SVN中经常用到的一些概念 :

(1)repository(源代码库):源代码统一存放的地方;

(2)Checkout (提取):当你手上没有源代码的时候,你需要从repository checkout一份;

(3)Commit (提交):当你已经修改了代码,你就需要Commit到repository;

(4)Update (更新):当你已经Checkout了一份源代码, Update一下你就可以和Repository上的源代码同步,你手上的代码就会有最新的变更 ;

 

SVN的工作方式:

    日常开发过程其实就是这样的(假设你已经Checkout并且已经工作了几天):Update(获得最新的代码) -->作出自己的修改并调试成功 --> Commit(大家就可以看到你的修改了) 。

    如果两个程序员同时修改了同一个文件呢,  SVN可以合并这两个程序员的改动,实际上SVN管理源代码是以行为单位的,就是说两个程序员只要不是修改了同一行程序,SVN都会自动合并两种修改。如果是同一行,SVN会提示文件Confict, 冲突,需要手动确认。

 

客户端软件:

    Windows下常用的客户端软件常用TortoiseSVN。它是一个免费的开源的客户端。 下载地址:http://tortoisesvn.net/downloads.html

wKioL1P604-i-SluAALJcg565I0261.jpg

 

Subversion提供以下主要功能:

(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)。 所以这些操作只会花费很小, 而且是固定的时间。


二、安装以及使用过程:

1、在Linux环境下直接使用yum安装即可:

[root@node1 ~]# yum install subversion


2、安装好之后就可以配置一下相关的配置文件了、其实说配置主要是先创建一个源代码库(也叫版本库),在哪里创建都可以、创建版本库使用的命令如下:

[root@node1 ~]# svnadmin create /data/www/svn


3、配置版本库中的相关配置,设置用户访问的权限,添加访问用户等,在创建的版本库中我们可以在conf文件夹中看到三个文件,这三个文件就是我们要修改的配置:

authz  passwd  svnserve.conf

wKioL1P61j-A01A4AAA4qtOpP-g229.jpg

(1)svnserve.conf:  svn服务配置文件

(2)passwd: 用户名口令文件。

(3)authz: 权限配置文件。


4、接下来我们修改这三个文件;

[root@node1 conf]# vim svnserve.conf

wKiom1P61e7Q__uAAAI3zMlsKOI089.jpg

    anon-access:控制非鉴权用户访问版本库的权限。

    auth-access:控制鉴权用户访问版本库的权限。

    password-db:指定用户名口令文件名。

    authz-db:指定权限配置文件名,通过该文件可以实现以路径为基础的访问控制。

    realm:指定版本库的认证域,即在登录时提示的认证域名称(也就是版本库的名称)。若两个版本库的认证域相同,建议使用相同的用户名口令数据文件


[root@node1 conf]# vim passwd 

wKiom1P61qjTxtebAABQGf3Y3M4787.jpg


[root@node1 conf]# vim authz 

wKioL1P62KrTB0a-AAEW-Uwxa7M143.jpg


如果版本库有多个文件夹,且都需要分配不同的权限的话,只要再加[版本库名:/文件目录]一项这个就可以了,有多少个用多少个,比如:

wKioL1P62i_SC8yLAAFIHRn2Zv0729.jpg


版本库目录,如果你创建的版本库为/data/www/svn,那这里就写上你的目录名,格式:[目录名:/]

@后面跟上组名,再指定组的权限,*=表示不在这个组内的所有组都没有权限;


好了,到这里我们就可以启动服务了;

[root@node1 ~]# svnserver -d -r /data/www/  

-d:表示在后台运行;-r:指出要运行的版本库的路径,如果你创建的版本库路径为/data/www/svn,那么只需要指定/data/www就可以了、查看端口;

wKioL1P62-SywiMUAAE3QYSjUTQ053.jpg

OK、到这里我们已经安装好了,并配置好相关的权限和用户了,那么接下来我们安装windows客户端来测试一下。


三、安装windows客户端SVN、到官网下载客户端,顺便把汉化包也一起下载下来:http://tortoisesvn.net/downloads.html

wKiom1P62_vRyxR-AAKXuaNr-Os007.jpg


下载好客户端之后就一直next到底就可以了,这个不多说了,安装好客户端之后再安装汉化包就可以了,安装完汉化包就要设置一下,改成中文的去:

wKioL1P63ffRb1PMAAFSOFzYJ3U573.jpg

wKiom1P63TmBcR6RAAKX_c8mJTM891.jpg


好了之后我们就可以使用了,找到一个存放源代码的目录,右键空白处,选择SVN检出:

wKiom1P63jTifT4-AAGdQAj-i3k144.jpg


点击确定之后就会弹出输入用户名和密码的对话框:

wKioL1P63_3zGJ-xAAC-6yNzus8909.jpg

wKiom1P635Hg2WEgAAGsZNwXMpw780.jpg


好了,到这里我们的SVN已经搭建完成了,这样我们就可以完全的使用了。如果有什么不明白的地方欢迎各种在下面留言,我会尽量解答各位的问题,谢谢。










本文转自 wei0164 51CTO博客,原文链接:http://blog.51cto.com/tanxw/1544680,如需转载请自行联系原作者
目录
相关文章
|
2月前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第16天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括配置系统源、安装 SQL Server 2019 软件包以及数据库初始化,确保 SQL Server 正常运行。
|
2月前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第8天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统准备、配置安装源、安装 SQL Server 软件包、运行安装程序、初始化数据库以及配置远程连接。通过这些步骤,您可以顺利地在 CentOS 系统上部署和使用 SQL Server 2019。
|
2月前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第7天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统要求检查与准备、配置安装源、安装 SQL Server 2019、配置 SQL Server 以及数据库初始化(可选)。通过这些步骤,你可以成功安装并初步配置 SQL Server 2019,进行简单的数据库操作。
|
3月前
|
Linux 网络安全 数据安全/隐私保护
Linux系统之Centos7安装cockpit图形管理界面
【10月更文挑战第12天】Linux系统之Centos7安装cockpit图形管理界面
120 1
Linux系统之Centos7安装cockpit图形管理界面
|
2月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
128 3
|
2月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。
本文介绍了在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。内容涵盖准备工作、下载源码、编译安装、配置服务、登录设置及实践心得,帮助读者根据需求选择最适合的安装方法。
121 2
|
2月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
185 2
|
3月前
|
Linux 知识图谱
Centos7安装killall,fuser, killall,pstree和pstree.x11
通过上述步骤,您已在CentOS 7系统中成功部署了killall、fuser、pstree以及pstree.x11,为高效管理系统进程打下了坚实基础。更多关于服务器管理与优化的知识,获取全面技术支持与解决方案。
107 1
|
3月前
|
监控 安全 Linux
CentOS7下安装配置ntp服务的方法教程
通过以上步骤,您不仅能在CentOS 7系统中成功部署NTP服务,还能确保其配置合理、运行稳定,为系统时间的精确性提供保障。欲了解更多高级配置或遇到特定问题,提供了丰富的服务器管理和优化资源,可作为进一步学习和求助的平台。
238 1
|
2月前
|
存储 安全 Linux
VMware安装CentOS7
【11月更文挑战第11天】本文详细介绍了在 VMware 中安装 CentOS 7 的步骤,包括准备工作、创建虚拟机、配置虚拟机硬件和安装 CentOS 7。具体步骤涵盖下载 CentOS 7 镜像文件、安装 VMware 软件、创建和配置虚拟机硬件、启动虚拟机并进行安装设置,最终完成 CentOS 7 的安装。在安装过程中,需注意合理设置磁盘分区、软件选择和网络配置,以确保系统的性能和功能满足需求。
253 0