3

UNIX ソケットを使用して、PHP に IPC メッセージを Go に送信させようとしています。PHP がソケットからの応答を読み取り続けているように見え、手放さないことを除いて、すべてが機能しているように見えます。(ブラウザのロードスピナーは動き続け、ページのレンダリングはありません。) PHP:socket_read() 関数でフラグ PHP_NORMAL_READ を使用し、Go から "\n" を明示的に送信しています。

ターミナルで Go プロセスを見ると、すべてが正しく動作しているように見えます。

編集:ブラウザのキャッシュの問題だったと思います。PHP がエコーするために別のデータを送り返すと、すべてが期待どおりに機能します。また、 fmt.Fprintln() に切り替えて、改行が間違っていないことを確認しました。

行け:

package main

import (
    "net"
    "fmt"
    "log"
    "os"
)

const socket_addr = "/tmp/odc_ws.sock"

func echoServer(c net.Conn){
    buf := make([]byte, 512)
    size, err := c.Read(buf)
    if err != nil {
        log.Fatal("Read error: ", err)
    }
    data := buf[0:size]     
    fmt.Println("Server received: ", string(data))

    // NEW CODE
    t := time.Now()
    retMsg := fmt.Sprintf("OK+ at %s", t)
    size, err = fmt.Fprintln(c, retMsg)     

    //size, err = c.Write(ok)

    if err == nil{
        fmt.Println("Wrote this many bytes: ", size)
    } else {
        log.Fatal("Write error: ", err)
    }
}

func main(){
    l, err := net.Listen("unix", socket_addr)
    if err != nil{
        fmt.Println("On noes: %s", err)
        return
    }
    defer l.Close()
    for{
        fd, err := l.Accept()
        if err != nil{
            log.Fatal("Accept error", err)
        }
        go echoServer(fd)
    }

}

PHP:

ob_implicit_flush();
$socket_file = "/tmp/odc_ws.sock";

if (($socket = socket_create(AF_UNIX, SOCK_STREAM, 0)) === false) {
    echo "socket_create() failed: reason: " . socket_strerror(socket_last_error()) . "<br>";
}
if (socket_connect($socket, $socket_file) === false) {
    echo "socket_connect() failed: reason: " . socket_strerror(socket_last_error($sock)) . "<br>";
}

$msg = 'PHP sent Go a message at ' . date('H:i:s');
$write_res = socket_write($socket, $msg, $msg_len = strlen($msg));
if($write_res != $msg_len){
    echo '<div>Socket write error: ' . socket_strerror( socket_last_error($socket) ) . '</div>';
}

while($read = socket_read($socket, 512, PHP_NORMAL_READ)){
    echo "<div>Server says: $read</div>";
}
socket_close($socket);
4

1 に答える 1