我们有一个电子商务应用程序,我们在公司开发.它是一个合理标准的LAMP应用程序,我们已经开发和关闭了大约3年.我们在测试域上开发应用程序,在这里我们添加新功能并修复错误等.我们的错误跟踪和功能开发都在托管的subversion解决方案(unfuddle.com)中进行管理.当报告错误时,我们在测试域上进行这些修复,然后在我们很高兴修复错误时将更改提交给svn.我们按照相同的步骤添加新功能.

值得指出的是我们的服务器系统和应用程序的一般架构.每次开发新功能时,我们都会使用我们的应用程序(始终是我们控制的服务器)将此更新推送到所有站点.使用我们系统的每个站点实际上对95%的代码库使用完全相同的文件.我们在每个站点中有几个文件夹,其中包含定制到该站点的文件–css文件/图像等.除此之外,每个站点之间的差异由每个站点数据库中的各种配置设置定义.

这将进入实际部署本身.当我们准备推出某种更新时,我们在测试站点所在的服务器上运行命令.这将执行复制命令(cp -fru / testsite / / othersite /)并通过每个vhost强制根据修改日期更新文件.我们托管的每个附加服务器都有一个vhost,我们将生产代码库与同步,然后我们在该服务器上的所有站点上重复复制过程.在此过程中,我们移出了我们不想被覆盖的文件,在复制完成后将它们移回.我们的rollout脚本执行许多其他功能,例如应用sql命令来更改每个数据库,添加字段/新表等.

我们越来越担心我们的过程不够稳定,不容错,也是一种蛮力方法.我们也意识到我们没有充分利用颠覆,因为我们有一个位置,即在我们不使用分支或标签时,处理新功能会阻止我们推出重要的错误修复.我们在服务器上进行了如此多的文件复制似乎也是错误的.我们也无法轻松地对刚刚推出的内容进行回滚.我们在每次推出之前都会执行差异,因此我们可以获得将要更改的文件列表,以便我们知道之后已经更改的内容,但回滚过程仍然存在问题.就数据库而言,我已开始将dbdeploy视为一种潜在的解决方案.我们真正想要的是关于如何改进文件管理和部署的一般指导.理想情况下,我们希望文件管理与我们的存储库更紧密地链接,因此rollout / rollback将更多地连接到svn.比如使用export命令确保站点文件与repo文件相同.如果解决方案可能也会停止我们服务器周围的文件复制,那也不错.

忽略我们当前的方法,听听其他人如何处理同样的问题真的很好.

总结一下……

>制作文件的最佳方式是什么
跨多个服务器保持同步
与svn?
>我们应该如何防止文件
复制?符号链接/东西
其他?
>我们应该如何构建我们的回购
我们可以开发新功能并修复旧功能
那些?
>我们应该如何触发
首次展示/回滚?

提前致谢

编辑:

最近我读了很多关于使用Phing和Capistrano来完成这些任务的好东西.任何人都可以提供更多关于它们的信息以及它们对于这种任务有多好吗?

我对发布版本的建议是具有功能发布和维护版本.功能发布将是获得新功能的版本.这些都会添加到您的subversion主干中.如果您认为这些功能已完成,请将这些功能分支到发布分支中.一旦您的QA流程对此版本感到满意,您就可以标记版本并将代码部署到您的服务器.

现在,当您收到错误报告时,您将此修复程序提交给分支并将其移植到主干.当您对修复的错误数量感到满意时,您可以标记和部署维护版本.

重要的是,您的实时代码库的分支(或者能够通过了解实时修订创建一个分支)与开发分支分开,这样您就可以将修复程序部署到实时代码而无需部署新功能或未经测试的代码.

我建议使用您的发行版的本机打包系统来部署新代码.如果你有一个包含所有代码库的软件包,你知道你的所有代码都是在一种原子操作中部署的,你可以一目了然地查看安装的版本,可以使用软件包校验和来验证你的代码库.回滚只是安装以前安装的软件包版本的一种情况.

我可以看到实现这一点的唯一障碍是,您似乎拥有在单个服务器上运行的不同客户的代码库的多个副本.我会尝试安排您的代码,以便所有客户都使用相同的文件并且不使用副本.我不知道这对你有多容易,但减少你必须处理的副本数量将大大减轻你的头痛.

我假设你提到LAMP时,你正在使用PHP或其他脚本语言,这不需要编译过程.这意味着你可能错过了一个名为持续集成的精彩过程.这基本上意味着你的代码不断被测试,以确保它仍处于可释放的状态.每次有人检查新代码时,进程都会接受并运行构建和测试过程.使用编译语言,您通常会使用它来确保代码仍然编译.你应该利用每种语言运行单元测试(你的代码是可测试的单元不是吗?)和集成测试.对于网站来说,测试集成测试的一个好工具是Selenium.在我们的Java构建中,我们还测量代码覆盖率和代码度量,以了解我们如何随着时间推移而进展.我们为Java找到的最好的CI服务器是Hudson,但像buildbot这样的东西可能更适合其他语言.您可以使用CI服务器构建包.

php – 改进我们的部署策略的更多相关文章

  1. 基于EJB技术的商务预订系统的开发

    用EJB结构开发的应用程序是可伸缩的、事务型的、多用户安全的。总的来说,EJB是一个组件事务监控的标准服务器端的组件模型。基于EJB技术的系统结构模型EJB结构是一个服务端组件结构,是一个层次性结构,其结构模型如图1所示。图2:商务预订系统的构架EntityBean是为了现实世界的对象建造的模型,这些对象通常是数据库的一些持久记录。

  2. js中‘!.’是什么意思

  3. InnoDB 和 MyISAM 引擎恢复数据库,使用 .frm、.ibd文件恢复数据库

  4. Error: Cannot find module ‘node:util‘问题解决

    控制台 安装 Vue-Cli 最后一步出现 Error: Cannot find module 'node:util' 问题解决方案1.问题C:\Windows\System32>cnpm install -g @vue/cli@4.0.3internal/modules/cjs/loader.js:638 throw err; &nbs

  5. yarn的安装和使用(全网最详细)

    一、yarn的简介:Yarn是facebook发布的一款取代npm的包管理工具。二、yarn的特点:速度超快。Yarn 缓存了每个下载过的包,所以再次使用时无需重复下载。 同时利用并行下载以最大化资源利用率,因此安装速度更快。超级安全。在执行代码之前,Yarn 会通过算法校验每个安装包的完整性。超级可靠。使用详细、简洁的锁文件格式和明确的安装算法,Yarn 能够保证在不同系统上无差异的工作。三、y

  6. 前端环境 本机可切换node多版本 问题源头是node使用的高版本

    前言投降投降 重头再来 重装环境 也就分分钟的事 偏要折腾 这下好了1天了 还没折腾出来问题的源头是node 使用的高版本 方案那就用 本机可切换多版本最终问题是因为nodejs的版本太高,导致的node-sass不兼容问题,我的node是v16.14.0的版本,项目中用了"node-sass": "^4.7.2"版本,无法匹配当前的node版本根据文章的提

  7. 宝塔Linux的FTP连接不上的解决方法

    宝塔Linux的FTP连接不上的解决方法常见的几个可能,建议先排查。1.注意内网IP和外网IP2.检查ftp服务是否启动 (面板首页即可看到)3.检查防火墙20端口 ftp 21端口及被动端口39000 - 40000是否放行 (如是腾讯云/阿里云等还需检查安全组)4.是否主动/被动模式都不能连接5.新建一个用户看是否能连接6.修改ftp配置文件 将ForcePassiveIP前面的#去掉 将19

  8. 扩展element-ui el-upload组件,实现复制粘贴上传图片文件,带图片预览功能

  9. 微信小程序canvas实现水平、垂直居中效果

    这篇文章主要介绍了小程序中canvas实现水平、垂直居中效果,本文图文实例代码相结合给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

  10. 使用HTML5做的导航条详细步骤

    这篇文章主要介绍了用HTML5做的导航条详细步骤,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

随机推荐

  1. PHP个人网站架设连环讲(一)

    先下一个OmnihttpdProffesinalV2.06,装上就有PHP4beta3可以用了。PHP4给我们带来一个简单的方法,就是使用SESSION(会话)级变量。但是如果不是PHP4又该怎么办?我们可以假设某人在15分钟以内对你的网页的请求都不属于一个新的人次,这样你可以做个计数的过程存在INC里,在每一个页面引用,访客第一次进入时将访问时间送到cookie里。以后每个页面被访问时都检查cookie上次访问时间值。

  2. PHP函数学习之PHP函数点评

    PHP函数使用说明,应用举例,精简点评,希望对您学习php有所帮助

  3. ecshop2.7.3 在php5.4下的各种错误问题处理

    将方法内的函数,分拆为2个部分。这个和gd库没有一点关系,是ecshop程序的问题。会出现这种问题,不外乎就是当前会员的session或者程序对cookie的处理存在漏洞。进过本地测试,includes\modules\integrates\ecshop.php这个整合自身会员的类中没有重写integrate.php中的check_cookie()方法导致,验证cookie时返回的username为空,丢失了登录状态,在ecshop.php中重写了此方法就可以了。把他加到ecshop.php的最后面去就可

  4. NT IIS下用ODBC连接数据库

    $connection=intodbc_connect建立数据库连接,$query_string="查询记录的条件"如:$query_string="select*fromtable"用$cur=intodbc_exec检索数据库,将记录集放入$cur变量中。再用while{$var1=odbc_result;$var2=odbc_result;...}读取odbc_exec()返回的数据集$cur。最后是odbc_close关闭数据库的连接。odbc_result()函数是取当前记录的指定字段值。

  5. PHP使用JpGraph绘制折线图操作示例【附源码下载】

    这篇文章主要介绍了PHP使用JpGraph绘制折线图操作,结合实例形式分析了php使用JpGraph的相关操作技巧与注意事项,并附带源码供读者下载参考,需要的朋友可以参考下

  6. zen_cart实现支付前生成订单的方法

    这篇文章主要介绍了zen_cart实现支付前生成订单的方法,结合实例形式详细分析了zen_cart支付前生成订单的具体步骤与相关实现技巧,需要的朋友可以参考下

  7. Thinkphp5框架实现获取数据库数据到视图的方法

    这篇文章主要介绍了Thinkphp5框架实现获取数据库数据到视图的方法,涉及thinkPHP5数据库配置、读取、模型操作及视图调用相关操作技巧,需要的朋友可以参考下

  8. PHP+jquery+CSS制作头像登录窗(仿QQ登陆)

    本篇文章介绍了PHP结合jQ和CSS制作头像登录窗(仿QQ登陆),实现了类似QQ的登陆界面,很有参考价值,有需要的朋友可以了解一下。

  9. 基于win2003虚拟机中apache服务器的访问

    下面小编就为大家带来一篇基于win2003虚拟机中apache服务器的访问。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  10. Yii2中组件的注册与创建方法

    这篇文章主要介绍了Yii2之组件的注册与创建的实现方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下

返回
顶部