Sockets
✖
Sockets
Details
data:image/s3,"s3://crabby-images/9a887/9a887aea2d47e17b2b3756ac423c1ce6a05d569c" alt=""
- Returned sockets are all given as SocketObject constructs.
- Possible forms of spec include:
-
"Remote" sockets that originate outside the current session "Local" sockets that originate within the current session "Server" local sockets opened with SocketOpen "Client" local sockets connected with SocketConnect "TCP" sockets with protocol of "TCP" "ZMQ" sockets with protocol of "ZMQ" {"ZMQ","type"} sockets with protocol "ZMQ_type" All all local and remote sockets - Close closes socket connections and frees associated resources.
- If a socket is opened with SocketOpen and connected to in the same Wolfram Language session with SocketConnect, both sides of the socket will have an associated SocketObject.
Examples
open allclose allBasic Examples (1)Summary of the most common use cases
Scope (2)Survey of the scope of standard use cases
Only see local sockets on your machine:
data:image/s3,"s3://crabby-images/84297/84297fe102fa7f7fe06b1e075d1363478eb56cc4" alt=""
https://wolfram.com/xid/0b8b7m498v-5c5nf2
data:image/s3,"s3://crabby-images/66efe/66efe935e742e5cad092752a3d8ab31b27dc8656" alt=""
data:image/s3,"s3://crabby-images/cc363/cc3636520d4dc5de9df0d217a2cf588fc4d4f872" alt=""
https://wolfram.com/xid/0b8b7m498v-qvl0t
data:image/s3,"s3://crabby-images/55e0c/55e0cdb84732faeb7297089f0cc416a464075595" alt=""
Listen on a socket with SocketListen and see the socket that is listened on:
data:image/s3,"s3://crabby-images/f86c5/f86c54888a1265e0d97cdd71518bc368ee8fe78d" alt=""
https://wolfram.com/xid/0b8b7m498v-88uyor
data:image/s3,"s3://crabby-images/7cfd9/7cfd9c36781aab4bcc09d5847d891b71bdff6f75" alt=""
data:image/s3,"s3://crabby-images/0c67b/0c67b7622534342bbfe3cb1ea6c5009d62fdbf59" alt=""
https://wolfram.com/xid/0b8b7m498v-i08ssz
data:image/s3,"s3://crabby-images/38bc4/38bc49e1c5d28d02d7100a159f849e3c150e1cb3" alt=""
The socket can also be viewed with the property "Socket" on the SocketListener[…] object:
data:image/s3,"s3://crabby-images/c7052/c70522ab76f2b7af264ac3ac9b43e087ecd82310" alt=""
https://wolfram.com/xid/0b8b7m498v-8zwa7
data:image/s3,"s3://crabby-images/53fef/53feffef5450932335a452d50358e0e77e8de4be" alt=""
Close the socket and delete the listener:
data:image/s3,"s3://crabby-images/6e24d/6e24d610f3adf34940bbecdebfcfb4c98041a018" alt=""
https://wolfram.com/xid/0b8b7m498v-de1a1o
data:image/s3,"s3://crabby-images/ad449/ad4497ef14a453c97e8da5597b568cc93100adc4" alt=""
data:image/s3,"s3://crabby-images/822ba/822bab8ea058d464d37f4540befb9adfb64d4014" alt=""
https://wolfram.com/xid/0b8b7m498v-fptktw
Possible Issues (1)Common pitfalls and unexpected behavior
When connecting to a server socket with SocketConnect in the same session, the socket returned by SocketConnect is different than the socket object returned by the server socket's "ConnectedClients" property.
Open a server socket and connect a client to it:
data:image/s3,"s3://crabby-images/bd77e/bd77e9877775439469a6c62ac71945fd0b17ca7e" alt=""
https://wolfram.com/xid/0b8b7m498v-zzn6ez
Sockets[] will only show the connections you opened, because they are both local:
data:image/s3,"s3://crabby-images/e1aec/e1aecc0cbd4d261d5a4f425043c41961eeb8914a" alt=""
https://wolfram.com/xid/0b8b7m498v-7dmti2
data:image/s3,"s3://crabby-images/91805/91805f0b1295594f13b8faa6ea4ad182385e0098" alt=""
data:image/s3,"s3://crabby-images/41fed/41fed05aeefd9d0d1197fc131f5457622214fa7d" alt=""
There is also an additional remote socket created with the same details as the client socket accessible inside Sockets["Remote"]:
data:image/s3,"s3://crabby-images/e9274/e927484ff03efc66149e42f5419d7decf17a7ad8" alt=""
https://wolfram.com/xid/0b8b7m498v-3o64hr
data:image/s3,"s3://crabby-images/4b919/4b919069e17876903bc01e40449504c4291c1996" alt=""
The UUID for the remote client does not match the local client returned by SocketConnect:
data:image/s3,"s3://crabby-images/20e9f/20e9fa004e94044c2fdf7c4d89d12154d7f98864" alt=""
https://wolfram.com/xid/0b8b7m498v-ztammi
data:image/s3,"s3://crabby-images/72efc/72efcb6000a6e1175019d9acd793de5dbc3dfa2b" alt=""
These two sockets are the two ends of the socket connection; writing to one of them will send a message to the other:
data:image/s3,"s3://crabby-images/b264d/b264dd064bb3661dffbc7ab3947980f71fe4cc82" alt=""
https://wolfram.com/xid/0b8b7m498v-webnh
data:image/s3,"s3://crabby-images/db50c/db50c8de881a37629f48984eecc430fdefee3c80" alt=""
data:image/s3,"s3://crabby-images/05509/0550991510724d7bcae0b8be2ea18c4302f3c658" alt=""
https://wolfram.com/xid/0b8b7m498v-sj6za8
data:image/s3,"s3://crabby-images/290ce/290ce07f22af6eea4b0cbaa332cfeb6948f691fb" alt=""
Closing the server will disconnect the remote client and remove it from the list of active sockets:
data:image/s3,"s3://crabby-images/b2fa9/b2fa91415ab317bd005513cdd559bc95c4064bc9" alt=""
https://wolfram.com/xid/0b8b7m498v-38qjqj
data:image/s3,"s3://crabby-images/ac8af/ac8af6024a9aa5321c28cfa4ab41784db985cf07" alt=""
data:image/s3,"s3://crabby-images/af1ee/af1ee782e760576cf4523f1103b3fefe9c51204c" alt=""
https://wolfram.com/xid/0b8b7m498v-fkkrxp
data:image/s3,"s3://crabby-images/40126/40126821e4cbfa70cc70c787870a69c970ff1893" alt=""
Wolfram Research (2017), Sockets, Wolfram Language function, https://reference.wolfram.com/language/ref/Sockets.html (updated 2020).
Text
Wolfram Research (2017), Sockets, Wolfram Language function, https://reference.wolfram.com/language/ref/Sockets.html (updated 2020).
Wolfram Research (2017), Sockets, Wolfram Language function, https://reference.wolfram.com/language/ref/Sockets.html (updated 2020).
CMS
Wolfram Language. 2017. "Sockets." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2020. https://reference.wolfram.com/language/ref/Sockets.html.
Wolfram Language. 2017. "Sockets." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2020. https://reference.wolfram.com/language/ref/Sockets.html.
APA
Wolfram Language. (2017). Sockets. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/Sockets.html
Wolfram Language. (2017). Sockets. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/Sockets.html
BibTeX
@misc{reference.wolfram_2025_sockets, author="Wolfram Research", title="{Sockets}", year="2020", howpublished="\url{https://reference.wolfram.com/language/ref/Sockets.html}", note=[Accessed: 21-February-2025
]}
BibLaTeX
@online{reference.wolfram_2025_sockets, organization={Wolfram Research}, title={Sockets}, year={2020}, url={https://reference.wolfram.com/language/ref/Sockets.html}, note=[Accessed: 21-February-2025
]}