文章目录
svn简介
SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于CVS,它采用了分支管理系统,它的设计目标就是取代CVS。
官方网站:http://subversion.apache.org/
Windows客户端 :http://tortoisesvn.net/
常见的版本控制软件:
- svn
- git
SVN存储数据的方式
- BDB,Berkeley DB,一种事务安全型表类型
- FSFS,“FSFS” 采用文件系统的方式, 替代原来的基于Berkeley DB的实现。
因为BDB方式在服务器中断时,有可能锁住数据,所以还是FSFS方式更安全一点。
端口号:3690
运行原理
svn 可以单独运行,也可以跟apache结合起来使用,SVN结合apache的时候需要用到模块 mod_dav_svn
客户端访问svn,需要先经过80端口访问apache,使用mod_dav_svn的协议实现网站的展现,进而访问到SVN server
svn 单机形式安装
1. 实验环境
查看系统环境:
[root@zmedu-17 ~]# uname -r
3.10.0-1062.el7.x86_64
[root@zmedu-17 ~]# cat /etc/redhat-release
CentOS Linux release 7.7.1908 (Core)
[root@zmedu-17 ~]#
关闭防火墙和selinux
[root@zmedu-17 ~]# systemctl stop firewalld.service
[root@zmedu-17 ~]# setenforce 0
2. 使用yum安装svn
[root@zmedu-17 ~]# yum install -y subversion httpd mod_dav_svn
3. 创建版本库目录
[root@zmedu-17 ~]# mkdir /zmgaosh ### 创建存放版本库的主目录
[root@zmedu-17 ~]# svnadmin create /zmgaosh/jgou1 创建名字为架构1的版本库
[root@zmedu-17 ~]# svnadmin create /zmgaosh/jgou2
[root@zmedu-17 ~]# ls /zmgaosh/jgou1
conf db format hooks locks README.txt
4. 查看版块库的目录结构:
[root@zmedu-17 ~]# tree /zmgaosh/jgou1
/zmgaosh/jgou1
├── conf #### 仓库的主配置文件
│ ├── authz #### 认证权限相关的内容
│ ├── passwd #### 用户名和密码
│ └── svnserve.conf #### 服务的配置文件
├── db #### 所有版本控制的数据存放文件
│ ├── current ### 主要记录当前版本号
│ ├── format
│ ├── fsfs.conf #### fsfs 文件类型格式配置文件(默认是FSFS格式)
│ ├── fs-type #### 版本库数据真实存储格式
│ ├── min-unpacked-rev
│ ├── revprops #### 记录版本的属性
│ │ └── 0
│ │ └── 0
│ ├── revs
│ │ └── 0
│ │ └── 0
│ ├── transactions
│ ├── txn-current ### 记录当前的事务
│ ├── txn-current-lock
│ ├── txn-protorevs
│ ├── uuid ### 存储版本库唯一标识
│ └── write-lock
├── format #### 存储一个整数文件,代表版本
├── hooks ### 存放版本库钩子目录。同步更新需要再此处设置
│ ├── post-commit.tmpl
│ ├── post-lock.tmpl
│ ├── post-revprop-change.tmpl
│ ├── post-unlock.tmpl
│ ├── pre-commit.tmpl
│ ├── pre-lock.tmpl
│ ├── pre-revprop-change.tmpl
│ ├── pre-unlock.tmpl
│ └── start-commit.tmpl
├── locks ### 存放svn 监控锁定数据的目录,追踪存取文件库的客户端
│ ├── db.lock
│ └── db-logs.lock
└── README.txt
我们常用的:
[root@zmedu-17 conf]# ls
authz passwd svnserve.conf
[root@zmedu-17 conf]#
修改配置文件
1. 修改配置文件:
[root@zmedu-17 conf]# pwd
/zmgaosh/jgou1/conf
[root@zmedu-17 conf]# vim svnserve.conf
[root@zmedu-17 conf]# cat svnserve.conf |grep ^[^#]
[general]
anon-access = read ##认证用户可读
auth-access = write ##认证用户可读
password-db = passwd ##认证用户的访问密码库文件
authz-db = authz ## 认证权限文件
realm = zmgaosh-svn #登陆提示信息
2. 配置用户和密码及认证权限
1)修改密码文件
[root@zmedu-17 conf]# vim /zmgaosh/jgou1/conf/passwd
[users]
zmgaosh = 123456
gaosh = 123456
xinsz08 = 123456
2)设置用户和组的权限
[root@zmedu-17 conf]# vim authz
Check = xinsz08,zmgaosh
[groups]
[/]
gaosh = rw
@Check = r
启动svn并测试
1. 启动服务
[root@zmedu-17 conf]# svnserve -d -r /zmgaosh/
-r 表示启动所有版本库
如果只启动某一个版本库在/zmgaosh 下面写要启动的版本库即可。
[root@zmedu-17 conf]# ps -aux |grep svn
root 68178 0.0 0.0 197712 1040 ? Ss 12:18 0:00 svnserve -d -r /zmgaosh/
root 68180 0.0 0.0 112728 972 pts/2 R+ 12:18 0:00 grep --color=auto svn
[root@zmedu-17 conf]#
[root@zmedu-17 conf]# lsof -i :3690
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
svnserve 68178 root 3u IPv4 145957 0t0 TCP *:svn (LISTEN)
[root@zmedu-17 conf]#
测试
小王是一个写前端的开发,今天写完的代码v2和v1,下班前要传到svn服务器
[root@zmedu-17 ~]# mkdir jser
[root@zmedu-17 ~]# cd jser/
今天写好的代码js.v2
[root@zmedu-17 jser]# touch js.v1 js.v2
上传到svn
[root@zmedu-17 ~]# svn import /root/jser/ file:///zmgaosh/jgou1/ -m "today is v2"
正在增加 jser/js.v1
正在增加 jser/js.v2
提交后的版本为 1。
[root@zmedu-17 ~]#
第二天,小王来到公司,下载昨天的代码继续写
[root@zmedu-17 ~]# svn checkout svn://192.168.1.17/jgou1 day03
认证领域: <svn://192.168.1.17:3690> zmgaosh-svn
“root”的密码:
认证领域: <svn://192.168.1.17:3690> zmgaosh-svn
用户名: zmgaosh
“zmgaosh”的密码:
-----------------------------------------------------------------------
注意! 你的密码,对于认证域:
<svn://192.168.1.17:3690> zmgaosh-svn
只能明文保存在磁盘上! 如果可能的话,请考虑配置你的系统,让 Subversion
可以保存加密后的密码。请参阅文档以获得详细信息。
你可以通过在“/root/.subversion/servers”中设置选项“store-plaintext-passwords”为“yes”或“no”,
来避免再次出现此警告。
-----------------------------------------------------------------------
保存未加密的密码(yes/no)?y
A day03/js.v1
A day03/js.v2
取出版本 1。
[root@zmedu-17 ~]#
进入下载目录day03 ,以往看到了昨天的密码:
[root@zmedu-17 ~]# cd day03/
[root@zmedu-17 day03]# ls
js.v1 js.v2
今天继续写v3版本
[root@zmedu-17 day03]# touch js.v3
写完后,临时有事,没下班前就要走,所以把代码传到snv服务器上
[root@zmedu-17 day03]# svn add js.v3
A js.v3
[root@zmedu-17 day03]# svn commit -m "day03提交"
svn: E170001: 提交失败(细节如下):
svn: E170001: 认证失败
[root@zmedu-17 day03]#
提交失败了,为啥呢?
因为小王是个新员工,项目经理给的用户名zmgaosh, 在svn服务器里只有读的权限,没有写的权限。
如何切换用户呢? 小王先问项目经理要了有写入权限的用户名和密码
用户名: gaosh
密码: 123456
小王在自己的Linux上先是删除了当前目录下的临时文件
[root@zmedu-17 day03]# rm -rf ~/.subversion/auth/*
然后重新提交:
[root@zmedu-17 day03]# svn commit -m "day03"
认证领域: <svn://192.168.1.17:3690> zmgaosh-svn
“root”的密码:
认证领域: <svn://192.168.1.17:3690> zmgaosh-svn
用户名: gaosh
“gaosh”的密码:
-----------------------------------------------------------------------
注意! 你的密码,对于认证域:
<svn://192.168.1.17:3690> zmgaosh-svn
只能明文保存在磁盘上! 如果可能的话,请考虑配置你的系统,让 Subversion
可以保存加密后的密码。请参阅文档以获得详细信息。
你可以通过在“/root/.subversion/servers”中设置选项“store-plaintext-passwords”为“yes”或“no”,
来避免再次出现此警告。
-----------------------------------------------------------------------
保存未加密的密码(yes/no)?y
正在增加 js.v4
传输文件数据.
提交后的版本为 2。
可以看到最后提交成功了,版本号为2.
总结
本文搭建了一台SVN服务器,并通过命令行交互的形式来与svn交互,并演示了我们设置的权限用户,zmgaosh没有写的权限,我们又换成了gaosh之后才有了写的权限。
说明了权限管理的重要性。
来源:oschina
链接:https://my.oschina.net/u/4418449/blog/4469343