zmq_proxy man page on Alpinelinux

Man page or keyword search:  
man Server   18016 pages
apropos Keyword Search (all sections)
Output format
Alpinelinux logo
[printable version]

ZMQ_PROXY(3)			  0MQ Manual			  ZMQ_PROXY(3)

NAME
       zmq_proxy - start built-in 0MQ proxy

SYNOPSIS
       int zmq_proxy (const void *frontend, const void *backend, const void
       *capture);

DESCRIPTION
       The zmq_proxy() function starts the built-in 0MQ proxy in the current
       application thread.

       The proxy connects a frontend socket to a backend socket. Conceptually,
       data flows from frontend to backend. Depending on the socket types,
       replies may flow in the opposite direction. The direction is conceptual
       only; the proxy is fully symmetric and there is no technical difference
       between frontend and backend.

       Before calling zmq_proxy() you must set any socket options, and connect
       or bind both frontend and backend sockets. The two conventional proxy
       models are:

       zmq_proxy() runs in the current thread and returns only if/when the
       current context is closed.

       If the capture socket is not NULL, the proxy shall send all messages,
       received on both frontend and backend, to the capture socket. The
       capture socket should be a ZMQ_PUB, ZMQ_DEALER, ZMQ_PUSH, or ZMQ_PAIR
       socket.

       Refer to zmq_socket(3) for a description of the available socket types.

EXAMPLE USAGE
   Shared Queue
       When the frontend is a ZMQ_ROUTER socket, and the backend is a
       ZMQ_DEALER socket, the proxy shall act as a shared queue that collects
       requests from a set of clients, and distributes these fairly among a
       set of services. Requests shall be fair-queued from frontend
       connections and distributed evenly across backend connections. Replies
       shall automatically return to the client that made the original
       request.

   Forwarder
       When the frontend is a ZMQ_XSUB socket, and the backend is a ZMQ_XPUB
       socket, the proxy shall act as a message forwarder that collects
       messages from a set of publishers and forwards these to a set of
       subscribers. This may be used to bridge networks transports, e.g. read
       on tcp:// and forward on pgm://.

   Streamer
       When the frontend is a ZMQ_PULL socket, and the backend is a ZMQ_PUSH
       socket, the proxy shall collect tasks from a set of clients and
       forwards these to a set of workers using the pipeline pattern.

RETURN VALUE
       The zmq_proxy() function always returns -1 and errno set to ETERM (the
       0MQ context associated with either of the specified sockets was
       terminated).

EXAMPLE
       Creating a shared queue proxy.

	   //  Create frontend and backend sockets
	   void *frontend = zmq_socket (context, ZMQ_ROUTER);
	   assert (backend);
	   void *backend = zmq_socket (context, ZMQ_DEALER);
	   assert (frontend);
	   //  Bind both sockets to TCP ports
	   assert (zmq_bind (frontend, "tcp://*:5555") == 0);
	   assert (zmq_bind (backend, "tcp://*:5556") == 0);
	   //  Start the queue proxy, which runs until ETERM
	   zmq_proxy (frontend, backend, NULL);

SEE ALSO
       zmq_bind(3) zmq_connect(3) zmq_socket(3) zmq(7)

AUTHORS
       This page was written by the 0MQ community. To make a change please
       read the 0MQ Contribution Policy at
       http://www.zeromq.org/docs:contributing.

0MQ 4.0.1			  03/10/2014			  ZMQ_PROXY(3)
[top]

List of man pages available for Alpinelinux

Copyright (c) for man pages and the logo by the respective OS vendor.

For those who want to learn more, the polarhome community provides shell access and support.

[legal] [privacy] [GNU] [policy] [cookies] [netiquette] [sponsors] [FAQ]
Tweet
Polarhome, production since 1999.
Member of Polarhome portal.
Based on Fawad Halim's script.
....................................................................
Vote for polarhome
Free Shell Accounts :: the biggest list on the net