mirror of
https://github.com/NixOS/nix
synced 2025-07-06 21:41:48 +02:00
* Benchmarking Unix domain sockets.
This commit is contained in:
parent
fe15f991e3
commit
5f0b9de6d8
3 changed files with 121 additions and 0 deletions
43
socket/client.c
Normal file
43
socket/client.c
Normal file
|
@ -0,0 +1,43 @@
|
|||
#include <assert.h>
|
||||
#include <stdio.h>
|
||||
#include <unistd.h>
|
||||
#include <string.h>
|
||||
#include <errno.h>
|
||||
|
||||
#include <sys/types.h>
|
||||
#include <sys/socket.h>
|
||||
#include <sys/un.h>
|
||||
|
||||
|
||||
#define SOCKET_PATH "/tmp/nix-daemon"
|
||||
|
||||
|
||||
int main(int argc, char * * argv)
|
||||
{
|
||||
int res;
|
||||
|
||||
int sock = socket(PF_UNIX, SOCK_STREAM, 0);
|
||||
assert(sock != -1);
|
||||
|
||||
struct sockaddr_un addr;
|
||||
addr.sun_family = AF_UNIX;
|
||||
strcpy(addr.sun_path, SOCKET_PATH);
|
||||
|
||||
res = connect(sock, (struct sockaddr *) &addr, sizeof(addr));
|
||||
assert(res != -1);
|
||||
|
||||
int i;
|
||||
for (i = 0; i < 100000; i++) {
|
||||
int len = send(sock, &i, sizeof(i), 0);
|
||||
assert(len == sizeof(i));
|
||||
|
||||
int j;
|
||||
len = recv(sock, &j, sizeof(j), 0);
|
||||
if (len < sizeof(j)) break;
|
||||
assert(i * 2 == j);
|
||||
}
|
||||
|
||||
close(sock);
|
||||
|
||||
return 0;
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue