ops

command
v0.0.0-...-78ff11c Latest Latest
Warning

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

Go to latest
Published: Nov 30, 2024 License: MIT Imports: 6 Imported by: 0

README

Ops Service

The Ops service provides API access to various operational information that we want to allow various tool access to. While this could be built into the chatbot.go binary that implements the ChatOps interface, this abstraction allows us to have multiple programs that can access these API calls. In addition, if we want to migrate to another chat service instead of Slack (like Microsoft Teams), we can easily do so without impacting users during a migration.

Basic Architecture

This is your standard gRPC service with a nice Go client ready made to access the service. We stick the important parts in internal to keep anyone from using the packages that are just for the service. proto/ contains the protocol buffer messages we have for the client/server communication.

The file directory layout is as follows (with some highlighted files, but not all files):

├── client
│   └── client.go
├── internal
│   ├── jaeger
│   │   └── client
│   │       ├── client.go
│   │       └── test
│   ├── prom
│   │   └── prom.go
│   └── server
│       └── server.go
├── ops.go
└── proto
    ├── jaeger
    │   └── model
    ├── ops.pb.go
    ├── ops.proto
    └── ops_grpc.pb.go
  • ops.go is the main file for the Ops service
  • client/ provides a client library for accessing our Ops service using Go
  • internal/jaeger provides a client wrapper for accessing Jaeger and some end to end testing
  • internal/prom provides a client wrapper for accessing prometheus
  • proto/ contains protocol buffer messages and services for accessing the Ops service via gRPC
    • proto/jaeger provides various protocol buffers required to access Jaeger

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
internal
jaeger/client
Package client provides a Jaegar client for grabbing traces from the Jaegar service.
Package client provides a Jaegar client for grabbing traces from the Jaegar service.
server
Package server contains our gRPC server implementation for the ops server.
Package server contains our gRPC server implementation for the ops server.
proto module

Jump to

Keyboard shortcuts

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