【linux】循序渐进学运维-服务篇-svn服务器单机实战
作者:互联网
文章目录
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 -r3.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]# lsauthz 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 authzCheck = 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 svnroot 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 :3690COMMAND 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]# lsjs.v1 js.v2
今天继续写v3版本
[root@zmedu-17 day03]# touch js.v3
写完后,临时有事,没下班前就要走,所以把代码传到snv服务器上
[root@zmedu-17 day03]# svn add js.v3A 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之后才有了写的权限。
说明了权限管理的重要性。
标签:学运,svn,zmgaosh,17,zmedu,conf,linux,root 来源: https://blog.51cto.com/xinsz08/2704382