php – 关于如何在一直使用的网站上运行维护的任何想法?
|
我帮助澳大利亚的一个大型游戏网站.我们从当地时间早上7点到第二天凌晨1点开始比赛,每周一天.自网站发布以来,我们没有跳过一天.当然,这使得维护非常难以运行,并且我们发现我们的登台服务器在我们的生产分支之前最多提交了50个.通常,主开发必须极早醒来以合并分支并确保一切正常. 我们一直在努力使我们的临时站点尽可能地与生产站点相似,但我们只能使它变得如此相似. 我们的网站基于Laravel,具有实时的Node.JS服务器.我们正在使用Laravel Forge. 有没有人对如何更频繁地推送更新有任何建议?我们愿意接受任何事情. 您可以采取许多措施来改进部署过程.其中一些是:>确保您的代码经过充分测试. 理想情况下,您应该拥有100%的单元测试覆盖率,以及针对每种可能的场景进行集成测试. 如果你没有这个,你应该放弃一切并得到这个照顾. 研究行为驱动的发展. 拥有完整的测试套件将允许您…… 每当有人提交更改时,CI就可以自动运行测试套件.如果测试套件通过,则可以立即部署(或安排部署).对于不需要对数据库进行任何重大更改的更改,仅此一项就可以为您节省大量时间和精力. 如果出现问题,CI还可以为您提供一键式回滚. 如果您的测试套件不完整和正确,则CI不太有用,因为整个前提依赖于能够以自动方式验证您的代码. 理想情况下,您不应只是在生产服务器上复制旧文件.而是使用capistrano等工具将每个文件复制到新位置,然后使用符号链接指向所需的部署.回滚是即时的,因为它涉及简单地将符号链接更改为指向先前的部署. (虽然这不一定涵盖您的数据库迁移.) 还要看看Docker等容器是否可以帮助你. 无论您是否有测试,CI或什么都没有,这一点可以帮助您.每个更改都应该有自己的git分支,并且部署应该尽可能少地进行更改.由于更改较小,因此在部署期间可能出错的可能性较小. 在这方面,尽可能使更改更加孤立.如果您对奥马哈游戏进行了更改,并且它不会影响德州扑克,5张卡片或任何其他内容,那么这是唯一需要暂停维护的游戏. 您提到部署的某些部分需要很长时间.这可能是数据库架构更改.值得让DBA查看您的数据库以及每个架构更改,以查看可以更好地执行哪些操作. 让主题专家查看占用大量时间的部署的任何其他部分. 你可能已经这样做了,但值得一提的是.不应期望开发人员(和系统管理员!)不再工作“9到5”,尤其是24×7全天候运行.如果有人预计会花一夜的时间照顾部署,解决任何问题,然后保持白天的日程安排,那么你的期望是不现实的,而且你正在设置那个人倦怠. (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
