组播
来源:互联网 发布:淘宝毛毛仔体育正吗 编辑:程序博客网 时间:2024/05/04 11:22
关于消息队列的使用
http://www.cnblogs.com/chenpingzhao/p/5262050.html
消息队列采用高可用,可持久化的消息中间件。比如Active MQ,Rabbit MQ,Rocket Mq。
ZeroMQ
号称史上最快的消息队列
性能对比见http://blog.csdn.net/abcd1f2/article/details/47318693
ZeroMQ的C版本nanomsg
Sender.cpp
#include <stdlib.h>#include <sys/types.h>#include <sys/socket.h>#include <netinet/in.h>#include <arpa/inet.h>#include <time.h>#include <string.h>#include <stdio.h>#include <unistd.h>#define HELLO_PORT 12345#define HELLO_GROUP "225.0.0.37"int main(int argc, char *argv[]){struct sockaddr_in addr;int fd, cnt;struct ip_mreq mreq;char *message="Hello, World!";/* create what looks like an ordinary UDP socket */if ((fd=socket(AF_INET,SOCK_DGRAM,0)) < 0) {perror("socket");exit(1);}/* set up destination address */memset(&addr,0,sizeof(addr));addr.sin_family=AF_INET;addr.sin_addr.s_addr=inet_addr(HELLO_GROUP);addr.sin_port=htons(HELLO_PORT);/* now just sendto() our destination! */while (1){if (sendto(fd,message, strlen(message), 0, (struct sockaddr *) &addr, sizeof(addr)) < 0) {perror("sendto");exit(1);}sleep(1);}}
Recver.cpp 文件内容如下:
#include <stdlib.h>#include <sys/types.h>#include <sys/socket.h>#include <netinet/in.h>#include <arpa/inet.h>#include <time.h>#include <string.h>#include <stdio.h>#include <unistd.h>#define HELLO_PORT 12345#define HELLO_GROUP "225.0.0.37"#define MSGBUFSIZE 256int main(int argc, char *argv[]){struct sockaddr_in addr;int fd, nbytes,addrlen;struct ip_mreq mreq;char msgbuf[MSGBUFSIZE];u_int yes=1; /*** MODIFICATION TO ORIGINAL *//* create what looks like an ordinary UDP socket */if ((fd=socket(AF_INET,SOCK_DGRAM,0)) < 0) {perror("socket");exit(1);}/**** MODIFICATION TO ORIGINAL *//* allow multiple sockets to use the same PORT number */if (setsockopt(fd,SOL_SOCKET,SO_REUSEADDR,&yes,sizeof(yes)) < 0) {perror("Reusing ADDR failed");exit(1);}/*** END OF MODIFICATION TO ORIGINAL *//* set up destination address */memset(&addr,0,sizeof(addr));addr.sin_family=AF_INET;addr.sin_addr.s_addr=htonl(INADDR_ANY); /* N.B.: differs from sender */addr.sin_port=htons(HELLO_PORT);/* bind to receive address */if (bind(fd,(struct sockaddr *) &addr,sizeof(addr)) < 0){perror("bind");exit(1);}/* use setsockopt() to request that the kernel join a multicast group */mreq.imr_multiaddr.s_addr=inet_addr(HELLO_GROUP);mreq.imr_interface.s_addr=htonl(INADDR_ANY);if (setsockopt(fd,IPPROTO_IP,IP_ADD_MEMBERSHIP,&mreq,sizeof(mreq)) < 0) {perror("setsockopt");exit(1);}/* now just enter a read-print loop */while (1) {addrlen=sizeof(addr);if ((nbytes=recvfrom(fd,msgbuf,MSGBUFSIZE,0, (struct sockaddr *) &addr,(socklen_t*)&addrlen)) < 0) {perror("recvfrom");exit(1);}puts(msgbuf);}return 0;}
0 0
- 多播,组播
- 多播、组播
- 多播,组播
- “单播”“组播”和“多播”
- 单播、广播、组播(多播)
- 单播、广播、组播(多播)
- 单播 多播 组播
- 单播,组播,多播
- 单播,组播,广播,任播
- 组播
- 组播
- 组播
- 组播
- 组播
- 组播
- 组播
- 组播
- 组播
- typedef的用法
- Guava学习笔记:Guava新增集合类型-Multimap
- java构造私有化的作用
- 启动 Tomcat 显示指定的服务未安装的解决办法
- Linux下用freetds连接mssql中文乱码的问题
- 组播
- 设计模式 —— 动态代理(Dynamic Proxy)
- 使用Eclipse调试ROS包
- mongodb的like查询
- Python学习笔记(嵌套循环)
- SaaS营销网站的组织结构
- TCP与UDP区别
- 关于 RegExp exec()方法的学习
- DrawerLayout与status bar