Socket Connection в NodeMCU Lua работает как фрагмент, а не из init.lua

У меня есть следующий код

conn = net.createConnection(net.TCP, 0)  
conn:on("sent", function(sck,c) 
   print("Sent")
   sck:close() 
   end)

conn:on("connection", function(sck,c) 
   print("Connected..")
   sck:send("test") 
   end)

 conn:connect(9090, "192.168.1.89")
 print("Send data.")

Это отлично работает при запуске в качестве фрагмента в ESPlorer, IE запускает живой интерпретатор. Я вижу вывод «Подключено..» и «Отправлено», и на сервере появляется сообщение. Когда он является частью файла init.lua или моего mcu-temp.lua, я даже не вижу сообщения «Подключено..».

Соединение с WIFI в порядке, и плата не сбрасывается между попыткой «вживую» и из файла. Я действительно застрял в том, почему это работает нормально в одну сторону, а не в другую.


person Martin    schedule 30.05.2016    source источник


Ответы (1)


Соединение с WIFI в порядке

Я серьезно сомневаюсь в этом. Если запускать из ESPlorer то да, но не при перезагрузке устройства.

Обычно подключение к точке доступа занимает несколько секунд. Вам нужно подождать, пока он не будет подключен, прежде чем вы сможете продолжить последовательность запуска. Помните: с NodeMCU большинство операций асинхронны и управляются событиями, wifi.sta.connect() НЕ блокируется.

Вот последовательность запуска, которую я позаимствовал и адаптировал с сайта https://cknodemcu.wordpress.com/.

SSID = <tbd>
PASSWORD = <tbd>

function startup()
    local conn = net.createConnection(net.TCP, 0)  
    conn:on("sent", function(sck, c) 
       print("Sent")
       sck:close() 
    end)

    conn:on("connection", function(sck, c) 
       print("Connected..")
       sck:send("test") 
    end)

    conn:connect(9090, "192.168.1.89")
    print("Sent data.")
end

print("setting up WiFi")
wifi.setmode(wifi.STATION)
wifi.sta.config(SSID,PASSWORD)
wifi.sta.connect()
tmr.alarm(1, 1000, 1, function() 
    if wifi.sta.getip() == nil then 
        print("IP unavaiable, Waiting...") 
    else 
        tmr.stop(1)
        print("Config done, IP is "..wifi.sta.getip())
        print("You have 5 seconds to abort startup")
        print("Waiting...")
        tmr.alarm(0, 5000, 0, startup)
    end 
 end)

Всего два дня назад я ответил почти на тот же вопрос здесь, на SO. См. https://stackoverflow.com/a/37495955/131929 альтернативное решение.

person Marcel Stör    schedule 30.05.2016
comment
Сценарий инициализации намного лучше, чем тот, который был у меня, поэтому я определенно использую его. Хотя это не решило проблему. Я запустил «nc -l 192.168.1.84 9090» на целевом хосте, а также в исходном приложении nodejs, которое я написал, и я не получаю сообщение о подключении из событий сокета. - person Martin; 30.05.2016
comment
Прошу прощения, получилось! Виноваты правила брандмауэра после перезапуска ВМ. - person Martin; 30.05.2016