Remote Debug 远程调试¶
提示
说明:远程调试通信基于socket,内核基于mobdebug.lua ,依赖于luasocket模块,所以被调试的程序需要支持luasocket
远程调试要先启动,再启动目标程序
1. 执行步骤¶
- 配置Remote调试设置,点击右上角
Edit Configurations
data:image/s3,"s3://crabby-images/b1e54/b1e544694bb53dd2b019ab8f42a6fc50511f53c6" alt="../_images/debug-config.png"
- 点击
+
选择并创建Lua Remote(Mobdebug)
配置
data:image/s3,"s3://crabby-images/58967/58967e7e08cf8e99a7a0ae41a56778b2b84d9ba0" alt="../_images/debug-config2.png"
- 设置好相关参数后点击OK
data:image/s3,"s3://crabby-images/27fa6/27fa6cce801b44a07b27a3538843597d0e7f700a" alt="../_images/debug-config3.png"
- 点击右上角debug按钮
data:image/s3,"s3://crabby-images/3ff35/3ff353681be78a784d48c0dfab9e2dc3258a34e1" alt="../_images/debug-config4.png"
- 注意IDEA控制台LOG输出,如下图所示表示启动
data:image/s3,"s3://crabby-images/801db/801dbe481a77242ce50720db79dd927ac831085f" alt="../_images/debug-config5.png"
- 下载
mobdebug.lua
并在目标程序的lua代码入口处添加代码
1 | require("mobdebug").start()
|
或者
1 | require("mobdebug").start("host-ip", port) --默认值为 "localhost", 8172
|
- 最后启动目标程序,并注意IDEA控制台窗口,出现下图所示`Connected`则表示调试器连接成功并可以添加断点并调试了
data:image/s3,"s3://crabby-images/e672f/e672f6794f93747fdeeccb3417f98bcefb610ee0" alt="../_images/debug-config6.png"
2. 失败相关问题排查¶
运行目标程序后控制台并没有出现`Connected`日志
- 确认目标程序包含luasocket模块
- 确认调试端口一致(默认是8172端口)
Connected
日志有,但断点无效检查
Sources
目录设置正确检查目标程序在运行时提供的文件名与源码文件的文件名一致(致少除了后缀名的前面的部分一致)
此项检查快捷方式是在
mobdebug.lua
的1
local function has_breakpoint(file, line)
函数中打印输出
file