#include "mod_socket.h" #include "shm_mm_wraper.h" #include "usg_common.h" #include "logger_factory.h" static Logger logger = LoggerFactory::getLogger(); typedef struct Targ { int port; int id; }Targ; void server(int port) { void *socket = mod_open_socket(REQ_REP); mod_socket_bind(socket, port); mod_listen(socket); int size; void *recvbuf; char sendbuf[512]; int rv; while ( (rv = mod_recv(socket, &recvbuf, &size) ) == 0) { logger.debug("rv ==%d", rv); sprintf(sendbuf, "SERVER RECEIVED: %s", recvbuf); puts(sendbuf); mod_send(socket, sendbuf, strlen(sendbuf) + 1); free(recvbuf); } mod_close_socket(socket); } void client(int port) { void *socket = mod_open_socket(REQ_REP); mod_connect(socket, port); int size; void *recvbuf; char sendbuf[512]; while (true) { printf("request: "); scanf("%s", sendbuf); mod_send(socket, sendbuf, strlen(sendbuf) + 1); mod_recv(socket, &recvbuf, &size); printf("reply: %s\n", (char *)recvbuf); free(recvbuf); } mod_close_socket(socket); } void *threadrun(void *arg) { Targ *targ = (Targ *)arg; int port = targ->port; char sendbuf[512]; int scale = 100000; int i; void *socket = mod_open_socket(REQ_REP); mod_connect(socket, port); char filename[512]; sprintf(filename, "test%d.txt", targ->id); FILE *fp = NULL; fp = fopen(filename, "w+"); int size; void *recvbuf; for (i = 0; i < scale; i++) { sprintf(sendbuf, "thread(%d) %d", targ->id, i); fprintf(fp, "requst:%s\n", sendbuf); mod_send(socket, sendbuf, strlen(sendbuf)+1) ; mod_recv(socket, &recvbuf, &size); fprintf(fp, "reply: %s\n", (char *)recvbuf); free(recvbuf); } fclose(fp); mod_close_socket(socket); return (void *)i; } void multyThreadClient(int port) { int status, i = 0, processors = 4; void *res[processors]; Targ *targs = (Targ *)calloc(processors, sizeof(Targ)); pthread_t tids[processors]; char sendbuf[512]; for (i = 0; i < processors; i++) { targs[i].port = port; targs[i].id = i; pthread_create(&tids[i], NULL, threadrun, (void *)&targs[i]); } for (i = 0; i < processors; i++) { if (pthread_join(tids[i], &res[i]) != 0) { perror("multyThreadClient pthread_join"); } else { fprintf(stderr, "client(%d) 写入 %ld 条数据\n", i, (long)res[i]); } } } int main(int argc, char *argv[]) { shm_mm_wrapper_init(512); int port; if (argc < 3) { fprintf(stderr, "Usage: reqrep %s|%s ...\n", "server", "client"); return 1; } port = atoi(argv[2]); if (strcmp("server", argv[1]) == 0) { server(port); } if (strcmp("client", argv[1]) == 0) client(port); if (strcmp("mclient", argv[1]) == 0) multyThreadClient(port); shm_mm_wrapper_destroy(); // fprintf(stderr, "Usage: reqrep %s|%s ...\n", "server", "client"); return 0; }