记一次改代码后本地正常,开发环境服务能启动,一个生产环境发布正常,另一个生产环境服务启动失败的事故(还好没杀程序员祭天)以警示

本文主要是介绍记一次改代码后本地正常,开发环境服务能启动,一个生产环境发布正常,另一个生产环境服务启动失败的事故(还好没杀程序员祭天)以警示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题描述:这两天在工作中的两个项目优化一点同样写死的代码,大概是这样的↓

1203220171237629901和1203220171237629902是写死的,但其实可以通过Redis中动态获取,改完之后一个项目中本地测试跑main方法没问题,服务也能启动↓

另一个项目本地启动服务也能起来,不过有一些相关的报错↓

发布到线上后,服务启动失败,一个Service对象创建失败↓

子系统宕机10分钟,被运维人员吐槽,还好不是白天,要不然真是要杀程序员祭天了,扣绩效都是小事。

 

项目概况和环境:改动涉及到两个工程,都是Spring Boot项目,一个工程是用来定时跑任务的,一个工程是业务后台,跑任务的工程没用配置中心,跑业务后台的工程用了配置中心,配置中心这边有公共的配置文件application.yml,以及多个服务各个环境的配置文件↓

   

 

 

分析问题:

找到创建失败的Service,发现在static代码块有一句代码是通过RedisTemplate获取器的一个方法获取RedisTemplate对象,熟悉Spring的后端开发同学都知道Service对象会纳入Spring Bean管理,自动初始化,static代码块中的代码会随着初始化,此时就会获取RedisTemplate对象,而要获取Redis肯定要依赖配置文件的配置,代码也是这么写的↓

本地环境是dev,会去找application-dev.yml,本地也有这个文件,跑任务的工程发布到开发环境,此时环境也是dev,正常,发布到正式环境是prod,也正常。业务后台的工程当时没有发布到开发环境,直接发到线上去了,服务启动失败。我就很纳闷为什么同样的修改一个生产正常,一个生产事故,后来再仔细想了下,发现问题:跑任务的工程没有用配置中心,线上环境有各个环境对应的application-%s.yml文件并且有Redis配置,跑业务后台的工程用了配置中心,没有application-prod.yml文件导致报错。

 

心得:

1.要遵循发布流程,上生产的代码一定要先上测试环境通过测试

2.要求自己把控好质量关,开发环境一定要验证,而不仅仅只是单元测试或者跑main方法通过就行了

3.加强工作中的沟通,存在不确定时要询问主管或其他同事确认

欢迎各位大佬留言讨论。我还不想死呀,以后要更严谨。

这篇关于记一次改代码后本地正常,开发环境服务能启动,一个生产环境发布正常,另一个生产环境服务启动失败的事故(还好没杀程序员祭天)以警示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1055671

相关文章

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

Java服务实现开启Debug远程调试

《Java服务实现开启Debug远程调试》文章介绍如何通过JVM参数开启Java服务远程调试,便于在线上排查问题,在IDEA中配置客户端连接,实现无需频繁部署的调试,提升效率... 目录一、背景二、相关图示说明三、具体操作步骤1、服务端配置2、客户端配置总结一、背景日常项目中,通常我们的代码都是部署到远程

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路