aboutsummaryrefslogtreecommitdiffstats
path: root/functest/opnfv_tests/vnf/router/__init__.py
diff options
context:
space:
mode:
authorCedric Ollivier <ollivier.cedric@gmail.com>2017-04-13 15:28:43 +0000
committerGerrit Code Review <gerrit@opnfv.org>2017-04-13 15:28:43 +0000
commit32ccb8926fd7057fed83f68e9035bd13577bf58a (patch)
tree1dcefef5c00e21a23b8ea06b432819d207ef1716 /functest/opnfv_tests/vnf/router/__init__.py
parent888271575907898d80081e69b37f879091a636fc (diff)
parenta53de635ee773435f8a789844b484a35441e6862 (diff)
Merge "update check_os.sh admin port seds to match public"
Diffstat (limited to 'functest/opnfv_tests/vnf/router/__init__.py')
0 files changed, 0 insertions, 0 deletions
light .sx { color: #e6db74 } /* Literal.String.Other */ .highlight .sr { color: #e6db74 } /* Literal.String.Regex */ .highlight .s1 { color: #e6db74 } /* Literal.String.Single */ .highlight .ss { color: #e6db74 } /* Literal.String.Symbol */ .highlight .bp { color: #f8f8f2 } /* Name.Builtin.Pseudo */ .highlight .fm { color: #a6e22e } /* Name.Function.Magic */ .highlight .vc { color: #f8f8f2 } /* Name.Variable.Class */ .highlight .vg { color: #f8f8f2 } /* Name.Variable.Global */ .highlight .vi { color: #f8f8f2 } /* Name.Variable.Instance */ .highlight .vm { color: #f8f8f2 } /* Name.Variable.Magic */ .highlight .il { color: #ae81ff } /* Literal.Number.Integer.Long */ } @media (prefers-color-scheme: light) { .highlight .hll { background-color: #ffffcc } .highlight .c { color: #888888 } /* Comment */ .highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */ .highlight .k { color: #008800; font-weight: bold } /* Keyword */ .highlight .ch { color: #888888 } /* Comment.Hashbang */ .highlight .cm { color: #888888 } /* Comment.Multiline */ .highlight .cp { color: #cc0000; font-weight: bold } /* Comment.Preproc */ .highlight .cpf { color: #888888 } /* Comment.PreprocFile */ .highlight .c1 { color: #888888 } /* Comment.Single */ .highlight .cs { color: #cc0000; font-weight: bold; background-color: #fff0f0 } /* Comment.Special */ .highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */ .highlight .ge { font-style: italic } /* Generic.Emph */ .highlight .gr { color: #aa0000 } /* Generic.Error */ .highlight .gh { color: #333333 } /* Generic.Heading */ .highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */ .highlight .go { color: #888888 } /* Generic.Output */ .highlight .gp { color: #555555 } /* Generic.Prompt */ .highlight .gs { font-weight: bold } /* Generic.Strong */ .highlight .gu { color: #666666 } /* Generic.Subheading */ .highlight .gt { color: #aa0000 } /* Generic.Traceback */ .highlight .kc { color: #008800; font-weight: bold } /* Keyword.Constant */ .highlight .kd { color: #008800; font-weight: bold } /* Keyword.Declaration */ .highlight .kn { color: #008800; font-weight: bold } /* Keyword.Namespace */ .highlight .kp { color: #008800 } /* Keyword.Pseudo */ .highlight .kr { color: #008800; font-weight: bold } /* Keyword.Reserved */ .highlight .kt { color: #888888; font-weight: bold } /* Keyword.Type */ .highlight .m { color: #0000DD; font-weight: bold } /* Literal.Number */ .highlight .s { color: #dd2200; background-color: #fff0f0 } /* Literal.String */ .highlight .na { color: #336699 } /* Name.Attribute */ .highlight .nb { color: #003388 } /* Name.Builtin */ .highlight .nc { color: #bb0066; font-weight: bold } /* Name.Class */ .highlight .no { color: #003366; font-weight: bold } /* Name.Constant */ .highlight .nd { color: #555555 } /* Name.Decorator */ .highlight .ne { color: #bb0066; font-weight: bold } /* Name.Exception */ .highlight .nf { color: #0066bb; font-weight: bold } /* Name.Function */ .highlight .nl { color: #336699; font-style: italic } /* Name.Label */ .highlight .nn { color: #bb0066; font-weight: bold } /* Name.Namespace */ .highlight .py { color: #336699; font-weight: bold } /* Name.Property */ .highlight .nt { color: #bb0066; font-weight: bold } /* Name.Tag */ .highlight .nv { color: #336699 } /* Name.Variable */ .highlight .ow { color: #008800 } /* Operator.Word */ .highlight .w { color: #bbbbbb } /* Text.Whitespace */ .highlight .mb { color: #0000DD; font-weight: bold } /* Literal.Number.Bin */ .highlight .mf { color: #0000DD; font-weight: bold } /* Literal.Number.Float */ .highlight .mh { color: #0000DD; font-weight: bold } /* Literal.Number.Hex */ .highlight .mi { color: #0000DD; font-weight: bold } /* Literal.Number.Integer */ .highlight .mo { color: #0000DD; font-weight: bold } /* Literal.Number.Oct */ .highlight .sa { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Affix */ .highlight .sb { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Backtick */ .highlight .sc { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Char */ .highlight .dl { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Delimiter */ .highlight .sd { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Doc */ .highlight .s2 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Double */ .highlight .se { color: #0044dd; background-color: #fff0f0 } /* Literal.String.Escape */ .highlight .sh { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Heredoc */ .highlight .si { color: #3333bb; background-color: #fff0f0 } /* Literal.String.Interpol */ .highlight .sx { color: #22bb22; background-color: #f0fff0 } /* Literal.String.Other */ .highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */ .highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */ .highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */ .highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */ .highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */ .highlight .vc { color: #336699 } /* Name.Variable.Class */ .highlight .vg { color: #dd7700 } /* Name.Variable.Global */ .highlight .vi { color: #3333bb } /* Name.Variable.Instance */ .highlight .vm { color: #336699 } /* Name.Variable.Magic */ .highlight .il { color: #0000DD; font-weight: bold } /* Literal.Number.Integer.Long */ }
=======================
Use cases and scenarios
=======================

Resource reservation is a basic feature in any virtualization-based network
operation. In order to perform such resource reservation from NFVO to VIM, NFVI
capacity information is also necessary at the NFVO side. Below, four use cases
to show typical requirements and solutions for capacity management and resource
reservation is presented. A typical use case as considered for the Brahmaputra
release is described in :ref:`uc-brahmaputra`.

#.  Resource capacity management
#.  Resource reservation for immediate use
#.  Resource reservation for future use
#.  Co-existence of reservations and allocation requests without reservation

Resource capacity management
============================

NFVO takes the first decision on in which NFVI it would instantiate a VNF. Along
with NFVIs resource attributes (e.g. availability of hardware accelerators,
particular CPU architectures etc.), NFVO needs to know available capacity of an
NFVI in order to make an informed decision on selecting a particular NFVI. Such
capacity information shall be in a coarser granularity than the respective VIM,
as VIM maintains capacity information of its NFVI in fine details.  However a
very coarse granularity, like simply the number of available virtual CPU cores,
may not be sufficient. In order to allow the NFVO to make well founded
allocation decisions, an appropriate level to expose the available capacity may
be per flavor. Capacity information may be required for the complete NFVI, or
per partition or availability zone, or other granularities. Therefore, VIM
requires to inform the NFVO about available capacity information regarding its
NFVI at a pre-determined abstraction, either by a query-response, or in an
event-based, or in a periodical way.

Resource reservation for immediate use
======================================

Reservation is inherently for the future. Even if some reserved resources are to
be consumed instantly, there is a network latency between the issuance of a
resource reservation request from the NFVO, a response from the VIM, and actual
allocation of the requested resources to a VNF/VNFM. Within such latency,
resource capacity in the NFVI in question could change, e.g., due to failure,
allocation to a different request. Therefore, the response from a VIM to the
NFVO to a resource reservation request for immediate use should have a validity
period which shows until when this VIM can hold the requested resources. During
this time, the NFVO should proceed to allocation if it wishes to consume the
reserved requested. If allocation is not performed within the validity period,
the response from VIM for a particular resource reservation request becomes
invalid and VIM is not liable to provide those resources to NFVO/VNFM anymore.
Reservations requests for immediate use do not have a start time but may have
an end time.

Resource reservation for future use
===================================

Network operators may want to reserve extra resources for future use. Such
necessity could arise from predicted congestion in telecom nodes e.g. due to
local traffic spikes for concerts, natural disasters etc. In such a case, the
NFVO, while sending a resource reservation request to the VIM, shall include a
start time (and an end time if necessary). The start time indicates at what
time the reserved resource shall be available to a designated consumer e.g. a
VNF/VNFM. Here, the requirement is that the reserved resources shall be
available when the start time arrives. After the start time has arrived, the
reserved resources are allocated to the designated consumer(s). An explicit
allocation request is needed. How actually these requested resources are held
by the VIM for the period in between the arrival of the resource reservation
request and the actual allocation is outside the scope of this requirement
project.

Co-existence of reservations and allocation requests without reservation
========================================================================

In a real environment VIM will have to handle allocation requests without any
time reference, i.e. time-unbound, together with time-bound reservations and
allocation requests with an explicitly indicated end-time. A granted
reservation for the future will effectively reduce the available capacity for
any new time-unbound allocation request. The consequence is that reservations,
even those far in the future, may result in denial of service for new
allocation requests.

To alleviate this problem several approaches can be taken. They imply an
implicit or explicit priority scheme:

* Allocation requests without reservation and which are time-unbound will be
  granted resources in a best-effort way: if there is instant capacity, but the
  resources may be later withdrawn due to the start time of a previously
  granted reservation
* Both allocation requests and reservation requests contain a priority which
  may be related to SLAs and contractual conditions between the tenant and the
  NFVI provider. Interactions may look like:

  * A reservation request for future use may cancel another, not yet
    started, reservation with lower priority
  * An allocation request without reservations and time-unbound [#unbound]_
    may be granted resources and prevent a future reservation with lower
    priority from getting resources at start time
  * A reservation request may result in terminating resources allocated to a
    request with no reservation, if the latter has lower priority

.. [#unbound] In this case, the consumer (VNFM or NFVO) requests to immediately
              instantiate and assign virtualized resources without having
              reserved the resources beforehand