/** * {@inheritDoc} */ public void run() { try { LoggerContext lc = (LoggerContext) getContext(); while (!Thread.currentThread().isInterrupted()) { SocketConnector connector = createConnector(address, port, 0, reconnectionDelay); connectorTask = activateConnector(connector); if (connectorTask == null) { break; } socket = waitForConnectorToReturnASocket(); if (socket == null) break; dispatchEvents(lc); } } catch (InterruptedException ex) { assert true; // ok... we'll exit now } addInfo("shutting down"); }
/** * {@inheritDoc} */ protected boolean shouldStart() { int errorCount = 0; if (port == 0) { errorCount++; addError("No port was configured for receiver. " + "For more information, please visit http://logback.qos.ch/codes.html#receiver_no_port"); } if (remoteHost == null) { errorCount++; addError("No host name or address was configured for receiver. " + "For more information, please visit http://logback.qos.ch/codes.html#receiver_no_host"); } if (reconnectionDelay == 0) { reconnectionDelay = AbstractSocketAppender.DEFAULT_RECONNECTION_DELAY; } if (errorCount == 0) { try { address = InetAddress.getByName(remoteHost); } catch (UnknownHostException ex) { addError("unknown host: " + remoteHost); errorCount++; } } if (errorCount == 0) { receiverId = "receiver " + remoteHost + ":" + port + ": "; } return errorCount == 0; }
private SocketConnector createConnector(InetAddress address, int port, int initialDelay, int retryDelay) { SocketConnector connector = newConnector(address, port, initialDelay, retryDelay); connector.setExceptionHandler(this); connector.setSocketFactory(getSocketFactory()); return connector; }
private Future<Socket> activateConnector(SocketConnector connector) { try { return getContext().getScheduledExecutorService().submit(connector); } catch (RejectedExecutionException ex) { return null; } }
/** * {@inheritDoc} */ @Override protected boolean shouldStart() { try { SSLContext sslContext = getSsl().createContext(this); SSLParametersConfiguration parameters = getSsl().getParameters(); parameters.setContext(getContext()); socketFactory = new ConfigurableSSLSocketFactory(parameters, sslContext.getSocketFactory()); return super.shouldStart(); } catch (Exception ex) { addError(ex.getMessage(), ex); return false; } }
private void dispatchEvents(LoggerContext lc) { ObjectInputStream ois = null; try { socket.setSoTimeout(acceptConnectionTimeout); ois = new HardenedLoggingEventInputStream(socket.getInputStream()); socket.setSoTimeout(0); addInfo(receiverId + "connection established"); while (true) { ILoggingEvent event = (ILoggingEvent) ois.readObject(); Logger remoteLogger = lc.getLogger(event.getLoggerName()); if (remoteLogger.isEnabledFor(event.getLevel())) { remoteLogger.callAppenders(event); } } } catch (EOFException ex) { addInfo(receiverId + "end-of-stream detected"); } catch (IOException ex) { addInfo(receiverId + "connection failed: " + ex); } catch (ClassNotFoundException ex) { addInfo(receiverId + "unknown event class: " + ex); } finally { CloseUtil.closeQuietly(ois); CloseUtil.closeQuietly(socket); socket = null; addInfo(receiverId + "connection closed"); } }
private Future<Socket> activateConnector(SocketConnector connector) { try { return getContext().getExecutorService().submit(connector); } catch (RejectedExecutionException ex) { return null; } }
/** * {@inheritDoc} */ @Override protected boolean shouldStart() { try { SSLContext sslContext = getSsl().createContext(this); SSLParametersConfiguration parameters = getSsl().getParameters(); parameters.setContext(getContext()); socketFactory = new ConfigurableSSLSocketFactory(parameters, sslContext.getSocketFactory()); return super.shouldStart(); } catch (Exception ex) { addError(ex.getMessage(), ex); return false; } }
/** * {@inheritDoc} */ public void run() { try { LoggerContext lc = (LoggerContext) getContext(); while (!Thread.currentThread().isInterrupted()) { SocketConnector connector = createConnector(address, port, 0, reconnectionDelay); connectorTask = activateConnector(connector); if (connectorTask == null) break; socket = waitForConnectorToReturnASocket(); if (socket == null) break; dispatchEvents(lc); } } catch (InterruptedException ex) { assert true; // ok... we'll exit now } addInfo("shutting down"); }
private SocketConnector createConnector(InetAddress address, int port, int initialDelay, int retryDelay) { SocketConnector connector = newConnector(address, port, initialDelay, retryDelay); connector.setExceptionHandler(this); connector.setSocketFactory(getSocketFactory()); return connector; }
private Future<Socket> activateConnector(SocketConnector connector) { try { return getContext().getScheduledExecutorService().submit(connector); } catch (RejectedExecutionException ex) { return null; } }
/** * {@inheritDoc} */ @Override protected boolean shouldStart() { try { SSLContext sslContext = getSsl().createContext(this); SSLParametersConfiguration parameters = getSsl().getParameters(); parameters.setContext(getContext()); socketFactory = new ConfigurableSSLSocketFactory(parameters, sslContext.getSocketFactory()); return super.shouldStart(); } catch (Exception ex) { addError(ex.getMessage(), ex); return false; } }
if (port == 0) { errorCount++; addError("No port was configured for receiver. " + "For more information, please visit http://logback.qos.ch/codes.html#receiver_no_port"); addError("No host name or address was configured for receiver. " + "For more information, please visit http://logback.qos.ch/codes.html#receiver_no_host"); address = InetAddress.getByName(remoteHost); } catch (UnknownHostException ex) { addError("unknown host: " + remoteHost); errorCount++;
/** * {@inheritDoc} */ public void run() { try { LoggerContext lc = (LoggerContext) getContext(); while (!Thread.currentThread().isInterrupted()) { SocketConnector connector = createConnector(address, port, 0, reconnectionDelay); connectorTask = activateConnector(connector); if (connectorTask == null) { break; } socket = waitForConnectorToReturnASocket(); if (socket == null) break; dispatchEvents(lc); } } catch (InterruptedException ex) { assert true; // ok... we'll exit now } addInfo("shutting down"); }
private SocketConnector createConnector(InetAddress address, int port, int initialDelay, int retryDelay) { SocketConnector connector = newConnector(address, port, initialDelay, retryDelay); connector.setExceptionHandler(this); connector.setSocketFactory(getSocketFactory()); return connector; }
private void dispatchEvents(LoggerContext lc) { try { socket.setSoTimeout(acceptConnectionTimeout); ObjectInputStream ois = new ObjectInputStream(socket.getInputStream()); socket.setSoTimeout(0); addInfo(receiverId + "connection established"); while (true) { ILoggingEvent event = (ILoggingEvent) ois.readObject(); Logger remoteLogger = lc.getLogger(event.getLoggerName()); if (remoteLogger.isEnabledFor(event.getLevel())) { remoteLogger.callAppenders(event); } } } catch (EOFException ex) { addInfo(receiverId + "end-of-stream detected"); } catch (IOException ex) { addInfo(receiverId + "connection failed: " + ex); } catch (ClassNotFoundException ex) { addInfo(receiverId + "unknown event class: " + ex); } finally { CloseUtil.closeQuietly(socket); socket = null; addInfo(receiverId + "connection closed"); } }
private Future<Socket> activateConnector(SocketConnector connector) { try { return getContext().getScheduledExecutorService().submit(connector); } catch (RejectedExecutionException ex) { return null; } }
/** * {@inheritDoc} */ @Override protected boolean shouldStart() { try { SSLContext sslContext = getSsl().createContext(this); SSLParametersConfiguration parameters = getSsl().getParameters(); parameters.setContext(getContext()); socketFactory = new ConfigurableSSLSocketFactory(parameters, sslContext.getSocketFactory()); return super.shouldStart(); } catch (Exception ex) { addError(ex.getMessage(), ex); return false; } }