目录

问题现象:

问题分析:

        1、密码中的特殊字符。

        2、密码长度问题。

解决方法:

拓展:


问题现象:

        今天生产环境使用xxljob任务调度创建执行任务时,出现程序报错

        通过查询xxljob日志

        定位报错点的代码检查代码本地debug后,发现是没问题的;而且在开发环境测试环境一直都能正常运行,为啥到生产环境报错了呢?真是百思不得其解,后来只能不断翻看接口调用相关服务日志,终于看到一丝异常:在接口调用结束后,我发现如图所示信息::


问题分析

        从图片可以得知一下几个信息

        1、从&gt;&gt; trigger Xxl-job &lt;< response关键词可知:这是本服务连接xxljob后,xxljob响应相关信息

        2、从[HTTP/1.1 302 Found]可知:这是重定向错误

        3、从[keepalive]可知:这应该是本服务xxljob服务间的心跳检测机制,也就是定期发送连接请求检查服务间的正常通信

        4、从Location所示地址可知:心跳机制链接xxljob服务登录接口通过浏览器访问可以看到如下图所示的登录界面

        当时看到这个302报错的时候,真的是一脸懵逼,为啥会是重定向错误呢?难道是ip有误?域名不对?服务开启防火墙导致无法调用?做了nginx转发url写错了?

        于是我就去看了本服务中的xxljob配置

        经过反反复复的检查,依旧发现不出任何问题

        也试过ip域名方式访问xxljob还是没有发现问题所在

        最终只能采用最基础的方法直接自己本地debug连接生产环境xxljob看看是否也会报错,通过本地调用xxljob的登录api,终于发现问题真正的报错信息

账号密码错误

        至此,才明白原来并不是302报错,这应该是401报错才对啊!

        既然知道真正的报错信息,那问题就好办了。

        通过对比开发环境、测试环境生产环境的账号和密码发现

        三个环境的账号是一样的,那问题肯定就出在密码上面了,其中开发环境、测试环境的密码是一样的,生产环境的密码复杂很多,毕竟是考虑安全性

        1、密码中的特殊字符

        2、密码长度问题

        亲测发现,三个环境的密码都带有特殊字符,所以排除了原因1;通过上文中提到的xxljob的登录界面输入密码发现,原来xxljob的密码长度上限是18位,超过18位后的输入无效通过查看三个环境的密码发现:开发测试环境的密码是一样的,且长度并未超过18位,而生产环境的密码刚好就是19位,超过了xxljob的密码长度上限(18位) 。

        终于定位到了问题原因,那接下来解决问题就变得非常简单了。


解决方法

        首先是修改xxljob服务的密码,保证密码长度不超过18位;然后修改各服务中调用的xxljob服务配置的密码;重启服务后即可正常连接了:


拓展

        按我的理解【账号或密码错误这个应该属于HTTP 401错误才对,也就是身份认证失败用户没有访问权限;实在没懂为什么心跳机制会出现HTTP 302错误

        简单地在网上查了一下资料,发现找不到有和我类似情况的有用信息,希望有知道原因大佬赐教一下!否则只能是自己在日后有时间上xxljob官网查查文档了。

原文地址:https://blog.csdn.net/weixin_42585386/article/details/131898966

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_42642.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注