ina260-zmq-publisher/src/subscriber.c

96 lines
2.2 KiB
C
Raw Normal View History

2023-07-14 18:49:03 +02:00
#include <zmq.h>
#include <assert.h>
2023-07-16 14:50:53 +02:00
#include <signal.h>
2023-07-15 08:38:33 +02:00
#include "utils.h"
2023-07-14 19:29:18 +02:00
2023-07-16 14:50:53 +02:00
unsigned char __stop=0;
void sighandler(int signo){
if (signo == SIGINT){
printf("Stopping...\n");
__stop=1;
}
}
2023-07-14 18:49:03 +02:00
int main (int argc, char *argv [])
{
2023-07-15 19:12:13 +02:00
if(argc != 3){
printf("Usage: %s <port> <cdatadir>",argv[0]);
2023-07-15 14:02:43 +02:00
exit(1);
}
2023-07-15 14:36:48 +02:00
//----- Arguments
2023-07-15 19:12:13 +02:00
int port=atoi(argv[1]);
char *cdatadir=argv[2];
2023-07-15 15:27:34 +02:00
//----- Various inits
mkdirp(cdatadir);
2023-07-16 14:50:53 +02:00
signal(SIGINT,sighandler);
2023-07-15 14:02:43 +02:00
2023-07-15 14:36:48 +02:00
//----- Init ZMQ
2023-07-15 14:02:43 +02:00
void *context = zmq_ctx_new ();
void *subscriber = zmq_socket (context, ZMQ_SUB);
2023-07-16 10:46:52 +02:00
char bindto[STATIC_LEN];
2023-07-15 19:12:13 +02:00
sprintf(bindto,"tcp://*:%d",port);
2023-07-15 18:41:58 +02:00
int rc = zmq_bind (subscriber, bindto);
2023-07-15 14:02:43 +02:00
if(rc!=0){
printf("Failed to bind zmq on %s\n",bindto);
exit(1);
}
rc = zmq_setsockopt (subscriber, ZMQ_SUBSCRIBE,
ZMQ_TOKEN, strlen(ZMQ_TOKEN));
2023-07-15 14:36:48 +02:00
//----- Listen
char buffer[ZMQ_MSG_SIZE];
int size;
2023-07-16 14:50:53 +02:00
while(!__stop){
2023-07-15 14:36:48 +02:00
size=zmq_recv (subscriber, buffer, ZMQ_MSG_SIZE-1, 0);
2023-07-16 14:50:53 +02:00
if(size<=0)
continue;
2023-07-15 14:36:48 +02:00
buffer[size < ZMQ_MSG_SIZE ? size : ZMQ_MSG_SIZE - 1] = '\0';
2023-07-15 15:27:34 +02:00
//----- Read buffer
char *token = strtok(buffer, "\n");
2023-07-16 10:46:52 +02:00
char key[STATIC_LEN];
char client[STATIC_LEN];
2023-07-15 15:27:34 +02:00
long int interval;
FILE *fptr;
int line=1;
while(token != NULL){
if(line==2)
strcpy(key,token);
else if(line==3)
strcpy(client,token);
else if(line==4)
interval=atoi(token);
if(line==4){
2023-07-16 12:46:22 +02:00
double size_mib=size/(1024*1024);
printf("Data received: key=%s client=%s interval=%ld msgsize=%.2lfMiB\n",key, client, interval,size_mib);
2023-07-16 10:46:52 +02:00
char path[STATIC_LEN]="";
2023-07-16 17:19:44 +02:00
// Create dir if not exists:
2023-07-16 12:25:28 +02:00
sprintf(path,"%s/%s/%s/",cdatadir,key,client);
if(!DIR_EXISTS(path)){
mkdirp(path);
}
2023-07-16 17:19:44 +02:00
// Now open output file:
2023-07-16 12:25:28 +02:00
sprintf(path,"%s/%s/%s/%ld",cdatadir,key,client,interval);
2023-07-15 15:27:34 +02:00
fptr=fopen(path,"a");
}
2023-07-16 17:19:44 +02:00
// Write all the measurements:
2023-07-15 15:27:34 +02:00
if(line>4){
fwrite(token, strlen(token), 1, fptr);
2023-07-17 18:22:36 +02:00
//printf("%s\n",token);
2023-07-16 12:46:22 +02:00
fwrite("\n",1,1,fptr);
2023-07-15 15:27:34 +02:00
}
token=strtok(NULL, "\n");
line++;
}
fclose(fptr);
2023-07-15 14:36:48 +02:00
}
2023-07-15 14:02:43 +02:00
zmq_close (subscriber);
zmq_ctx_destroy (context);
return 0;
2023-07-14 18:49:03 +02:00
}