I’m not sure how Socket Appender works. I know that logging events are sent to particular port. Then we can print logs on a console or put into a file.
My question is more about the way logs are sent. Is there e.g. one queue? Is it synchronous or asynchronous? Can using it slow down my program?
I’ve found some info here, but it isn’t clear for me.
From the SocketAppender documentation
Since the appender uses the TCP protocol, I would say the log events are “sort of synchronous”.
Basically, the appender uses TCP to send the first log event to the server. However, if the network latency is so high that the message has still not been sent by the time a second event is generated, then the second log event will have to wait (and thus block), until the first event is consumed. So yes, it would slow down your application, if the app generates log events faster than the network can pass them on.
As mentioned by @Akhil and @Nikita, JMSAppender or AsyncAppender would be better options if you don’t want the performance of your application to be impacted by the network latency.