Documentation ¶
Index ¶
Constants ¶
const ( ErrNoURIs = "no URIs provided to connect to" ErrFailedParsingURI = "failed to parse provided URI" ErrFailedDial = "failed to dial the host:port" )
const ( // TCPWriterHealthCheckName is the name used for the external health check TCPWriterHealthCheckName health.CheckType = "TCP_LOGGER_CONNECTION_STATUS" )
Variables ¶
This section is empty.
Functions ¶
func StartAsyncWriter ¶ added in v2.9.0
StartAsyncWriter creates a Writer whose Write method puts the submitted byte slice onto a channel. In a separate goroutine, slices are pulled from the queue and written to the output writer. The Close method stops the consumer goroutine and will cause future writes to fail.
Types ¶
type ConnProvider ¶
type ConnProvider interface { // GetConn returns a net.Conn or an error if there is no connection established. // It is the caller's responsibility to close the returned net.Conn and // gracefully handle any closed connection errors if the net.Conn is shared across clients. GetConn() (net.Conn, error) }
ConnProvider defines the behavior to retrieve an established net.Conn.
func NewTCPConnProvider ¶
func NewTCPConnProvider(uris []string, tlsCfg *tls.Config) (ConnProvider, error)
NewTCPConnProvider returns a new ConnProvider that provides TCP connections. The provided uris must not be empty and must be able to be parsed as URIs. Refer to the documentation for url.Parse. If the provided TLS config is nil, then the default config will be used.
type LogEnvelopeMetadata ¶
type LogEnvelopeMetadata struct { Type string `json:"type"` Deployment string `json:"deployment"` Environment string `json:"environment"` EnvironmentID string `json:"environmentId"` Host string `json:"host"` NodeID string `json:"nodeId"` Service string `json:"service"` ServiceID string `json:"serviceId"` Stack string `json:"stack"` StackID string `json:"stackId"` Product string `json:"product"` ProductVersion string `json:"productVersion"` }
func GetEnvelopeMetadata ¶
func GetEnvelopeMetadata() (LogEnvelopeMetadata, error)
GetEnvelopeMetadata retrieves all log envelope environment variables and returns the fully populated LogEnvelopeMetadata and a nil error. If any expected environment variables are not found or empty, then an empty LogEnvelopeMetadata will be returned along with an error that contains the missing environment variables.
type LogEnvelopeV1 ¶
type LogEnvelopeV1 struct { LogEnvelopeMetadata Payload json.RawMessage `json:"payload"` }
type TCPWriter ¶
type TCPWriter struct {
// contains filtered or unexported fields
}
func NewTCPWriter ¶
func NewTCPWriter(metadata LogEnvelopeMetadata, provider ConnProvider) *TCPWriter
NewTCPWriter returns an io.WriteCloser that writes logs to a TCP socket and wraps them with the provided envelope metadata. TCP connections are retrieved using the ConnProvider and connection state is managed internally.
func (*TCPWriter) Close ¶
Close will close any existing client connections and shuts down the writer from any future writes.
func (*TCPWriter) HealthStatus ¶
func (d *TCPWriter) HealthStatus(ctx context.Context) health.HealthStatus
func (*TCPWriter) Write ¶
Write implements the io.Writer interface for use with TCP sockets. The provided input is wrapped in a LogEnvelopeV1 and serialized as JSON before writing to the underlying socket. If there is a connection error before or during writing, the connection will be closed and an error will be returned. If a subsequent Write is called after Close, then this will return immediately with an error.