如何使用cl-async在Lisp中检索套接字对等体的地址

Ban*_*oos 5 lisp sbcl ip-address common-lisp

我正在尝试使用SBCL进行cl-async,我无法弄清楚如何检索正在通信的套接字的IP地址。

我在带有telent 1.9.4的gnu-linux上使用SBCL 1.4.16

ADDRESS插座对象裂缝出现的未绑定的,我没在试图从下级libuv提取结合

我正在使用文档中的默认示例,并在http://orthecreedence.github.io/cl-async/examples下面的注释之间添加了几行

(defun my-echo-server ()
    (format t "Starting server.~%")
    (as:tcp-server nil 9003  ; nil is "0.0.0.0"
        (lambda (socket data)
            ;; echo the data back into the socket

            ;; echo the data back into the socket
            (describe socket)

           (as:write-socket-data socket data))
        (lambda (err) (format t "listener event: ~a~%" err)))
  ;; catch sigint
  (as:signal-handler 2 (lambda (sig) (declare (ignore sig)) (as:exit-event-loop))))

(as:start-event-loop #'my-echo-server)
Run Code Online (Sandbox Code Playgroud)

一旦我连接并使用netcat或telnet发送内容,输出为:

#<CL-ASYNC:TCP-SOCKET {1004DC0BF3}>
  [standard-object]

Slots with :INSTANCE allocation:
  C                              = #.(SB-SYS:INT-SAP #X7F3EEC021490)
  DATA                           = NIL
  CLOSED                         = NIL
  DRAIN-READ-BUFFER              = T
  ADDRESS                        = #<unbound slot>
  BUFFER                         = #S(FAST-IO:OUTPUT-BUFFER..
  BUFFERINGP                     = NIL
  CONNECTED                      = T
  DIRECTION                      = :IN
Run Code Online (Sandbox Code Playgroud)

而且,ADDRESS插槽出人意料地不受限制...

有人遇到过这个问题吗?

Ban*_*oos 1

我在项目\xe2\x80\x99s 存储库上发现了一个存在相同问题的问题,因此我将关闭该问题,因为似乎没有干净的解决方案。对于我的项目,我\xe2\x80\x99m 将遵循作者的建议,将代理放在服务前面。\n问题

\n