微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – 关于如何在一直使用的网站上运行维护的任何想法?

我帮助澳大利亚的一个大型游戏网站.我们从当地时间早上7点到第二天凌晨1点开始比赛,每周一天.自网站发布以来,我们没有跳过一天.当然,这使得维护非常难以运行,并且我们发现我们的登台服务器在我们的生产分支之前最多提交了50个.通常,主开发必须极早醒来以合并分支并确保一切正常.

我们一直在努力使我们的临时站点尽可能地与生产站点相似,但我们只能使它变得如此相似.

我们的网站基于Laravel,具有实时的Node.JS服务器.我们正在使用Laravel Forge.

有没有人对如何更频繁地推送更新有任何建议?我们愿意接受任何事情.

您可以采取许多措施来改进部署过程.其中一些是:

>确保您的代码经过充分测试.

理想情况下,您应该拥有100%的单元测试覆盖率,以及针对每种可能的场景进行集成测试.

如果你没有这个,你应该放弃一切并得到这个照顾.

研究行为驱动的发展.

拥有完整的测试套件将允许您……
>运行持续集成.

每当有人提交更改时,CI就可以自动运行测试套件.如果测试套件通过,则可以立即部署(或安排部署).对于不需要对数据库进行任何重大更改的更改,仅此一项就可以为您节省大量时间和精力.

如果出现问题,CI还可以为您提供一键式回滚.

如果您的测试套件不完整和正确,则CI不太有用,因为整个前提依赖于能够以自动方式验证您的代码.
>进行原子更新.

理想情况下,您不应只是在生产服务器上复制旧文件.而是使用capistrano等工具将每个文件复制到新位置,然后使用符号链接指向所需的部署.回滚是即时的,因为它涉及简单地将符号链接更改为指向先前的部署. (虽然这不一定涵盖您的数据库迁移.)

还要看看Docker等容器是否可以帮助你.
>进行更小,更频繁的更改.

无论您是否有测试,CI或什么都没有,这一点可以帮助您.每个更改都应该有自己的git分支,并且部署应该尽可能少地进行更改.由于更改较小,因此在部署期间可能出错的可能性较小.

在这方面,尽可能使更改更加孤立.如果您对奥马哈游戏进行了更改,并且它不会影响德州扑克,5张卡片或任何其他内容,那么这是唯一需要暂停维护的游戏.
>分析长期运行的任何事情.

您提到部署的某些部分需要很长时间.这可能是数据库架构更改.值得让DBA查看您的数据库以及每个架构更改,以查看可以更好地执行哪些操作.

主题专家查看占用大量时间的部署的任何其他部分.
>工作奇数小时.

你可能已经这样做了,但值得一提的是.不应期望开发人员(和系统管理员!)不再工作“9到5”,尤其是24×7全天候运行.如果有人预计会花一夜的时间照顾部署,解决任何问题,然后保持白天的日程安排,那么你的期望是不现实的,而且你正在设置那个人倦怠.

原文地址:https://www.jb51.cc/php/139890.html

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

相关推荐