背景
Postgresql 插件,向外部tpc/ip socket服务发生字节流。
pgsocket is an extension for Postgresql server to send bytes to remote TCP/IP socket server.
For the first version only single function provided for one way data send in bytearray.
This extension is compiled in Linux against Postgresql version 10.
Download source code from https://github.com/AbdulYadi/pgsocket . Build in Linux as usual:
$ USE_PGXS=1 make clean $ USE_PGXS=1 make $ USE_PGXS=1 make install
On successful compilation, install this extension in Postgresql environment
$ create extension pgsocket;
Let us send bytes to –for example– host with IP address nnn.nnn.nnn.nnn, port 9090, send time out 30 seconds, messages 'Hello'
$ select pgsocketsend('nnn.nnn.nnn.nnn', 9090, 30, (E'\\x' || encode('Hello', 'hex'))::bytea);
Or using address host name instead of IP address
$ select pgsocketsend('thesocketserver', 9090, 30, (E'\\x' || encode('Hello', 'hex'))::bytea);
Now, sending text from a table to remote TCP/IP socket server is easy. Assuming there is a table words:
id txt ——————– 1 Life is easy 2 with Postgresql
just do:
$ select pgsocketsend('thesocketserver', 9090, 30, (E'\\x' || encode(t.txt, 'hex'))::bytea) from words t WHERE t.id = 1;
参考
https://abdulyadi.wordpress.com/2018/09/11/pgsocket-extension-for-simple-socket-client/
https://github.com/AbdulYadi/pgsocket
https://abdulyadi.wordpress.com/2015/11/14/extension-for-qr-code-bitmap/
https://abdulyadi.wordpress.com/2012/03/03/consume-soap-web-service-from-postgresql-user-defined-function-in-c/
原文地址:https://github.com/digoal/blog/blob/master/201809/20180913_03.md
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。