2022-03-30 07:57:40 +00:00
# "socket-api" sample introduction
2022-03-10 07:13:38 +00:00
This sample demonstrates how to use WAMR socket-api to develop wasm network applications.
Two wasm applications are provided: tcp-server and tcp-client, and this sample demonstrates
how they communicate with each other.
## Preparation
Please install WASI SDK, download the [wasi-sdk release ](https://github.com/CraneStation/wasi-sdk/releases ) and extract the archive to default path `/opt/wasi-sdk` .
And install wabt, download the [wabt release ](https://github.com/WebAssembly/wabt/releases ) and extract the archive to default path `/opt/wabt`
## Build the sample
```bash
mkdir build
cd build
cmake ..
make
```
2022-03-30 07:57:40 +00:00
`iwasm` and three Wasm modules, `tcp_server.wasm` , `tcp_client.wasm` , `send_recv.wasm`
will be generated. And their corresponding native version, `tcp_server` ,
`tcp_client` , `send_recv` are generated too.
2022-03-10 07:13:38 +00:00
2022-03-30 07:57:40 +00:00
> Note that iwasm is built with libc-wasi and lib-pthread enabled.
2022-03-10 07:13:38 +00:00
## Run workload
Start the tcp server, which opens port 1234 and waits for clients to connect.
2022-03-30 07:57:40 +00:00
2022-03-10 07:13:38 +00:00
```bash
cd build
./iwasm --addr-pool=0.0.0.0/15 tcp_server.wasm
```
Start the tcp client, which connects the server and receives message.
2022-03-30 07:57:40 +00:00
2022-03-10 07:13:38 +00:00
```bash
cd build
./iwasm --addr-pool=127.0.0.1/15 tcp_client.wasm
```
The output of client is like:
2022-03-30 07:57:40 +00:00
2022-03-10 07:13:38 +00:00
```bash
[Client] Create socket
[Client] Connect socket
[Client] Client receive
[Client] 115 bytes received:
Buffer recieved:
Say Hi from the Server
Say Hi from the Server
Say Hi from the Server
Say Hi from the Server
Say Hi from the Server
[Client] BYE
```
2022-03-30 07:57:40 +00:00
`send_recv.wasm` contains a thread as a server and a thread as a client. They
send and receive data via 127.0.0.1:1234.
```bash
$ ./iwasm --addr-pool=127.0.0.1/0 ./send_recv.wasm
```
The output is:
```bash
Server is online ...
Client is running...
Start receiving.
Start sending.
Send 106 bytes successfully!
Receive 106 bytes successlly!
Data:
The stars shine down
It brings us light
Light comes down
To make us paths
It watches us
And mourns for us
```
2022-03-10 07:13:38 +00:00
Refer to [socket api document ](../../doc/socket_api.md ) for more details.