| | |
| | | DIRS = queue test2 |
| | | DIRS = queue test test2 |
| | | |
| | | all: |
| | | for i in $(DIRS); do \ |
| | |
| | | int shm_close_socket(shm_socket_t * socket) ; |
| | | |
| | | |
| | | int shm_soket_bind(shm_socket_t * socket, int port) ; |
| | | int shm_socket_bind(shm_socket_t * socket, int port) ; |
| | | |
| | | int shm_listen(shm_socket_t * socket) ; |
| | | |
| | |
| | | |
| | | static Logger getLogger() { |
| | | //ERROR ALL |
| | | static Logger logger(Logger::ERROR); |
| | | static Logger logger(Logger::ALL); |
| | | return logger; |
| | | } |
| | | }; |
| | |
| | | #include "mod_socket.h" |
| | | #include "shm_socket.h" |
| | | #include "usg_common.h" |
| | | #include "logger_factory.h" |
| | | static Logger logger = LoggerFactory::getLogger(); |
| | | |
| | | typedef struct mod_entry_t |
| | | { |
| | | int size; |
| | |
| | | |
| | | int mod_socket_bind(void * _socket, int port){ |
| | | mod_socket_t * socket = (mod_socket_t *) _socket; |
| | | return shm_soket_bind(socket->shm_socket, port); |
| | | return shm_socket_bind(socket->shm_socket, port); |
| | | } |
| | | |
| | | void * run_server_recv_client_msg(void *_socket) { |
| | |
| | | if(socket->is_server ) { |
| | | switch(socket->mod) { |
| | | case REQ_REP: |
| | | logger.debug("mod_send before"); |
| | | SemUtil::dec(socket->items); |
| | | rv = shm_send(socket->client_socket, buf, size); |
| | | SemUtil::inc(socket->slots); |
| | | logger.debug("mod_send after"); |
| | | break; |
| | | case SURVEY: |
| | | case PUB_SUB: |
| | |
| | | |
| | | } |
| | | else { |
| | | return shm_send(socket->shm_socket, buf, size); |
| | | logger.debug("mod_send before"); |
| | | rv = shm_send(socket->shm_socket, buf, size); |
| | | logger.debug("mod_send after"); |
| | | return rv; |
| | | } |
| | | return -1; |
| | | |
| | |
| | | if(socket->is_server ) { |
| | | switch(socket->mod) { |
| | | case REQ_REP: |
| | | logger.debug("REQ_REP mod_recv before"); |
| | | SemUtil::dec(socket->slots); |
| | | rv = socket->recvQueue->pop(entry); |
| | | *buf = entry.buf; |
| | | *size = entry.size; |
| | | socket->client_socket = entry.client_socket; |
| | | SemUtil::inc(socket->items); |
| | | logger.debug("REQ_REP mod_recv after"); |
| | | break; |
| | | case PUB_SUB: |
| | | rv = 0; |
| | |
| | | return rv; |
| | | } |
| | | else { |
| | | return shm_recv(socket->shm_socket, buf, size); |
| | | logger.debug("mod_recv before"); |
| | | rv = shm_recv(socket->shm_socket, buf, size); |
| | | logger.debug("mod_recv after"); |
| | | return rv; |
| | | } |
| | | |
| | | return -1; |
| | |
| | | client_socket->remoteQueue->push_timeout(close_msg, &timeout); |
| | | delete client_socket->remoteQueue; |
| | | client_socket->remoteQueue=NULL; |
| | | |
| | | delete client_socket->messageQueue; |
| | | client_socket->messageQueue=NULL; |
| | | socket->clientSocketMap->erase(iter); |
| | |
| | | return _shm_close_socket(socket, true); |
| | | } |
| | | |
| | | |
| | | |
| | | int shm_soket_bind(shm_socket_t * socket, int port) { |
| | | int shm_socket_bind(shm_socket_t * socket, int port) { |
| | | shm_socket_t * _socket = (shm_socket_t *) socket; |
| | | _socket -> port = port; |
| | | return 0; |
| | |
| | | |
| | | int shm_send(shm_socket_t *socket, const void *buf, const int size) { |
| | | // hashtable_t *hashtable = mm_get_hashtable(); |
| | | if(socket->remoteQueue == NULL) { |
| | | err_msg(errno, "当前客户端无连接!"); |
| | | return -1; |
| | | } |
| | | // if(socket->remoteQueue == NULL) { |
| | | // err_msg(errno, "当前客户端无连接!"); |
| | | // return -1; |
| | | // } |
| | | shm_msg_t dest; |
| | | dest.type=SHM_COMMON_MSG; |
| | | dest.port = socket->port; |
| | |
| | | #include "socket.h" |
| | | #include "shm_socket.h" |
| | | #include "usg_common.h" |
| | | #include "shm_mm.h" |
| | | typedef struct Targ { |
| | | int port; |
| | | int id; |
| | |
| | | sprintf(sendbuf, "SERVER RECEIVED: %s", recvbuf); |
| | | puts(sendbuf); |
| | | shm_send(socket, sendbuf, strlen(sendbuf)+1); |
| | | shm_free(recvbuf); |
| | | free(recvbuf); |
| | | } |
| | | shm_close_socket(socket); |
| | | } |
| | |
| | | shm_send(socket, sendbuf, strlen(sendbuf)+1) ; |
| | | shm_recv(socket, &recvbuf, &size); |
| | | printf("reply: %s\n", (char *)recvbuf); |
| | | shm_free(recvbuf); |
| | | free(recvbuf); |
| | | |
| | | } |
| | | shm_close_socket(socket); |
| | |
| | | shm_send(socket, sendbuf, strlen(sendbuf)+1) ; |
| | | shm_recv(socket, &recvbuf, &size); |
| | | printf("reply: %s\n", (char *)recvbuf); |
| | | shm_free(recvbuf); |
| | | free(recvbuf); |
| | | |
| | | |
| | | } |
| | |
| | | #include "mod_socket.h" |
| | | #include "shm_mm.h" |
| | | #include "usg_common.h" |
| | | #include "logger_factory.h" |
| | | static Logger logger = LoggerFactory::getLogger(); |
| | | typedef struct Targ { |
| | | int port; |
| | | int id; |
| | |
| | | int size; |
| | | void *recvbuf; |
| | | char sendbuf[512]; |
| | | while (mod_recv(socket, &recvbuf, &size) == 0) { |
| | | 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); |