TCP 方式还不如使用现在有的消息队列,所以数据库通过 Socket与应用程序通信,我推荐 UDP 方式。
UDP 有个好处,丢出去就不管了,性能非常好。并且可以实现组播,广播。下面是 UDP的例子
8.4.1. UDP
https://github.com/netkiller/mysql-udp-plugin
下载 mysql-udp_sendto-plugin 然后编译安装代码
# cmake . # make && make install
安装
create function udp_sendto returns string soname 'libudp_sendto.so';
卸载
drop function udp_sendto;
使用演示,首先使用nc命令监听一个UDP端口,用来接收数据库发送过来的数据。数据结构请自行定义。这里仅仅是演示,可以采用json, 逗号分隔等等方式。
# nc -luv 4000
在数据库中使用下面SQL发送数据给应用程序
select udp_sendto('192.168.2.1','4000','hello');
原文出处:Netkiller 系列 手札
本文作者:陈景峯
转载请与作者联系,同时请务必标明文章原始出处和作者信息及本声明。