Erlang/OTP viene con controladores solo para conectores tcp y udp. Entonces...
No.
Controladores de terceros
- unixdom_drv en http://jungerl.sourceforge.net/
- uds_dist en los ejemplos de controladores del árbol de fuentes
- procket en https://github.com/msantos/procket
En Erlang/OTP 19.0, los sockets UNIX ahora están disponibles, como se indica en el archivo Léame:
OTP-13572 Aplicación(es):erts, kernel
Identificaciones relacionadas:PR-612
* DESTACAR *
Se ha implementado soporte experimental para Unix Domain Sockets. Lee las fuentes si quieres probarlo. Ejemplo:gen_udp:open(0,[{ifaddr,{local,"/tmp/socket"}}]). La documentación se escribirá después de los comentarios de los usuarios sobre la API experimental.
Ejemplo:
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.
Y lo siguiente demuestra sus resultados:
$ 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>
El nanomsg
biblioteca admite sockets de dominio Unix, y el enm
el controlador proporciona un enlace de idioma Erlang para nanomsg
.
Por ejemplo, para abrir el lado de respuesta de un protocolo de solicitud/respuesta y vincularlo a una dirección de socket de dominio Unix:
Url = "ipc:///path/to/socket/file",
{ok,Rep} = enm:rep([{bind,Url}]),
Aquí, Rep
es un nanomsg
enchufe. Es compatible con send
y recv
así como todos los habituales Erlang {active, true | false | N}
modos, etc. que proporcionan los sockets regulares Erlang TCP/SCTP/UDP. Para más detalles consultar el enm
github LÉAME.