Erlang/OTP enthält nur Treiber für TCP- und UDP-Sockets. Also...
Nein.
Treiber von Drittanbietern
- unixdom_drv in http://jungerl.sourceforge.net/
- uds_dist in den Treiberbeispielen des Quellbaums
- procket unter https://github.com/msantos/procket
In Erlang/OTP 19.0 sind UNIX-Sockets jetzt verfügbar, wie in der Readme angegeben:
OTP-13572 Anwendung(en):erts, Kernel
Zugehörige ID(s):PR-612
* HERVORHEBEN *
Experimentelle Unterstützung für Unix-Domain-Sockets wurde implementiert. Lesen Sie die Quellen, wenn Sie es ausprobieren möchten. Beispiel:gen_udp:open(0,[{ifaddr,{local,"/tmp/socket"}}]). Die Dokumentation wird nach dem Feedback der Benutzer zur experimentellen API geschrieben.
Beispiel:
lsock.erl:
-module(lsock).
-export([watcher/1, test/0]).
watcher(Parent) ->
{ok, Sockin} = gen_udp:open(0, [{ifaddr, {local, "/tmp/testsockin"}}]),
io:format("watcher ok? ~w ~w~n", [ok, Sockin]),
Parent ! start,
receive
Msg -> io:format("watcher got: ~p ~n", [Msg]) end.
test() ->
file:delete("/tmp/testsockin"),
file:delete("/tmp/testsockout"),
_ = spawn(lsock, watcher, [self()]),
{ok, Sockout} = gen_udp:open(0, [{ifaddr, {local, "/tmp/testsockout"}}]),
io:format("parent ok? ~w ~w~n", [ok, Sockout]),
receive start ->
gen_udp:send(Sockout, {local, "/tmp/testsockin"}, 0, "hi") end.
Und das Folgende demonstriert seine Ergebnisse:
$ erlc lsock.erl
$ erl
Erlang/OTP 19 [erts-8.0.1] [source-ca40008] [64-bit] [smp:2:2] [async-threads:10] [hipe] [kernel-poll:false]
Eshell V8.0.1 (abort with ^G)
1> lsock:test().
<0.58.0>
parent ok? ok #Port<0.455>
watcher ok? ok #Port<0.456>
watcher got: {udp,#Port<0.456>,{local,<<"/tmp/testsockout">>},0,"hi"}
ok
2>
Der nanomsg
Die Bibliothek unterstützt Unix-Domain-Sockets und die enm
Der Treiber stellt eine Erlang-Sprachbindung für nanomsg
bereit .
Zum Beispiel, um die Antwortseite eines Request/Response-Protokolls zu öffnen und an eine Unix-Domain-Socket-Adresse zu binden:
Url = "ipc:///path/to/socket/file",
{ok,Rep} = enm:rep([{bind,Url}]),
Hier, Rep
ist ein nanomsg
Steckdose. Es unterstützt send
und recv
sowie alle üblichen Erlang {active, true | false | N}
Modi usw., die normale Erlang TCP/SCTP/UDP-Sockets bereitstellen. Weitere Einzelheiten finden Sie im enm
github-README.