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);