CentOS的SVN服务器搭建和自动部署
时间:2022-05-30
本文章向大家介绍CentOS的SVN服务器搭建和自动部署,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
花了一个晚上时间折腾svn,网上的教程太乱太杂,还有很多是错误的,终于搞定了,把过程记录下来~
服务器搭建
安装服务
yum install subversion
配置服务
mkdir -p /data/wwwsvn/myrepo #创建svn仓库的目录
这里可以自定义创建的目录,注意不是网站的文件目录。
svnadmin create /data/wwwsvn/myrepo #与上面的目录相同。
这里要注意该目录不能是空目录。 成功以后会得到以下文件
# ls
conf db format hooks locks README.txt
进入conf修改配置文件
-
vi passwd
添加在末尾
[users]
# harry = harryssecret
# sally = sallyssecret
youname = yourpassword #你的用户和密码
-
vi authz
添加在末尾
...
[/]
yourname = rw
-
vi svnserve.conf
关闭注释以及修改变量
anon-access = read #匿名用户可读
auth-access = write #授权用户可写
password-db = passwd #使用哪个文件作为账号文件
authz-db = authz #使用哪个文件作为权限文件
realm = /data/wwwsvn/myrepo # 认证空间名,版本库所在目录,和之前的一样
开启和关闭服务
svnserve -d -r /data/wwwroot/myrepo #开启
killall svnserve #关闭
ps aux | grep svnserve #查看是否运行
打开端口
这一步很重要,如果你都配置完了却发现连接不上,那一定是端口没有打开,默认端口是3690.
iptables -I INPUT -i eth0 -p tcp --dport 3690 -j ACCEPT #开放端口
service iptables save #保存 iptables 规则(如不能保存请使用其他方法保存)
客户端连接
Windows
使用TortoiseSVN
,url填写svn://你的服务器ip
,账号密码填刚刚设置的。
Mac
使用CornerStone
,url填写svn://你的服务器ip
,账号密码填刚刚设置的。
自动部署
每一次commit提交代码之后都会执行钩子post-commit
,根据这个原理可以修改post-commit
,让服务器上的web目录在每次有人commit
之后自动update
。
cd /data/wwwsvn/myrepo/hooks #你的版本仓库目录
cp post-commit.tmpl post-commit
vi post-commit
内容如下
export LANG=zh_CN.UTF-8 #必须要这行
echo "hello world" >> /tmp/svn.log #用来测试钩子是否有执行,调试使用,如果正常就不需要这行了
/usr/bin/svn update /data/wwwroot/yourWebDir --username autoweb --password autoweb --no-auth-cache #也可以用其他方法,总之要保证web目录能正常update
钩子文件里的其他都可以不要了,可以都把他们注释掉。
能这么使用的前提是你的yourWebDir
已经checkout
过了
cd /data/wwwroot/yourWebDir
svn checkout svn://你的服务器ip
... #根据提示完成checkout
另外,post-commit
脚本必须有x
权限。
chmod +x post-commit
至此全部搞定,每一次commit到服务器会自动更新网站内容了。 这也是上次服务器数据丢失之后第一次记录了。
- Bootstrap幻灯轮播如何支持触屏左右滑动手势?
- JavaScript 调试小技巧
- 图片上传预览js
- Isolation Forest算法实现详解
- css继承样式怎么控制?用选择器
- wordpress站内搜索结果页URL伪静态如何操作
- 如何实现大图居中超过的部分两边自动隐藏
- Ubuntu16.04安装后开发环境配置和常用软件安装
- wordpress如何屏蔽wp-json(禁用REST API)
- 贝叶斯系列——贝叶斯与其他统计流派的区别和联系
- bootstrap tab切换如何让鼠标移动自动切换内容
- css自动换行如何设置?url太长会撑开页面
- Histogram of Oriented Gridients(HOG) 方向梯度直方图
- 动态规划系列之最长递增子序列问题解答
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法