一、代码管理平台介绍、安装SVN、客户端上使用SVN(Linux)、Windows

一、代码管理平台介绍

南安网站制作公司哪家好,找创新互联!从网页设计、网站建设、微信开发、APP开发、响应式网站建设等网站项目制作,到程序开发,运营维护。创新互联从2013年开始到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联。

版本控制,记录若干文件内容的变化,以便将来查阅特定版本修订情况

版本管理工具发展简史,CVS→SVN→Git

CVS:兼容性不太好。

SVN:太慢。全名:Subversion,是一个开源版本控制系统,始于2000年。

Git:Linux创始人linus发起的,2005年发布,最初目的是更好的管理Linux内核代码。

Git和SVN不同在于Git不需要依赖服务端就可以工作,即Git是分布式的。

关于Git和SVN的比较,参考http://blog.lishiming.net/?p=305

SVN和Git的最主要的差异——分布式。

SVN优势:

1.存储

SVN服务器既具有CVS所具有数据储存的优点,数据一般不会丢失,同时又拥有自己的特色。SVN是通过关系数据库及二进制的存储方式,同时解决了既往不能同时读写同一文件等问题,同时增添了自己特有的“零或一”原则。

2.速度

与初始的CVS相比,SVN在速度运行方面有很大提升。因为SVN服务器只支持少量的信息、资源传输,与其他系统相比,更支持的是离线模式,因此避免了网络拥挤现象的出现。

3.安全性

SVN是一种技术性更加安全的产品,实现了系统和控制两方面的结合。一方面可以将系统整体的安全功能有效地分布在分支系统中,进而保证分支系统能正常运行,从而使各分支系统能够互补,最终在系统整体性的安全性得以保障,通过均衡原则实现最终追求安全的目的。

Git优劣势:

优点:

适合分布式开发,强调个体。

公共服务器压力和数据量都不会太大。

速度快、灵活。

任意两个开发者之间可以很容易的解决冲突。

离线工作。

缺点:

资料少(起码中文资料很少)。

学习周期相对而言比较长。

不符合常规思维。

代码保密性差,一旦开发者把整个库克隆下来就可以完全公开所有代码和版本信息。

GitHub是基于Git的在线web页面代码托管平台,可以选择付费服务。

Gitlab可以认为是一个开源的GitHub,两者没有直接联系。

一句话区分,git是管理工具,github是在线的基于git的平台(或者叫做服务)。gitlab和github一样,也是一个基于git的提供web界面的代码管理平台。

二、安装SVN

# yum install -y subversion

创建版本库

# mkdir -p /data/svnroot/myproject   //该目录路径可自定义

# svnadmin create /data/svnroot/myproject     //在这个目录下初始化一些文件

# cd !$/conf   #authz为权限配置文件,passwd为密码文件,svnserve.conf为SVN仓库的配置文件。

# vim authz  //配置文件新增内容如下:
[groups]
admins = aming,user1   //加到用户组的下面

[/]
@admins = rw   //@后面跟组名
* = r   //除了admins组以外的所有人只有只读的权限。

[myproject:/]
user1 = rw
# myproject指项目名,这种用法适合于/data/svnroot/有多个项目的情况下,这只是其中一个项目而已。
# 带冒号指的是一个项目名,这里只有一个项目,可以在这下面创建子目录dir1,dir2。可以写成[/dir1]、[/dir2]的形式。
# 两种不同的形式表达而已。一种是[/dir1]、一种是[myproject:/],一个意思。因为这里只有一个项目。

aliases:别名

groups:用户组

[/]:指的是/data/svnroot/myproject这个目录。

仓库里面的目录或者项目里面的目录,针对这些项目配置的关于用户和组的读写权限:

[/foo/bar]

[repository:/baz/fuz]

# vim passwd  //[users]下新增
[users]
aming = aming_!(*$123     ##左边是用户,右边是密码。
user1 = user1_^^^123
user2 = user2-***123

# vim svnserve.conf
[general]  ##在下面增加这5行内容
anon-access = none  ##匿名用户,没有权限
auth-access = write  ##被授权的用户,有写权限
password-db = passwd  ##用户密码存储位置
authz-db = authz  ##权限控制文件位置,这里只写一个字符串,表示这个字符串就是一个文件名,位置在当前目录下,针对svnserve.conf的相对路径。
realm = /data/svnroot/myproject  ##表示对哪一个项目生效,绝对路径。

# svnserve -d -r /data/svnroot/   //启动SVN,-d:deamon的形式,后台启动;-r:指定SVN所在路径;后面也可以跟到项目名。
# ps aux |grep svn
root       1621  0.0  0.0 162200   656 ?        Ss   19:53   0:00 svnserve -d -r /data/svnroot/
root       1623  0.0  0.0 112676   984 pts/0    S+   19:53   0:00 grep --color=auto svn
# netstat -lntp |grep svn
tcp        0      0 0.0.0.0:3690            0.0.0.0:*               LISTEN      1621/svnserve
# iptables -nvL  //检查一下有没有防火墙规则,有的话后续操作不会太顺利。

三、客户端上使用SVN(Linux)

# yum install -y subversion  //另一台机器上安装,安装好后就可以使用svn命令了。
# mkdir svntest
# cd !$
# svn checkout svn://192.168.93.130/myproject --username=aming  //checkout,检出代码。如果你到一台机器上,从来没有连接过svn服务器的情况下,执行这一步以后,它就可以在本机上保存一个曾经你连接过的svnserve的用户名和密码。上面这条命令可以把远程服务端的myproject项目搞到本地来。
认证领域:  /data/svnroot/myproject
“aming”的密码: aming_!(*$123          //此处的密码就是配置文件中设置的密码
-----------------------------------------------------------------------
注意!  你的密码,对于认证域:

    /data/svnroot/myproject

只能明文保存在磁盘上!  如果可能的话,请考虑配置你的系统,让 Subversion
可以保存加密后的密码。请参阅文档以获得详细信息。

你可以通过在“/root/.subversion/servers”中设置选项“store-plaintext-passwords”为“yes”或“no”,
来避免再次出现此警告。
-----------------------------------------------------------------------
保存未加密的密码(yes/no)?yes   //将密码存在了/root/.subversion/servers下
取出版本 0。
[root@MRX svntest]# ls
myproject
# cd project ; ls -la
总用量 0
drwxr-xr-x 3 root root 18 8月  29 18:43 .
drwxr-xr-x 3 root root 23 8月  29 18:43 ..
drwxr-xr-x 4 root root 75 8月  29 18:43 .svn

[root@MRX myproject]# cp /etc/fstab .
# svn add ./fstab  //添加到版本控制中心,把变更的想要搞到服务器上去的东西做个标记
A         fstab
# svn commit -m "add file"   //把文件上传到服务器。先增加,再上传。
# svn commit -m "add fstab"
正在增加       fstab
传输文件数据.
提交后的版本为 1。
# svn delete filename  //在本地删除
# svn commit -m "delete filename"  //在服务器上删除
[root@MRX myproject]# svn delete fstab 
D         fstab
[root@MRX myproject]# svn commit -m "delete fstab"
正在删除       fstab

提交后的版本为 2。
# svn update  //把当前目录下的文件都更新到最新版,把本地的和服务端的同步。
# svn log  //查看变更日志
/root/.subversion/auth/svn.simple下的密码文件,如果某个用户不想存储了,可以删除这个文件。

四、客户端上使用SVN(windows)

官网 https://tortoisesvn.net/index.zh.html

下载TortoiseSVN 并安装

简明教程http://www.jianshu.com/p/6b3b7b915332

下载好后随便选择一个文件夹,比如新建一个myproject,右键文件夹可以看到SVN Checkout和TortoiseSVN。

第一次使用时,也要先SVN checkout,点击之后,会弹出来一个窗口,在最上面的URL of repository里定义一下服务地址和项目地址就可以点OK了:svn://192.168.93.130/myproject。

点OK后再定义用户名和密码:

aming , aming_!(*$123

再点OK

试验:

在Windows的myproject目录下创建一个txt文档,内容随便写一点。再右键该文档,和在Linux上同样的操作,TortoiseSVN→add,再右键SVN commit,在上方空白框内输入add 123.txt,再点OK就可以了。

再到服务端或者另一台客户端上svn update同步一下,就可以看到123.txt了。

在Linux上写了文档,同样的操作,再到Windows上右键SVN update一下,同样可以看到这个111.txt。

# svn add 111.txt
A         111.txt
[root@MRX myproject]# svn commit -m "add 111.txt"
正在增加       111.txt
传输文件数据.
提交后的版本为 4。

网页题目:一、代码管理平台介绍、安装SVN、客户端上使用SVN(Linux)、Windows
URL标题:http://scyanting.com/article/pcidsd.html