mirror of
https://github.com/go-micro/go-micro.git
synced 2025-01-23 17:53:05 +02:00
97c1300f53
* Add Get() and GetOptions. * Removed watcher. Outline of client. YAML templates * Added default service and deployment templates and types * Added API tests and cleaned up errors. * Small refactoring. Template package is no more. * Ripped out existing code in preparation to small rework * Reshuffled the source code to make it organized better * Create service and deployment in kubernetes runtime * Major cleanup and refactoring of Kubernetes runtime * Service now handles low level K8s API calls across both K8s deployment an service API objects * Runtime has a task queue that serves for queueing runtime action requests * General refactoring * No need for Lock in k8s service * Added kubernetes runtime env var to default deployment * Enable running different versions of the same service * Can't delete services through labels * Proto cruft. Added runtime.CreateOptions implementation in proto * Removed proxy service from default env variables * Make service name mandatory param to Get method * Get Delete changes from https://github.com/micro/go-micro/pull/945 * Replaced template files with global variables * Validate service names before sending K8s API request * Refactored Kubernetes API client. Fixed typos. * Added client.Resource to make API resources more explicit in code
90 lines
1.8 KiB
Go
90 lines
1.8 KiB
Go
// Package runtime is a service runtime manager
|
|
package runtime
|
|
|
|
import "time"
|
|
|
|
var (
|
|
// DefaultRuntime is default micro runtime
|
|
DefaultRuntime Runtime = NewRuntime()
|
|
)
|
|
|
|
// Runtime is a service runtime manager
|
|
type Runtime interface {
|
|
// Init initializes runtime
|
|
Init(...Option) error
|
|
// Create registers a service
|
|
Create(*Service, ...CreateOption) error
|
|
// Get returns service or fails with error
|
|
Get(string, ...GetOption) ([]*Service, error)
|
|
// Update the service in place
|
|
Update(*Service) error
|
|
// Remove a service
|
|
Delete(*Service) error
|
|
// List the managed services
|
|
List() ([]*Service, error)
|
|
// Start starts the runtime
|
|
Start() error
|
|
// Stop shuts down the runtime
|
|
Stop() error
|
|
}
|
|
|
|
// Notifier is an update notifier
|
|
type Notifier interface {
|
|
// Notify publishes notification events
|
|
Notify() (<-chan Event, error)
|
|
// Close stops the notifier
|
|
Close() error
|
|
}
|
|
|
|
// EventType defines notification event
|
|
type EventType int
|
|
|
|
const (
|
|
// Create is emitted when a new build has been craeted
|
|
Create EventType = iota
|
|
// Update is emitted when a new update become available
|
|
Update
|
|
// Delete is emitted when a build has been deleted
|
|
Delete
|
|
)
|
|
|
|
// 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"
|
|
}
|
|
}
|
|
|
|
// Event is notification event
|
|
type Event struct {
|
|
// Type is event type
|
|
Type EventType
|
|
// Timestamp is event timestamp
|
|
Timestamp time.Time
|
|
// Service is the name of the service
|
|
Service string
|
|
// Version of the build
|
|
Version string
|
|
}
|
|
|
|
// Service is runtime service
|
|
type Service struct {
|
|
// Name of the service
|
|
Name string
|
|
// url location of source
|
|
Source string
|
|
// Path to store source
|
|
Path string
|
|
// Exec command
|
|
Exec string
|
|
// Version of the service
|
|
Version string
|
|
}
|