tcpjson

package
v2.11.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Mar 16, 2021 License: Apache-2.0 Imports: 19 Imported by: 0

Documentation

Index

Constants

View Source
const (
	ErrNoURIs           = "no URIs provided to connect to"
	ErrFailedParsingURI = "failed to parse provided URI"
	ErrFailedDial       = "failed to dial the host:port"
)
View Source
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

func StartAsyncWriter(output io.Writer, registry metrics.Registry) io.WriteCloser

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

func (d *TCPWriter) Close() error

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

func (d *TCPWriter) Write(p []byte) (n int, err error)

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.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL