记一次远程Debug调试Minecraft服务器插件经历

文章前言

本文是笔者通过自己学习过程中整理出来的笔记,如有漏洞和不足,请向我反馈。
笔者使用环境:
IntelliJ IDEA 2022.1.3(Ultimate Edition)(目前最新)
Amazon Corretto OpenJDK 11
Mnecraft Paper 1.16.5 Server
大家可以根据自己需求更改环境,版本差异不会太大

晚上正在为团队的Minecraft服务器部署新的插件,具体插件名称这里就不提了,依照团队部署规范,让插件对接了数据库,开启服务器后调试中遇到了问题。

插件报错内容如下图:
在这里插入图片描述
从图中可以看出,该报错信息是在SQL语句执行时发出的错误,具体语句是在插件某个类的createTable()方法中,也就是创建数据表方法,初步分析应该是SQL语句拼写错了,于是我就开始各种调试。

首先我先翻阅插件的源代码,找到了这个方法:
在这里插入图片描述
从源码可以分析出,这是通过反射来获取Bean中的属性名和属性类型,来拼接SQL语句,从源码上看建表方法是没有任何问题的,于是我又检查了MySQL数据库的General Log日志

在这里插入图片描述
这个插件有4个Bean类需要创建数据库,而只有3个建表语句执行成功,那说明问题就出在第四个Bean上,但我当时没有仔细看那个Bean中的属性,疏忽了,既然MySQL的日志查不到错误的语句,那我干脆直接使用了JProfiler工具,看看能不能远程调试出错误的SQL语句。

在这里插入图片描述
但结果不尽人意,还是只捕捉到了执行成功的SQL语句,错误的那条没有被捕捉到,怎么办呢,我只能再使用IDEA打断点远程Debug来试试了

首先先在项目中配置好远程JVM调试:(远程JVM的启动参数也不要忘记)
在这里插入图片描述

然后在源代码中,打断点,这里我直接在最后return的结果那打断点:
在这里插入图片描述

开启调试,重启服务器,随着插件的进一步加载,成功命中源代码,获取到最后返回的SQL语句:
![在这里插入图片描述](https://img-blog.csdnimg.cn/d4b3f2bd9cbe445b812c231a972c08f9.png

格式化后:

create table if not exists sale
(
    id       int primary key not null auto_increment,
    stack    varchar(255),
    meta     varchar(255),
    nbt      varchar(255),
    appear   bigint,
    owner    varchar(255),
    buyer    varchar(255),
    price    varchar(31),
    cost     varchar(31),
    heat     int,
    nickname varchar(255),
    desc     varchar(255),
    classify varchar(255),
    auction  bit,
    point    bit,
    admin    bit
);

大家有没有发现什么问题?有个 desc 字段,建表时没有加上单引号,作者可能忽略了这个问题
在这里插入图片描述

在此之前我也没用仔细检查Bean中的各个属性名,没有想到这个问题,在这次的经历中丰富了经验,大家在开发时要记得注意一下保留关键字的使用,不要因为一时的疏忽,Debug一晚上。

编码不规范:
在这里插入图片描述

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Nicholas_LD

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值