svn服务器安装在centos7系统平台

当今用于版本控制的软件程序主要的有svn和git,其它软件咱不熟悉,今天记录下搭建svn服务器和svn客户端使用;

使用环境:

虚拟机为centos7系统,svn服务器安装在centos7系统平台上,svn客户端分别在windows7和centos7系统上使用;

1、安装svn服务器:

 ]# yum install subversion

2、配置svn服务器:

建立svn版本库根目录及相关目录即svndata及密码权限命令svnpasswd;

  ]# mkdir -p /application/{svndata,svnpasswd}

  svndata目录:作为存放svn的根目录;
  svnpasswd目录:作为存放登录svn的用户和密码;

3、启动svn服务:

 ]# svnserve -d -r /application/svndata/
  参数:
   -d:表示后台运行守护模式;
   -r:表示svn服务的根目录;

   检测svn端口3690是否已经监听:
 netstat -lntup | grep 3690

4、建立版本库:
在/application/svndata/目录下,创建项目sadoc:

  ]# svnadmin create /application/svndata/sadoc

会自动创建出一系列固定的目录:

]# tree /application/svndata/sadoc

/application/svndata/sadoc
├── conf
│   ├── authz
│   ├── passwd
│   └── svnserve.conf
├── db
│   ├── current
│   ├── format
│   ├── fsfs.conf
│   ├── 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
│   ├── db.lock
│   └── db-logs.lock
└── README.txt

 主要目录说明:
   conf目录:主要是配置文件、登录用户、密码认证;
   hooks目录:主要是svn的钩子脚本模板,使用时去掉.tmpl后缀即可,钩子脚本实际上就是代码提交前后,可以分别执行的脚本,脚本可用perl、shell、python等语言编写,该目录里面脚本文件名代表提交代码执行的不同时机,如提交代码前执行的脚本pre-commit,提交代码后执行的脚本post-commit,更多详情自行学习;

5、修改配置文件:

]# vim /application/svndata/sadoc/conf/svnserve.conf
anon-access = none 
  #不允许匿名访问,read为允许匿名访问;

 auth-access = write 
 #允许可写;

password-db = /application/svnpasswd/passwd
 #密码数据库

authz-db = /application/svnpasswd/authz 
 #控制权限数据库

注意:配置文件必须顶格写;

把用户和密码文件放到自定义的目录中:

 ]# cp authz passwd /application/svnpasswd/

改权限:

]# chmod 700 /application/svnpasswd/*   

配置passwd文件:

[users]
oldboy = oldboysecret
test = testsecret
test1 = test1secret

passwd配置文件说明:
格式为:svn账号=svn密码
账号和密码可随意指定;

配置authz:

[groups] 
#定义组信息,注意:用户账号在passwd里; 
ett_sa = oldboy,test1
ett_wangguan = test
[sadoc:/]
@ett_sa = rw
@ett_wangguan = r
test = r

authz配置文件说明:

1.权限配置文件中出现的用户必须已经在用户配置文件中定义;
2.对权限配置文件的修改立即生效,不必重启svn;
3.一个用户组可包含多个用户,用户间用逗号分隔;
4.版本库目录格式:
[<版本库>://项目目录]
@<用户组名> = <权限>
<用户名> = <权限>

   其中,方括号内部分可有多种写法:
 [/]:表示根目录及以下,根目录是svnserve启动时指定的,[/]表示对全部版本库设置权限;

 [repos:/]:表示对版本库repos设置权限;

 [repos:/sadoc]:表示对版本库repos中的sadoc项目设置权限;

 [repos:/sadoc/oldboy]:表示对版本库repos中的sadoc项目的oldboy目录设置权限;

 权限主体可以是用户、用户组或*,用户组在前面加@,*表示全部用户;

 权限可以是w、r、wr和空,空表示没有任何权限;
 authz中每个参数都要顶格写,开头不能有空格;
 对于组,要以@开头,而用户不需要;

6、重启svn服务:

 ]# pkill svnserve
 ]# svnserve -d -r /application/svndata/

 注意:
 更改svnserve.conf需要重启svn,更改authz、passwd文件时不需要重启;

 检查3690端口是否处于监听状态,至此svn服务器搭建完成;下面是svn客户端的安装与使用;

分别说明在windows平台和centos7平台上的svn客户端安装和使用:

svn客户端访问方式:

subversion可通过多种方式访问--本地磁盘服务,或各种各样不同的网络协议,但一个版本库地址永远都是一个url,url方案反映了访问方法;

  1.file:// 直接版本库服务(本地磁盘或访问方法;
  2. http:// 通过webdav协议服务支持subversion的apache服务器;
  3.https:// 与http://相似,但是用ssl加密;
  4.svn:// 通过未认证的tcp/ip自定义协议访问svnserve服务器;
  5. svn+ssh:// 通过认证并加密的tcp/ip自定义协议访问svnserve服务器;

1、windows平台:
下载svn客户端安装即可,都是鼠标操作,比较容易;
主要说明后续的使用步骤:
1.在本地创建svn目录:如创建svn-test目录;

2.在该目录上右击,选择SVN Checkout:
然后,根据弹框,填写svn服务器地址、用户名等信息;首次使用svn用checkout,会要求输入用户名和密码;
保存认证信息在缺省目录:%APPDATA%\Subversion\auth目录下,在运行cmd窗口输入:

%APPDATA%\Subversion\auth即可,
即C:\Users\sshss\AppData\Roaming\Subversion\auth

该目录上右击:


继续操作:


点击ok


这样即可完成

3.在创建的目录里,编写代码,然后在该目录右击,选择SVN Commit提交代码即可

4.如果要拉取,svn服务器上的代码,右击该目录,选择SVN Update即可;


具体功能,自行学习下,点击鼠标就行了;

2、centos7平台:

主要步骤即svn命令说明:

1.导入svn原始目录:

  先创建svn目录: 
  ]# mkdir /data/oldboy -p

  在其目录下,创建3个目录:
  ]# cd /data/oldboy; mkdir trunk branch tags -p
 导入:
 ]# svn import /data/oldboy svn://192.168.255.12/sadoc/ -m "import tree"

2.从svn库提取数据:

]# mkdir /data/test
]# svn checkout svn://192.168.255.12/sadoc /data/test --username oldboy --password oldboysecret
或简写:
 ]# svn co svn://192.168.255.12/sadoc /data/test --username=oldboy --password=oldboysecret
 或:
 ]# svn co file:///application/svndata/sadoc /data/test --username=oldboy --password=oldboysecret

注意:首次使用svn用checkout;后面再用提取数据不用再使用用户名和密码:

3.查看svn中的数据:

]# svn list --verbose svn://192.168.255.12/sadoc
或:
 ]# svn ls --verbose svn://192.168.255.12/sadoc 
 ]# svn cat svn://192.168.255.12/sadoc/trunk/test1.txt

4.向svn中提交数据:

  ]# touch /data/test/trunk/test2.txt
  ]# svn add /data/test/trunk/test2.txt
  ]# svn ci -m "test2.txt" /data/test/trunk/test2.txt

  ci简称:commit;
  co简称:checkout;

  注意:提交时,先add,再commit;

5.svn钩子脚本使用(仅演示一个)

仅演示post-commit脚本使用:
 ]# vim /application/svndata/sadoc/hooks/post-commit
 注释掉默认执行语句,添加:
 touch /tmp/$(date +%F).log

 添加执行权限:
  ]# chmod 755 post-commit

 在windows客户端上,修改数据后执行commit,在linux命令行上查看,是否执行了该钩子脚本;
 即在/tmp目录下创建了一个以时间命名的.log文件;

 注意:
  1、钩子脚本的权限要允许svn执行,一般设为chmod 755 post-commit;
  2、写钩子脚本时,尽可能定义变量,主要是用过的命令的路径,因为svn考虑安全问题,不会调用系统环境变量;
  3、在svn update之前,一定要先手动checkout一份出来,还有这里一定要加上用户和密码;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


文章浏览阅读903次。4.清除缓存目录(/var/cache/yum)下的软件包及旧的headers。11.列出所有已安裝但不在 Yum Repository 內的软件包信息。3.清除缓存目录(/var/cache/yum)下旧的 headers。2.清除缓存目录(/var/cache/yum)下的 headers。5.列出所有已安装但不在 Yum Repository 內的软件包。1.清除缓存目录(/var/cache/yum)下的软件包。9.列出所有可更新的软件包信息。3.列出所有可更新的软件包。_centos yum update
文章浏览阅读1.5k次。Python 是一种高级解释性编程语言,已被用于各种应用程序开发,并在近年来获得了巨大的流行。Python 可用于编写广泛的应用程序,包括 Web 开发、数据分析、科学计算、人工智能、游戏等。由于其简单易用,它是初学者的理想语言。Python广泛应用于金融、医疗保健和科技等行业,并且由于其丰富的数据分析和可视化库和工具集而受到数据科学家和研究人员的欢迎。创建本内容时 Python 的最新稳定版本是 Python 3.11。_linux安装python3.11
文章浏览阅读2.6k次。打开终端或控制台,以root或具有sudo权限的用户身份登录。根据你的Linux发行版和网络管理工具的不同,相应的命令可能略有不同。使用以下命令编辑网络配置文件,例如eth0网卡的配置文件:注意:ifcfg-eth0 可能会有不同的命名,根据实机情况确认。在编辑器中,找到以"IPADDR"开头的行,然后修改IP地址。例如,将IP地址更改为192.168.1.100_银河麒麟修改ip地址
文章浏览阅读744次,点赞24次,收藏26次。目标:通过AppSrv为InsideCli客户端网络分配地址,地址池范围:192.168.0.110-192.168.0.190/24。另外一个虚拟网卡改为192.168.0.1给Rserver服务器,添加多一个网卡,用于连接不同的网段分别选刚才选好的两个网段之后,开启各虚拟机,配置IP地址ip addr查看网卡vi /etc/sysconfig/network-scripts/ifcfg-ens33新网卡没有UUID,要生成一个uuidgen然后记下进入文件夹cd /etc/sysconfig/netwo
文章浏览阅读1.1w次,点赞8次,收藏26次。chmod命令来自于英文词组“change mode”的缩写,其功能适用于改变文件或者目录权限的命令。默认只有文件的所有者和管理员可以设置文件权限,普通用户只能管理自己的文件的权限属性。设置权限时可以使用数字法,亦可使用字母表达式,对于目录文件建议加入-R参数进行递归操作,意味着不仅对于目录本身,也对目录内的子文件/目录进行新权限的设定。_chmod修改权限
文章浏览阅读1.2k次。yum源的URL地址,本例中是文件系统的路径,以“file:///”开头。其中,是要安装的软件包的名称。:本节的名称,可以是任何名称,但是必须以“[ ]”括起来。如果能够看到光盘的设备信息,则说明系统已经检测到了光盘。注意:baseurl的值必须是光盘挂载的目录路径。:GPG公钥文件的路径,用于yum包的安全性检查。:yum源是否启用,1表示启用,0表示禁用。:是否进行GPG校验,1表示是,0表示否。打开终端,使用root用户登录。:yum源的名称,可以自定义。_centos挂载光盘
文章浏览阅读1.4k次。这会在系统中安装新的 OpenSSL 版本。如果输出结果中的版本号为 1.1.1 或更高版本,则说明 OpenSSL 已成功升级。然后将新安装的OpenSSL做软连接到这个路径。4.初始化并编译、安装。_centos 升级 openssl
文章浏览阅读4.9k次,点赞5次,收藏11次。[Linux下的软连接、软链接的方式]][[Linux使用的filesystem库来自于c++17提供的新特性]][[Linux下centos查看 GCC 、G++版本]][[Linux 下centos 查看 -std 是否支持 C17 ]]_gcc c++17
文章浏览阅读3.2k次,点赞3次,收藏9次。Linux (centos) 安装Python3.9(保姆级别)_centos安装python3.9
文章浏览阅读5.9k次,点赞4次,收藏4次。进入国内的阿里云的,这里CentOS 7提供了三种ISO镜像文件的下载:DVD ISO、Everything ISO、Minimal ISO。阿里云下载链接: http://mirrors.aliyun.com/centos/点击进入下载页面,随便选择一个下载即可(不推荐,推荐阿里云下载,见下文)阿里云下载站点(速度非常快推荐)_centos7 iso
文章浏览阅读3.9k次。运行报错_inconsistency detected by ld.so: dl-call-libc-early-init.c: 37: _dl_call_lib
文章浏览阅读782次,点赞22次,收藏24次。通过查看INSTALL文件我们可以知道安装glibc2.31的要求,需要binutils版本2.25以上,texinfo版本4.7以上,bison版本2.7以上,sed版本3.02以上,gettext0.10.36以上,Python3.4以上,GDB7.8以上,make版本4.0以上,GCC版本6.2 以上。isl-0.18版本: http://www.mirrorservice.org/sites/sourceware.org/pub/gcc/infrastructure。_rpm 更新glibc2.31
文章浏览阅读905次,点赞19次,收藏16次。操作系统运维相关操作,实用而全面_centos 共享磁盘
文章浏览阅读1.5k次。CentOS Stream的位置提到RHEL上游,解决了“孤儿”的问题。红帽在RHEL上开发的所有功能都已经在CentOS Stream上完成,生态伙伴所添加的内容都将返回到CentOS Stream中,这些新功能会在未来RHEL发布出来,避免了生态伙伴创新消失不见情况的发生,从而保护投资,保护创新。为什么强调位置的变化?红帽的创新得到了CentOS创造者Gregory Kurtzer的肯定,他曾在公开场合表示,红帽做了正确的事情,CentOS Stream的场景比CentOS更好,更适合社区的发展。_dnf: command not found
文章浏览阅读1k次,点赞3次,收藏6次。sysconf:keepalived核心配置文件所在位置,固定位置,改成其他位置则keepalived启动不了,/var/log/messages中会报错。注意:如果在第5步执行 make && make install 时,报如下错误,则可能是keepalived版本号不对,可以试试 2.1.0 以前的版本。4. 进入到解压后的文件夹内,里面会看到 configure 文件,接下来就可以使用 configure 命令进行配置了。2. 通过 ftp工具上传到 linux:/home/software/_服务器双机热备
文章浏览阅读3k次。配置iptables规则,限制用户的出口IP,这里是根据用户的uid去限制的,比如user001用户的uid是1000,配置user001用户的出口IP就是172.17.22.1,以下是示例,根据自己情况修改uid和出口IP。找到auth的配置,默认是注释了的,先放开注释(就是把首行的#去掉),然后把Authentication这列改为u,以下是修改后的截图。打开后是空文件,在这里面添加自己的代理账号和密码,格式:账号+英文空格+密码,以下是例子,自己配置自己的账号。至此恭喜你,完成了所有配置!_站群搭建socks5
文章浏览阅读815次。下载链接:https://github.com/PowerShell/PowerShell/releases。下载链接:https://github.com/PowerShell/PowerShell/_linux中pwsh安装
文章浏览阅读877次,点赞10次,收藏5次。在CentOS系统中,Apache服务器是一个常用的Web服务器软件,它可以高效地提供静态HTTP服务。现在,您已经成功地在CentOS系统中配置了Apache服务器提供静态HTTP服务。启用默认站点:确保在配置文件中启用了默认的站点配置。此外,根据您的需求,您可能还需要进一步配置Apache的其他功能和模块。在配置文件中,您可以进行各种设置以定义您的静态HTTP服务的行为。指令,以定义适当的权限和设置。例如,确保目录的权限设置为适当的读/写/执行权限。指令设置为包含您的静态文件的目录路径。_centos还能用服务器吗
文章浏览阅读676次,点赞71次,收藏64次。简单几步实现在Linux centos环境下安装部署sql server数据库,并结合cpolar内网穿透工具,创建安全隧道将其映射到公网上,获取公网地址,实现在外异地远程连接家里/公司的sqlserver数据库,而无需公网IP,无需设置路由器,亦无需云服务器。
文章浏览阅读5.5k次。在 CentOS 7 中,可以通过以下步骤来开放指定端口号:1、使用 root 或具有管理员权限的用户登录到 CentOS 7 服务器。2、使用防火墙管理工具 firewalld 进行端口开放。 firewalld 是 CentOS 7 默认的防火墙管理工具。3、检查当前防火墙的状态,确保 firewalld 服务已经运行并且正常工作。可以使用以下命令来检查:_centos7开放端口