Skip to content

Commit

Permalink
simplify volume dispense: compatible computing
Browse files Browse the repository at this point in the history
  • Loading branch information
jschwinger233 committed Nov 11, 2020
1 parent b6288f4 commit 2fad2f2
Show file tree
Hide file tree
Showing 11 changed files with 160 additions and 339 deletions.
4 changes: 2 additions & 2 deletions client/servicediscovery/eru_service_discovery.go
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ func (w *EruServiceDiscovery) Watch(ctx context.Context) (_ <-chan []string, err

for {
cancelTimer := make(chan struct{})
go func() {
go func(expectedInterval time.Duration) {
timer := time.NewTimer(expectedInterval * time.Second)
defer timer.Stop()
select {
Expand All @@ -60,7 +60,7 @@ func (w *EruServiceDiscovery) Watch(ctx context.Context) (_ <-chan []string, err
case <-cancelTimer:
return
}
}()
}(expectedInterval)
status, err := stream.Recv()
close(cancelTimer)
if err != nil {
Expand Down
2 changes: 1 addition & 1 deletion cluster/calcium/create.go
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ func (c *Calcium) doCreateWorkloads(ctx context.Context, opts *types.DeployOptio
for nodename, rollbackIndices := range rollbackMap {
if e := c.withNodeLocked(ctx, nodename, func(node *types.Node) error {
for _, plan := range plans {
plan.RollbackChangesOnNode(node, rollbackIndices...)
plan.RollbackChangesOnNode(node, rollbackIndices...) // nolint:scopelint
}
return errors.WithStack(c.store.UpdateNodes(ctx, node))
}); e != nil {
Expand Down
36 changes: 17 additions & 19 deletions cluster/calcium/realloc.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ import (
"github.com/projecteru2/core/utils"
)

// ReallocResource updates workload resource dynamically
func (c *Calcium) ReallocResource(ctx context.Context, opts *types.ReallocOptions) (err error) {
return c.withContainerLocked(ctx, opts.ID, func(container *types.Container) error {
rrs, err := resources.MakeRequests(
Expand Down Expand Up @@ -41,11 +42,10 @@ func (c *Calcium) doReallocOnNode(ctx context.Context, nodename string, containe
if err != nil {
return errors.WithStack(err)
}
if total != 1 {
if total < 1 {
return errors.WithStack(types.ErrInsufficientRes)
}

originalContainer := *container
return utils.Txn(
ctx,

Expand All @@ -60,17 +60,8 @@ func (c *Calcium) doReallocOnNode(ctx context.Context, nodename string, containe
}
return c.store.UpdateNodes(ctx, node)
},
// rollback to origin
func(ctx context.Context, failureByCond bool) error {
if failureByCond {
return nil
}
for _, plan := range plans {
plan.RollbackChangesOnNode(node, 1)
}
node.PreserveResources(&originalContainer.ResourceMeta)
return c.store.UpdateNodes(ctx, node)
},
// no need rollback
nil,

c.config.GlobalTimeout,
)
Expand All @@ -80,12 +71,9 @@ func (c *Calcium) doReallocOnNode(ctx context.Context, nodename string, containe
func (c *Calcium) doReallocContainersOnInstance(ctx context.Context, node *types.Node, plans []resourcetypes.ResourcePlans, container *types.Container) (err error) {
r := &types.ResourceMeta{}
for _, plan := range plans {
// TODO@zc: single existing instance
// TODO@zc: no HardVolumeBindings
if r, err = plan.Dispense(resourcetypes.DispenseOptions{
Node: node,
Index: 1,
ExistingInstances: []*types.Container{container},
Node: node,
ExistingInstance: container,
}, r); err != nil {
return
}
Expand Down Expand Up @@ -131,7 +119,17 @@ func (c *Calcium) doReallocContainersOnInstance(ctx context.Context, node *types
if failureByCond {
return nil
}
return errors.WithStack(c.store.UpdateContainer(ctx, &originalContainer))
r := &enginetypes.VirtualizationResource{
CPU: originalContainer.CPU,
Quota: originalContainer.CPUQuotaLimit,
NUMANode: originalContainer.NUMANode,
Memory: originalContainer.MemoryLimit,
Volumes: originalContainer.VolumeLimit.ToStringSlice(false, false),
VolumePlan: originalContainer.VolumePlanLimit.ToLiteral(),
VolumeChanged: r.VolumeChanged,
Storage: originalContainer.StorageLimit,
}
return errors.WithStack(node.Engine.VirtualizationUpdateResource(ctx, container.ID, r))
},

c.config.GlobalTimeout,
Expand Down
Loading

0 comments on commit 2fad2f2

Please sign in to comment.