Motivations
In 2023 we want to start off prototyping an open tool which will help make designing edge services easier. The overall goals of this year's development are as follows:
- Improve on existing tooling for edge service designers in a substantial way
- Provide an open source implementation
- Have something usable in a short (<1year) time frame
Even a relatively small piece of working code can be an anchor for further improvements. We also want to get our ideas "out there" to see what has traction (i.e. what looks useful to other developers and service designers). Hopefully, this can lead to productive partnerships and encourage ongoing development towards implementing the overall vision of the platform.
Focus
We've looked at the landscape of open tools and standards which could be applied to edge services, and have settled, at least for now, on OASIS TOSCA as a potential base technology. TOSCA is already in use in ONAP. It is a relatively mature standard, but still actively under development, and with several implementations. In particular, Eclipse Winery is an open source tool that provides graphical visualization and design tools using TOSCA data structures and formats. XOpera is another tool which provides support for deploying services described by TOSCA CSAR files.
TOSCA is a standard focused firstmost on cloud services. It seems likely that adapting it for use on the edge will require some work. On the other hand, it does provide a firm and extremely flexible foundation for modeling services. For this reason, and because of the availability of open source tooling mentioned above, it seems like a good fit for our project.
Our initial focus will be adding and extending functionality to Eclipse Winery in support of these goals:
- Reducing complexity for people designing edge services by supporting flexible and reusable service designs (service catalogs) and abstractions of service subsystems (components)
- Supporting developers of edge-oriented software and hardware offerings by making it possible to provide their products to service designers as service components, with the potential to be simply dropped into a service design with minimal configuration
How we plan to do this will be discussed below.
Basic Design
In this section we describe the approach we will be taking to implementing the new functionality in Eclipse Winery.
TOSCA and Eclipse Winery Fundamentals
Describe TOSCA modeling fundamentals and how Winery visualizes them, to provide a basis for understanding the new functionality described below.
TOSCA has a concept of node substitution, where a node in a service template can be programatically replaces by a group of nodes and relationships. This closely resembles the idea of components which will be described below. Where possible, we hope to make use of the syntax and concepts already developed as part of node substitution to implement support for components. We may even find that node substitution with only minor extensions can be applied directly to support components. This is an area for ongoing investigation as part of this year's development process.
Support for Components
Describe how components will be modeled in Winery and how they are expected to behave in a service catalog.
Flexible Service Catalogs
Describe what service catalogs are and how they will be implemented in the context of TOSCA and Winery.
Future Development
After the initial pass described above, we hope to continue expanding on the base we will establish this year. A few of the directions we are already considering are described here.
Deploying Services
The initial focus of our work is on improving the tools for design of services. The other half of the process, deploying those services, could be a focus for upcoming work. XOpera has already been mentioned as an orchestration/deployment tool. Even XOpera will probably require some work to integrate our changes, or at the very least testing and verification. We would also like to make our approach as agnostic as possible, supporting multiple tools, possibly through a plugin framework, and even potentially more than one orchestration tool in the same service. Service deployment and management has seen more work in the open source community than service design, so there are many potential tools to choose from.