Удаленная отладка Openresty LUA в Docker с помощью IDEA

У меня есть приложение openresty в контейнере докеров:

FROM openresty/openresty:xenial

RUN luarocks install luasocket

# Add additional binaries into PATH for convenience
ENV PATH=$PATH:/usr/local/openresty/luajit/bin:/usr/local/openresty/nginx/sbin:/usr/local/openresty/bin
ENV LUA_PATH="/usr/local/openresty/site/lualib/?.ljbc;/usr/local/openresty/site/lualib/?/init.ljbc;/usr/local/openresty/lualib/?.ljbc;/usr/local/openresty/lualib/?/init.ljbc;/usr/local/openresty/site/lualib/?.lua;/usr/local/openresty/site/?.lua;/usr/local/openresty/site/lualib/?/init.lua;/usr/local/openresty/site/?/init.lua;/usr/local/openresty/lualib/?.lua;/usr/local/openresty/lualib/?/init.lua;./?.lua;/usr/local/openresty/luajit/share/luajit-2.1.0-beta3/?.lua;/usr/local/share/lua/5.1/?.lua;/usr/local/share/lua/5.1/?/init.lua;/usr/local/openresty/luajit/share/lua/5.1/?.lua;/usr/local/openresty/luajit/share/lua/5.1/?/init.lua"
ENV LUA_CPATH="/usr/local/openresty/site/lualib/?.so;/usr/local/openresty/lualib/?.so;./?.so;/usr/local/lib/lua/5.1/?.so;/usr/local/openresty/luajit/lib/lua/5.1/?.so;/usr/local/lib/lua/5.1/loadall.so;/usr/local/openresty/luajit/lib/lua/5.1/?.so"
CMD ["/usr/local/openresty/bin/openresty", "-g", "daemon off;"]

Вот пример nginx.conf:

server {
    listen       80;
    server_name  localhost;

    # disable code cache, do not need reload nginx with all changes
    lua_code_cache off;

    location / {
        rewrite_by_lua_block {
            local Core = require "core"
            Core.rewrite()
        }
    }
}

Основной исходный файл lua (с точками останова в каждой строке):

_G.debug = require("debug")

local Core = {}

function Core:rewrite()
    require("mobdebug").start("host.docker.internal")
    local a = 2
    ngx.say(a)
end

return Core

Итак, я пытаюсь использовать EmmyLua (IDEA) + mobdebug для удаленной отладки моего приложения openresty.

Конфигурация каталогов IDEA

После запуска отладки + сделанный http-вызов:

Start mobdebug server at port:8172
Waiting for process connection...
Connected.

И ничего не происходит после этого. Я вижу ответ от openresty, но отладка все еще активна с сообщением «Подключено».

Что я делаю неправильно?


person Dmitriy Vorobey    schedule 09.07.2019    source источник
comment
семейство директив init_by_lua_* инициализирует экземпляр nginx; который является потоком, отличным от рабочих процессов, которые в конечном итоге обрабатывают запросы. Если я правильно помню, вместо этого вам нужно требовать вещи в одной из директив init_worker_by_lua_*, иначе они не будут найдены.   -  person DarkWiiPlayer    schedule 10.07.2019
comment
Неважно, я только что проверил, и это не имеет значения. Однако я обнаружил, что отключение кеша кода Lua приводит к тому, что переменные, объявленные в init_by_lua, забываются. В заключение, я думаю, мой совет: Всегда запрашивайте вещи там, где они вам нужны. В продакшне они могут кэшироваться, в dev они могут требоваться каждый раз; в любом случае, это деталь реализации.   -  person DarkWiiPlayer    schedule 10.07.2019
comment
@DarkWiiPlayer, локальные требования не помогают. Я обновил свой вопрос с примером.   -  person Dmitriy Vorobey    schedule 10.07.2019


Ответы (2)


А has_breakpoint_file всегда логирует time.lua... Если я поставлю несколько брейкпоинтов - то все они будут логироваться в set_breakpoint, но ни один в has_breakpoint не работает.

Я не вижу никаких проблем с вашей настройкой. Пока выполнение проходит через эту конкретную строку и срабатывает ловушка отладки, вы должны увидеть вызов has_breakpoint (если только вы не «проходите» код вручную).

Если этого не происходит, вы можете проверить, выполняется ли код, в котором вы устанавливаете точки останова, в сопрограмме, поскольку отладка сопрограммы должна быть явно включена. Подробнее см. в этом разделе документации.

Если это все еще не помогает, вы можете добавить несколько команд print в функцию debug_hook в mobdebug, чтобы увидеть, срабатывает ли она на этих строках с точками останова, и что происходит после этого.

person Paul Kulchenko    schedule 11.07.2019

Как запустить образ докера с открытыми портами? Вы получили сообщение «Ошибка привязки для 0.0.0.0:8172: порт уже выделен»?

Спасибо, Ирина

person Irina    schedule 21.08.2019