<p dir="ltr">Well, LogWriter assumes a specific semantics from the underlying transport. Async APIs usually give you access to the fd, and the needed I/O event mask. If that&#39;s the case, you can probably integrate it to syslog-ng&#39;s mainloop, which is ivykis based (an async event lib).</p>
<p dir="ltr">But you can create a separate event loop if that&#39;s easier. E.g. use a single thread for all kafka destinations.</p>
<p dir="ltr">Can you explain your use-case why the existing kafka destination is not good enough? Is it performance, is it java?</p>
<div class="gmail_quot&lt;blockquote class=" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"> ❦ 22 janvier 2016 12:43 +0100, &quot;Scheidler, Balázs&quot; &lt;<a href="mailto:balazs.scheidler@balabit.com">balazs.scheidler@balabit.com</a>&gt; :<br>
<br>
&gt; well, the afsocket one. that&#39;s a completely nonblocking destination<br>
&gt; that implements udp/tcp/unix-stream/unix-dgram/syslog/network sources<br>
&gt; and destinations.<br>
&gt;<br>
&gt; It basically boils down to using a LogWriter class that does the heavy<br>
&gt; lifting at least as long as your transport protocol is simple enough.<br>
&gt; Probably the simplest is to create a LogProto implementation and let<br>
&gt; the afsocket driver do the rest.<br>
&gt;<br>
&gt; Asynchronous sources/destinations operate on a set of worker threads<br>
&gt; (in contrast to a dedicated thread) and are driven by the epoll()<br>
&gt; based event loop.<br>
<br>
It&#39;s for the librdkafka-based kafka destination. So, the third-party<br>
library is taking care of all the transport stuff. Is the afsocket one<br>
still a good example for async stuff in this case? I didn&#39;t have a look<br>
yet.<br>
--<br>
Don&#39;t compare floating point numbers just for equality.<br>
            - The Elements of Programming Style (Kernighan &amp; Plauger)<br>
______________________________________________________________________________<br>
Member info: <a href="https://lists.balabit.hu/mailman/listinfo/syslog-ng" rel="noreferrer" target="_blank">https://lists.balabit.hu/mailman/listinfo/syslog-ng</a><br>
Documentation: <a href="http://www.balabit.com/support/documentation/?product=syslog-ng" rel="noreferrer" target="_blank">http://www.balabit.com/support/documentation/?product=syslog-ng</a><br>
FAQ: <a href="http://www.balabit.com/wiki/syslog-ng-faq" rel="noreferrer" target="_blank">http://www.balabit.com/wiki/syslog-ng-faq</a><br>
<br>
</div>