Commit edeeff89 authored by Daniele Venzano's avatar Daniele Venzano

Update changelog

parent ad31af17
......@@ -6,6 +6,8 @@
* New elastic scheduler added, the default remains the one available in previous releases
* Abstraction of container backends, that are now configurable as well
* Added a new backend based on the old swarm, but using the new docker API library. The old Swarm backend is not deprecated and will be removed in the next release
* Use underscores in container labels instead of dots, to work around special meaning of dots in several monitoring systems
* A revised ZApp format and packaging, see the ZApp documentation for more details
## Version 0.10.2
# Copyright (c) 2017, Daniele Venzano
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""When a service from the application description needs to be instantiated, it is transformed into a ServiceInstance, an internal representation of a generic container. This class is used to gather all the attributes that describe a container and to provide a clear interface with the backend."""
from zoe_lib.state import Service, Execution
from zoe_lib.config import get_conf
import zoe_master.backends.common
class ServiceInstance:
"""The ServiceInstance class, a Service that is going to be instantiated into a container."""
def __init__(self, execution: Execution, service: Service): =
self.hostname = service.dns_name
self.memory_limit = service.resource_reservation.memory
self.core_limit = service.resource_reservation.cores
self.labels = {
'': str(,
'': str(,
'zoe.owner': execution.user_id,
'zoe.deployment_name': get_conf().deployment_name,
'zoe.type': 'app_service'
if service.is_monitor:
self.labels['zoe_monitor'] = 'true'
self.labels['zoe_monitor'] = 'false'
self.labels = zoe_master.backends.common.gen_labels(service, execution)
self.environment = service.environment + zoe_master.backends.common.gen_environment(service, execution)
self.volumes = service.volumes + zoe_master.backends.common.gen_volumes(service, execution)
self.entrypoint = '/'
self.command = service.command
self.image_name = service.image_name
self.ports = service.ports
Markdown is supported
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment