mirror of
https://github.com/go-micro/go-micro.git
synced 2025-01-11 17:18:28 +02:00
Dynamic Runtime source for k8s with github packages (#1252)
* Dynamic Runtime source for k8s * Still check for source * Replace / with - for k8s service names * Simplify sourceForName function
This commit is contained in:
parent
ffdf986aac
commit
5e8d5834eb
@ -270,9 +270,9 @@ func (k *kubernetes) Create(s *runtime.Service, opts ...runtime.CreateOption) er
|
|||||||
if len(options.Type) == 0 {
|
if len(options.Type) == 0 {
|
||||||
options.Type = k.options.Type
|
options.Type = k.options.Type
|
||||||
}
|
}
|
||||||
if len(k.options.Source) > 0 {
|
|
||||||
s.Source = k.options.Source
|
// determine the full source for this service
|
||||||
}
|
options.Source = k.sourceForService(s.Name)
|
||||||
|
|
||||||
service := newService(s, options)
|
service := newService(s, options)
|
||||||
|
|
||||||
@ -330,6 +330,7 @@ func (k *kubernetes) Update(s *runtime.Service) error {
|
|||||||
// create new kubernetes micro service
|
// create new kubernetes micro service
|
||||||
service := newService(s, runtime.CreateOptions{
|
service := newService(s, runtime.CreateOptions{
|
||||||
Type: k.options.Type,
|
Type: k.options.Type,
|
||||||
|
Source: k.sourceForService(s.Name),
|
||||||
})
|
})
|
||||||
|
|
||||||
// update build time annotation
|
// update build time annotation
|
||||||
@ -432,3 +433,15 @@ func NewRuntime(opts ...runtime.Option) runtime.Runtime {
|
|||||||
client: client,
|
client: client,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// sourceForService determines the nested package name for github
|
||||||
|
// e.g src: docker.pkg.github.com/micro/services an srv: users/api
|
||||||
|
// would become docker.pkg.github.com/micro/services/users-api
|
||||||
|
func (k *kubernetes) sourceForService(name string) string {
|
||||||
|
if !strings.HasPrefix(k.options.Source, "docker.pkg.github.com") {
|
||||||
|
return k.options.Source
|
||||||
|
}
|
||||||
|
|
||||||
|
formattedName := strings.ReplaceAll(name, "/", "-")
|
||||||
|
return fmt.Sprintf("%v/%v", k.options.Source, formattedName)
|
||||||
|
}
|
||||||
|
@ -34,9 +34,9 @@ func newService(s *runtime.Service, c runtime.CreateOptions) *service {
|
|||||||
kservice := client.NewService(name, version, c.Type)
|
kservice := client.NewService(name, version, c.Type)
|
||||||
kdeploy := client.NewDeployment(name, version, c.Type)
|
kdeploy := client.NewDeployment(name, version, c.Type)
|
||||||
|
|
||||||
if len(s.Source) > 0 {
|
if len(c.Source) > 0 {
|
||||||
for i := range kdeploy.Spec.Template.PodSpec.Containers {
|
for i := range kdeploy.Spec.Template.PodSpec.Containers {
|
||||||
kdeploy.Spec.Template.PodSpec.Containers[i].Image = s.Source
|
kdeploy.Spec.Template.PodSpec.Containers[i].Image = c.Source
|
||||||
kdeploy.Spec.Template.PodSpec.Containers[i].Command = []string{}
|
kdeploy.Spec.Template.PodSpec.Containers[i].Command = []string{}
|
||||||
kdeploy.Spec.Template.PodSpec.Containers[i].Args = []string{name}
|
kdeploy.Spec.Template.PodSpec.Containers[i].Args = []string{name}
|
||||||
}
|
}
|
||||||
|
@ -53,6 +53,8 @@ type CreateOptions struct {
|
|||||||
Type string
|
Type string
|
||||||
// Retries before failing deploy
|
// Retries before failing deploy
|
||||||
Retries int
|
Retries int
|
||||||
|
// Source of the service
|
||||||
|
Source string
|
||||||
}
|
}
|
||||||
|
|
||||||
// ReadOptions queries runtime services
|
// ReadOptions queries runtime services
|
||||||
@ -72,6 +74,13 @@ func CreateType(t string) CreateOption {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// CreateSource sets the source of service to create
|
||||||
|
func CreateSource(t string) CreateOption {
|
||||||
|
return func(o *CreateOptions) {
|
||||||
|
o.Source = t
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// WithCommand specifies the command to execute
|
// WithCommand specifies the command to execute
|
||||||
func WithCommand(args ...string) CreateOption {
|
func WithCommand(args ...string) CreateOption {
|
||||||
return func(o *CreateOptions) {
|
return func(o *CreateOptions) {
|
||||||
|
@ -35,6 +35,11 @@ func (s *svc) Create(svc *runtime.Service, opts ...runtime.CreateOption) error {
|
|||||||
o(&options)
|
o(&options)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// set the default source from MICRO_RUNTIME_SOURCE
|
||||||
|
if len(svc.Source) == 0 {
|
||||||
|
svc.Source = s.options.Source
|
||||||
|
}
|
||||||
|
|
||||||
// runtime service create request
|
// runtime service create request
|
||||||
req := &pb.CreateRequest{
|
req := &pb.CreateRequest{
|
||||||
Service: &pb.Service{
|
Service: &pb.Service{
|
||||||
|
@ -91,6 +91,8 @@ func CertsFromPEM(pemCerts []byte) ([]*x509.Certificate, error) {
|
|||||||
func Format(v string) string {
|
func Format(v string) string {
|
||||||
// to lower case
|
// to lower case
|
||||||
v = strings.ToLower(v)
|
v = strings.ToLower(v)
|
||||||
|
// / to dashes
|
||||||
|
v = strings.ReplaceAll(v, "/", "-")
|
||||||
// dots to dashes
|
// dots to dashes
|
||||||
v = strings.ReplaceAll(v, ".", "-")
|
v = strings.ReplaceAll(v, ".", "-")
|
||||||
// limit to 253 chars
|
// limit to 253 chars
|
||||||
|
Loading…
Reference in New Issue
Block a user