-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathplatform.tex
339 lines (258 loc) · 14.8 KB
/
platform.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
\documentclass[10pt,a4paper]{article}
\usepackage[utf8]{inputenc}
\usepackage[english]{babel}
\usepackage[activate={true,nocompatibility},final,tracking=true,kerning=true,spacing=true]{microtype}
\usepackage[plainpages=false,pdfpagelabels,unicode]{hyperref}
\usepackage{fullpage}
\usepackage{graphicx}
\usepackage{fancyhdr}
\usepackage{occi}
\setlength{\headheight}{13pt}
\pagestyle{fancy}
% just a test
% default sans-serif
\renewcommand{\familydefault}{\sfdefault}
% no lines for headers and footers
\renewcommand{\headrulewidth}{0pt}
\renewcommand{\footrulewidth}{0pt}
% header
\fancyhf{}
\lhead{GFD-R-P.227}
\rhead{\today}
% footer
\lfoot{[email protected]}
\rfoot{\thepage}
% paragraphs need some space...
\setlength{\parindent}{0pt}
\setlength{\parskip}{1ex plus 0.5ex minus 0.2ex}
%\renewcommand\paragraph{%
% \@startsection{paragraph}{4}{0mm}%
% {-\baselineskip}%
% {.5\baselineskip}%
% {\normalfont\normalsize\bfseries}}
% some space between header and text...
\headsep 13pt
\setcounter{secnumdepth}{4}
\begin{document}
% header on first page is different
\thispagestyle{empty}
GFD-R-P.227 \hfill Thijs Metsch, Intel\\
OCCI-WG \hfill Mohamed Mohamed, Telecom SudParis\\
\rightline {\today}
\vspace*{0.5in}
\begin{Large}
\textbf{Open Cloud Computing Interface -- Platform}
\end{Large}
\vspace*{0.5in}
\underline{Status of this Document}
\input{include/status}
\underline{Copyright Notice}
Copyright \copyright ~Open Grid Forum (2014-2016). All Rights
Reserved.
\underline{Trademarks}
OCCI is a trademark of the Open Grid Forum.
\underline{Abstract}
\input{include/abstract}
\newpage
\tableofcontents
\newpage
\section{Introduction}
\input{include/introduction}
OCCI makes an ideal interoperable boundary interface between the web
and the internal resource management system of platform providers.
\section{Notational Conventions}
\input{include/notational}
% begin platform content
\section{Platform}
The OCCI Platform document details how an OCCI implementation can model and implement a Platform as a Service API offering by extending the OCCI Core Model. This API enables the provisioning and management of PaaS resources. For example, it allows to deploy an application on one or more PaaS components. The application itself could be composed of different components. The main platform types defined within OCCI Platform are:
\begin{description}
\item[Application] Which defines the user-defined part of the overall service.
\item[Component] A configured instance of a piece of code providing business functions that are part of the execution of the application or responsible of hosting the application.
\item[ComponentLink] Connects an \hl{Application} instance to a hosting \hl{Component} or connects two components.
\end{description}
\begin{figure}[!h]
{\centering \resizebox*{0.7\columnwidth}{!}{\rotatebox{0}
{\includegraphics[scale=0.4]{figs/platform_overview.png}}} \par}
\caption{Overview Diagram of OCCI Platform Types.}
\label{fig:platform_uml}
\end{figure}
These platform types inherit the OCCI Core Model Resource base type and all their attributes. One can use a suitable transport protocol (e.g., HTTP) and a suitable rendering to discover and consume these resources. Independently of the implementation, the defined resources could be discoverable during runtime through OCCI compliant interfaces.
As required by the OCCI Core Model specification, every instantiated type that is a sub-type of \hl{Resource} or \hl{Link} MUST be assigned a \hl{Kind} that identifies the instantiated type. Each such \hl{Kind} instance MUST be related to the Resource or Link base type's \hl{Kind}. That assigned \hl{Kind} instance MUST always remain immutable to any client.
\subsection{Application Kind Definition}
The following kind MUST be present and represents the kind definition of an application resource.
\hl{Application} inherits the \hl{Resource} base type defined in OCCI Core Model \cite{occi:core}. \hl{Application} is assigned the \hl{Kind} instance \textit{http://schemas.ogf.org/occi/platform\#application}. An \hl{Application} instance MUST use and expose this \hl{Kind}. The \hl{Kind} instance assigned to the \hl{Application} type MUST be related to the \textit{http://schemas.ogf.org/occi/core\#resource} \hl{Kind} by setting the \texttt{parent} attribute.
\mytablefloat{
\label{tbl:app}\hl{Attribute}s defined for the \hl{Application} type.
}
{
\begin{tabular}{lp{2.5cm}p{1cm}lp{5cm}}
\toprule
Attribute&Type&Multi\-plicity&Mutability&Description\\
\colrule
occi.app.name & String & 1 & Mutable & Name of the application.\\
occi.app.context & URL & 1 & Immutable & URL for contextualizing the app.\\
occi.app.url & URL & 1 & Immutable & DNS entry.\\
occi.app.state & Enum \{active, inactive, error\} & 1 & Immutable & State of the application.\\
occi.app.state.message & String & 0..1 & Immutable & Human-readable explanation of the current instance state.\\
\botrule
\end{tabular}
}
Table~\ref{tbl:app} describes the \hl{Attribute}s defined by an \hl{Application} instance. These attributes MAY or MUST be exposed by an instance of the \hl{Application} type depending on the ``Multiplicity'' column in the aforementioned table.
The \hl{Action}s are defined by the \hl{Kind} instance \textit{http://schemas.ogf.org/occi/platform\#application}. Every \hl{Action} instance in the table uses the \textit{http://schemas.ogf.org/occi/platform/application/action\#} categorisation scheme. ``Action Term'' below refers to \texttt{\hl{Action}.term}.
\mytablefloat{
\label{tbl:app_actions}
\hl{Action}s applicable to instances of the \hl{Application} type.
}
{
\begin{tabular}{lll}
\toprule
Action Term & Target state & Attributes \\
\colrule
start & active & -- \\
stop & inactive & -- \\
\botrule
\end{tabular}
}
The state model for the \hl{Application} instance is defined in Fig.~\ref{fig:app_state}.
\begin{figure}[!h]
{\centering \resizebox*{0.5\columnwidth}{!}{\rotatebox{0}
{\includegraphics[scale=0.2]{figs/platform_component_state.png}}} \par}
\caption{State model of an \hl{Application} instance.}
\label{fig:app_state}
\end{figure}
\subsection{Component Kind Definition}
The following kind MUST be present and represents the kind definition of a component resource.
\hl{Component} inherits the \hl{Resource} base type defined in OCCI Core Model \cite{occi:core}. \hl{Component} is assigned the \hl{Kind} instance \textit{http://schemas.ogf.org/occi/platform\#component}. A \hl{Component} instance MUST use and expose this \hl{Kind}. The \hl{Kind} instance assigned to the \hl{Component} type MUST be related to the \textit{http://schemas.ogf.org/occi/core\#resource} \hl{Kind} by setting the \texttt{parent} attribute.
\mytablefloat{
\label{tbl:component}\hl{Attribute}s defined for the \hl{Component} type.
}
{
\begin{tabular}{lp{2.5cm}p{1cm}lp{5cm}}
\toprule
Attribute&Type&Multi\-plicity&Mutability&Description\\
\colrule
occi.component.state & Enum \{active, inactive, error\} & 1 & Immutable & State of the component.\\
occi.component.state.message & String & 0..1 & Immutable & Human-readable explanation of the current instance state.\\
\botrule
\end{tabular}
}
Table~\ref{tbl:component} describes the \hl{Attribute}s defined by \hl{Component} instance. These attributes MAY or MUST be exposed by an instance of the \hl{Component} type depending on the ``Multiplicity'' column in the aforementioned table.
The \hl{Action}s are defined by the \hl{Kind} instance \textit{http://schemas.ogf.org/occi/platform\#component}. Every \hl{Action} instance in the table uses the \textit{http://schemas.ogf.org/occi/platform/component/action\#} categorisation scheme. ``Action Term'' below refers to \hl{Action}.{\tt term}
\mytablefloat{
\label{tbl:component_actions}
\hl{Action}s applicable to instances of the \hl{Application} type.
}
{
\begin{tabular}{lll}
\toprule
Action Term & Target state & Attributes \\
\colrule
start & active & -- \\
stop & inactive & -- \\
\botrule
\end{tabular}
}
The state model for the \hl{Component} instance is defined in Fig.~\ref{fig:component_state}.
\begin{figure}[!h]
{\centering \resizebox*{0.5\columnwidth}{!}{\rotatebox{0}
{\includegraphics[scale=0.2]{figs/platform_component_state.png}}} \par}
\caption{State model of a \hl{Component} instance.}
\label{fig:component_state}
\end{figure}
\subsection{Linking to Components}
The composition of a service is realized through the linkage
of \hl{Application} and \hl{Component} instances with each
other. \hl{Application} can be linked to many \hl{Component}
instances. This allows \hl{Application} and \hl{Component}s
to form acyclic graphs. To illustrate this with an example, the
\hl{Application} is the frontend, perceived by the user, to a
composition of \hl{Component}s. To have a composition
of \hl{Component}s (e.g. microservices) those \hl{Components}
need to be related to one another (e.g. Applciation linking to
its DB or the DB linking to a monitoring service).
\hl{ComponentLink} inherits the \hl{Link} base type defined in OCCI Core Model \cite{occi:core}. \hl{ComponentLink} is assigned the \hl{Kind} instance \textit{http://schemas.ogf.org/occi/platform\#componentlink}. The \hl{Kind} instance assigned to the \hl{ComponentLink} type MUST be related to the \textit{http://schemas.ogf.org/occi/core\#link} \hl{Kind} by setting the \texttt{parent} attribute.
The \hl{ComponentLink} kind can be further enhanced by the use of provider-specific Mixins. This can be used to expose details such as database access URIs for an application linked up with a database component.
\subsection{Platform Templates}
Platform Templates allow for clients of an OCCI implementation to quickly and conveniently apply predefined configurations to OCCI Platform defined types. They are implemented using Mixin instances. There are two supported platform template types in OCCI Platform.
\subsubsection{Application Template}
Application templates allow clients to define which underlying framework the application should use (e.g., Programming language).
The Application Template is defined by a Mixin. A provider-specific defined Application Template Mixin MUST relate to the OCCI Application Template Mixin through the \texttt{depends} attribute in order to give absolute type information. The OCCI Application Template is defined by the \textit{http://schemas.ogf.org/occi/platform\#app\_tpl} Mixin and MUST be supported should Application Templates be offered.
Provider-specific Application Templates are constructed using a ``term'' and ``scheme'' combination where the ``term'' is a provider-specific description of the framework (e.g., python, ruby, \dots{}). Where an implementation requires additional information to be held in the Templates Mixin, it MAY do so by using \hl{Category}’s inherited \hl{Attribute}s.
\subsubsection{Resource Template}
The Resource Template Mixin builds upon the concept of Application Templates. A Resource Template is a provider defined Mixin instance that refers to a preset Resource configuration.
This can be used to define the resource instance attributes of the application and component. The provider-specific Resource Templates are defined by using a ``term'' and ``scheme'' combination. Those provider-specific Resource Template Mixin must relate to the OCCI Resource Template defined by \textit{http://schemas.ogf.org/occi/} \textit{platform\#res\_tpl} through the \texttt{depends} attribute. Where an implementation requires additional information to be held in the Templates Mixin, it MAY do so by using \hl{Category}'s inherited \hl{Attribute}s.
An example of these templates is shown in the following UML diagram in Figure~\ref{fig:templates}.
\begin{figure}[!h]
{\centering \resizebox*{0.7\columnwidth}{!}{\rotatebox{0}
{\includegraphics[scale=0.5]{figs/platform_templates.png}}} \par}
\caption{Application and Resource Templates.}
\label{fig:templates}
\end{figure}
\section{Specific Component Instance Mixins}
The following sections describe \hl{Mixin} instances, which SHOULD be implemented by Providers for some basic component type.
\subsection{Database Mixin}
\hl{Database} inherits the \hl{Mixin} base type defined in OCCI Core Model \cite{occi:core}. \hl{Database} is assigned the \hl{Mixin} instance \textit{http://schemas.ogf.org/occi/platform\#database}. The \hl{Database} instance \texttt{applies} to the \hl{Component} instance defined above.
\mytablefloat{
\label{tbl:database}\hl{Attribute}s defined for the \hl{Database} type.
}
{
\begin{tabular}{lp{2.5cm}p{1cm}lp{5cm}}
\toprule
Attribute&Type&Multi\-plicity&Mutability&Description\\
\colrule
occi.database.version & String & 1 & Immutable & Version of the database.\\
\botrule
\end{tabular}
}
Table~\ref{tbl:database} describes the \hl{Attribute}s defined by \hl{Database} instance.
\subsubsection{Database Link}
In case that an \hl{Application} instance links to a \hl{Component} instance, which has the \hl{Database} \hl{Mixin} instance applied the following \hl{Mixin} SHOULD be applied to the \hl{ComponentLink}.
\hl{DatabaseLink} inherits the \hl{Mixin} base type defined in OCCI Core Model \cite{occi:core}. \hl{DatabaseLink} is assigned the \hl{Mixin} instance \textit{http://schemas.ogf.org/occi/platform\#databaselink}. The \hl{DatabaseLink} instance \texttt{applies} to the \hl{ComponentLink} instance defined above.
\mytablefloat{
\label{tbl:database_link}\hl{Attribute}s defined for the \hl{Database} type.
}
{
\begin{tabular}{lp{2.5cm}p{1cm}lp{5cm}}
\toprule
Attribute&Type&Multi\-plicity&Mutability&Description\\
\colrule
occi.database.uri & URI & 1 & Immutable & Connection URI for the database instance.\\
occi.database.username & URI & 0\ldots1 & Immutable & Username.\\
occi.database.token & URI & 0\ldots1 & Immutable & Token.\\
\botrule
\end{tabular}
}
Table~\ref{tbl:database_link} describes the \hl{Attribute}s defined by \hl{DatabaseLink} instance.
% end platform content
\section{Security Considerations}
The OCCI Platform specification is an extension to the OCCI Core
Model specification \cite{occi:core}; thus the same security
considerations as for the OCCI Core Model specification apply
here.
\section{Glossary}
\label{sec:glossary}
\input{include/glossary}
\section{Contributors}
We would like to thank the following people who contributed to this
document:
\begin{tabular}{l|p{2in}|p{2in}}
Name & Affiliation & Contact \\
\hline
Andy Edmonds & ICCLab, ZHAW & edmo at zhaw.ch \\
Peter Troeger & TU Chemnitz & [email protected] \\
Thijs Metsch & Intel & [email protected]\\
Sami Yangui & Concordia University & s\[email protected] \\
Mohamed Mohamed & Telecom SudParis & \\
Philippe Merle & Inria & [email protected] \\
\end{tabular}
Next to these individual contributions we value the contributions from
the OCCI working group.
\section{Intellectual Property Statement}
\input{include/ip}
\section{Disclaimer}
\input{include/disclaimer}
\section{Full Copyright Notice}
\input{include/copyright}
\bibliographystyle{IEEEtran}
\bibliography{references}
\end{document}