Передача данных POST в сокет домена unix через nginx - PullRequest
0 голосов
/ 20 марта 2019

У меня есть файл сокета домена unix, и он работает с командой nc. Теперь я хочу получить к нему доступ через nginx, но он не работает. Я что-то упустил?

тест с nc => работает

$ echo  '{ "method" : "getinfo", "params" : [], "id" : "1" }' | nc -U /home/zono/.lightning/lightning-rpc
{ "jsonrpc": "2.0", "id" : "1", "result" :
{
  "id": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
}

тест через nginx => не работает

// /etc/nginx/sites-enabled/default
upstream nginx-internal-sock {
  server unix:/home/zono/.lightning/lightning-rpc;
}

server {
  listen 80;
  location / {
    proxy_pass http://nginx-internal-sock;
  }
}

$ curl -H "content-type: application/json" -X POST --data '{ "method" : "getinfo", "params" : [], "id" : "1" }' http://127.0.0.1
2019-03-20T04:25:52.551Z lightningd(30143):jcon fd 32: Invalid token in json input: 'POST / HTTP/1.0??Host: nginx-internal-sock??Connection: close??C'

Обновление 1

Там было развитие. Однако я не могу получить целые данные.

// install nginx-extras
apt-get install nginx-extras

// /etc/nginx/sites-enabled/default
server {
  listen 80;

  location / {
        content_by_lua '
            ngx.req.read_body()
            local body_data = ngx.req.get_body_data()

            local sock = ngx.socket.tcp()
            local ok, err = sock:connect("unix:/home/zono/.lightning/lightning-rpc")

            local bytes = sock:send(body_data)

            local line, err = sock:receive("*a")
            ngx.say(line)

            ok, err = sock:close()
        ';
  }
}

// Response is nil
$ curl -X POST --data '{ "method" : "getinfo", "params" : [], "id" : "1" }' http://127.0.0.1
nil

// /var/log/nginx/error.log
2019/03/20 07:43:39 [error] 4926#4926: *35 lua tcp socket read timed out, client: 127.0.0.1, server: , request: "POST / HTTP/1.1", host: "127.0.0.1"

// When I set "sock:receive("*l")" the response is the part of the data.
$ curl -X POST --data '{ "method" : "getinfo", "params" : [], "id" : "1" }' http://127.0.0.1
{ "jsonrpc": "2.0", "id" : "1", "result" :

Я сейчас проверяю ссылку. http://w3.impa.br/~diego/software/luasocket/tcp.html

'* a': чтение из сокета до тех пор, пока соединение не будет закрыто. Перевод конца строки не выполняется;

'* l': читает строку текста из сокета. Строка оканчивается символом LF (ASCII 10), опционально предшествует символ CR (ASCII 13). Символы CR и LF не включены в возвращаемую строку. Фактически, все символы CR игнорируются шаблоном. Это шаблон по умолчанию;

число: метод считывает указанное число байтов из сокета.

1 Ответ

0 голосов
/ 20 марта 2019

Я узнал ответ.

// install nginx-extras
apt-get install nginx-extras

// /etc/nginx/sites-enabled/default
server {
  listen 80;

  location / {
        content_by_lua '
            ngx.req.read_body()
            local body_data = ngx.req.get_body_data()

            local sock = ngx.socket.tcp()
            local ok, err = sock:connect("unix:/home/zono/.lightning/lightning-rpc")

            local bytes = sock:send(body_data)

            local readline = sock:receiveuntil("\\n\\n")
            local line, err, part = readline()
            if line then
                ngx.say(line)
            end

            ok, err = sock:close()
        ';
  }
}

// curl
$ curl -X POST --data '{ "method" : "getinfo", "params" : [], "id" : "1" }' http://127.0.0.1
...