backend

package
v0.0.0-...-40caaa6 Latest Latest
Warning

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

Go to latest
Published: Jan 13, 2025 License: BSD-3-Clause Imports: 28 Imported by: 0

README

This directory contains the backend service implementation and it's respective controllers.

The backend service is intended to host api endpoints that are not directly user facing. This helps isolate user facing components from the other services running in the cluster by providing a standard interface contract that calling services can adhere to. For example, to run manual pinpoint jobs from the UI, the frontend service can invoke the endpoint on the backend service. The backend endpoint will trigger the workflow in the temporal cluster. In the future if we replace temporal with another solution, the contract between frontend (and any other service that invokes this endpoint) remains unchanged and makes the code easy to upgrade. This service can also be used to lighten the load on the frontend service by offloading some heavier operations (eg: Dry run regression detection) that are currently being run in frontend to the backend service.

Running the backend service locally

To run a local instance of the backend service, simply run the cmd below from the perf directory.

make run-demo-backend

Adding a new endpoint

The endpoint controllers are all in the controllers directory. To add a new endpoint, please follow the steps below. A sample hello endpoint is provided for reference.

  1. Create a new proto definition defining your service. This need not be under this directory and can reside in a location specific to your implementation. Eg: culprit_service.proto.
  2. Create a generate.go file that provides the generation script to create the stubbed client/server code for your service. Eg: generate.go. Replace the arguments on the //:protoc command to specify your module and input proto file appropriately. Running go generate ./... in the location of this file will generate the stubs.
  3. Create your endpoint controller by implementing implement the backend.BackendService interface. Eg: culprit service
  4. Add the newly added service to the list in initialize() function in backend.go.

The endpoints are simple grpc apis, so you can either create a client for the specific endpoint using the stubs, or use a tool like grpc_cli.

Checking available endpoints

grpc_cli ls [::]:8005 --channel_creds_type=local

Invoking an endpoint locally

grpc_cli call [::]:8005 --channel_creds_type=local backend.v1.Hello.SayHello "text: 'World'"

Creating Go clients for your service

In order to make the grpc connections uniform across the services, we have created a backendclientutility to abstract out the GRPC boilerplate and make it easy to create clients for individual services. If you are adding a new service, simply follow the pattern in this file to create a function to create the client for your service.

URL for the Backend Service

For local deployments, you can simply use localhost:8005 (double check the value specified in demo.json). For production or GKE deployment of the Backend service, we use Kubernetes DNS. Since the endpoints on this service are intended to be internal S2S calls only, we are not opening up external DNS to the service. Instead we can use the service cluster url (eg: perf-be-chrome-non-public.perf.svc.cluster.local:7000) to invoke the BE kubernetes workload. The service name and port will be different for each instance, so please refer to the table below to get the url for the instance you want.

Instance URL
Chrome (Internal) perf-be-chrome-non-public.perf.svc.cluster.local:7000

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func NewPinpointService

func NewPinpointService(t tpr_client.TemporalProvider, l *rate.Limiter) *pinpointService

NewPinpointService returns a new instance of the pinpoint service.

Types

type Backend

type Backend struct {
	// contains filtered or unexported fields
}

Backend provides a struct for the application.

func New

func New(flags *config.BackendFlags,
	anomalygroupStore anomalygroup.Store,
	culpritStore culprit.Store,
	subscriptionStore subscription.Store,
	regressionStore regression.Store,
	notifier notify.CulpritNotifier,
) (*Backend, error)

New creates a new instance of Backend application.

func (*Backend) Cleanup

func (b *Backend) Cleanup()

Cleanup performs a graceful shutdown of the grpc server.

func (*Backend) Serve

func (b *Backend) Serve()

Serve intiates the listener to serve traffic.

func (*Backend) ServeGRPC

func (b *Backend) ServeGRPC() error

ServeGRPC does not return unless there is an error during the startup process, in which case it returns the error, or if a call to [Cleanup()] causes a graceful shutdown, in which case it returns either nil if the graceful shutdown succeeds, or an error if it does not.

type BackendService

type BackendService interface {
	// GetAuthorizationPolicy returns the authorization policy for the service.
	GetAuthorizationPolicy() shared.AuthorizationPolicy

	// RegisterGrpc registers the grpc service with the server instance.
	RegisterGrpc(server *grpc.Server)

	// GetServiceDescriptor returns the service descriptor for the service.
	GetServiceDescriptor() grpc.ServiceDesc
}

BackendService provides an interface for a service to be hosted on Backend application.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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