1
0
mirror of https://github.com/go-micro/go-micro.git synced 2025-01-17 17:44:30 +02:00
go-micro/runtime/runtime.go

111 lines
2.3 KiB
Go
Raw Normal View History

2019-09-14 06:33:14 +02:00
// Package runtime is a service runtime manager
package runtime
2020-01-18 04:13:24 +02:00
import (
"errors"
"time"
)
var (
2022-09-30 16:27:07 +02:00
// DefaultRuntime is default micro runtime.
DefaultRuntime Runtime = NewRuntime()
2022-09-30 16:27:07 +02:00
// DefaultName is default runtime service name.
2019-11-20 16:54:42 +02:00
DefaultName = "go.micro.runtime"
2020-01-18 04:13:24 +02:00
ErrAlreadyExists = errors.New("already exists")
)
2022-09-30 16:27:07 +02:00
// Runtime is a service runtime manager.
2019-09-14 06:33:14 +02:00
type Runtime interface {
// Init initializes runtime
Init(...Option) error
// Create registers a service
2019-09-24 19:32:35 +02:00
Create(*Service, ...CreateOption) error
// Read returns the service
2019-11-29 13:35:00 +02:00
Read(...ReadOption) ([]*Service, error)
2019-10-29 14:29:21 +02:00
// Update the service in place
Update(*Service, ...UpdateOption) error
// Remove a service
Delete(*Service, ...DeleteOption) error
2020-04-13 00:41:21 +02:00
// Logs returns the logs for a service
Logs(*Service, ...LogsOption) (LogStream, error)
// Start starts the runtime
Start() error
// Stop shuts down the runtime
2019-09-14 06:33:14 +02:00
Stop() error
2020-04-13 00:41:21 +02:00
// String describes runtime
String() string
}
2022-09-30 16:27:07 +02:00
// Stream returns a log stream.
type LogStream interface {
Error() error
Chan() chan LogRecord
Stop() error
}
type LogRecord struct {
Metadata map[string]string
2023-04-26 02:16:34 +02:00
Message string
2019-09-14 06:33:14 +02:00
}
2022-09-30 16:27:07 +02:00
// Scheduler is a runtime service scheduler.
2020-01-16 15:34:04 +02:00
type Scheduler interface {
// Notify publishes schedule events
Notify() (<-chan Event, error)
2020-01-16 15:34:04 +02:00
// Close stops the scheduler
Close() error
2019-09-14 06:33:14 +02:00
}
2022-09-30 16:27:07 +02:00
// EventType defines schedule event.
type EventType int
const (
2022-09-30 16:27:07 +02:00
// Create is emitted when a new build has been craeted.
Create EventType = iota
2022-09-30 16:27:07 +02:00
// Update is emitted when a new update become available.
Update
2022-09-30 16:27:07 +02:00
// Delete is emitted when a build has been deleted.
Delete
)
2019-10-29 14:29:21 +02:00
2022-09-30 16:27:07 +02:00
// String returns human readable event type.
func (t EventType) String() string {
switch t {
case Create:
return "create"
case Delete:
return "delete"
case Update:
return "update"
default:
return "unknown"
}
2019-10-29 14:29:21 +02:00
}
2022-09-30 16:27:07 +02:00
// Event is notification event.
type Event struct {
// Timestamp is event timestamp
Timestamp time.Time
2020-05-19 11:14:07 +02:00
// Service the event relates to
Service *Service
// Options to use when processing the event
Options *CreateOptions
2023-04-26 02:16:34 +02:00
// ID of the event
ID string
// Type is event type
Type EventType
2019-09-14 06:33:14 +02:00
}
2022-09-30 16:27:07 +02:00
// Service is runtime service.
type Service struct {
2023-04-26 02:16:34 +02:00
// Metadata stores metadata
Metadata map[string]string
// Name of the service
Name string
2019-11-24 00:50:13 +02:00
// Version of the service
Version string
// url location of source
Source string
2019-09-14 06:33:14 +02:00
}