guides:user:servicetypes:servicetypes_overview
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
guides:user:servicetypes:servicetypes_overview [2020/01/02 15:14] – [Special names] yspeerte | guides:user:servicetypes:servicetypes_overview [2024/07/03 12:31] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 1: | Line 1: | ||
+ | {{indexmenu_n> | ||
+ | |||
+ | ====== Service-types definition ====== | ||
+ | |||
+ | |||
+ | ===== Service-type commands ===== | ||
+ | |||
+ | It should be clear now that Service-types are an automated way to create and manipulate network related objects in an vendor independent (agnostic) and abstract manner. They do so by executing step-by-step a series of Service-type commands that perform specific actions on these objects. | ||
+ | |||
+ | Only four basic types of commands are needed: ADD, LOCATE, ASSIGN and DELETE. These execution types are available on all 17 object types and come in many specific variations to perform an action. In total about 250 unique Service-type commands are available. | ||
+ | |||
+ | Service-types commands are created using a simple wizard where the operator first chooses an execution type and an object type, which then filters for the available actions and options. Each Service-type command consists of of no more than six components. | ||
+ | |||
+ | The command for creating a new node in a service container looks like this: | ||
+ | |||
+ | < | ||
+ | [exec - class - scope - match - value - alias] | ||
+ | | ||
+ | </ | ||
+ | |||
+ | This line could be read as: ADD a NODE to the service <srv> with the NODE_TYPE ‘value’ and return the alias < | ||
+ | |||
+ | A subsequent Service-type command could rename the auto-generated nodename to something specific using: | ||
+ | |||
+ | < | ||
+ | [exec - class - scope - match - value - alias] | ||
+ | | ||
+ | </ | ||
+ | |||
+ | This line could be read like: ASSIGN to the NODE < | ||
+ | |||
+ | In this context, any enclosed in <..> refers to an ‘alias’. The alias is a descriptive handle to a returned object. It is used to perform additional manipulations and assignments once it is created or located. The notation using <..> is optional but highly recommended. | ||
+ | |||
+ | See the section below on Alias names [[guides: | ||
+ | |||
+ | > <color orange>A full list of all available Service-type commands per object class is maintained in the article [[guides: | ||
+ | |||
+ | |||
+ | ===== Service-type Objects ===== | ||
+ | |||
+ | There are 17 object classes available for manipulation using Service-types in NetYCE. Each represents a building block of the ‘abstract network’. Some have an hierarchical dependency, others are stand-alone or are associated with another object. | ||
+ | |||
+ | // | ||
+ | The Client object is a representation of a customer, internal or external that uses a specific Client-type (the architecture: | ||
+ | |||
+ | // | ||
+ | The Site is a location of a Client. Each Site has a Site_type associated that defines what Service_classes can be configured. | ||
+ | |||
+ | // | ||
+ | Any Site can have many Services within the restrictions imposed by the Service_class. A NetYCE Service is a container that groups objects like Nodes and IP Subnets (v4/v6) that deliver (part of) a service. | ||
+ | |||
+ | // | ||
+ | All Nodes (network devices) reside in a Service container. It can only be created using a Service-type which in turn relies on a Node_type definition. Node_types are grouped in the modelling using Node_classes. The node-type defines many (initial) attributes like the Template and the Hostname. The Template also determines the vendor, its hardware and the port-blueprint. A Node has many attributes but also links into its Domain, the Ports and their Topology. Optionally the VRF’s and eVPN’s it uses. | ||
+ | |||
+ | // | ||
+ | Ports are assigned to Nodes and are assigned a Port-template that defines their function. Ports can be linked using topology. The Port object manipulates | ||
+ | |||
+ | // | ||
+ | Ports are assigned to Nodes and are assigned a Port-template that defines their function. Ports can be linked using topology. The Port object manipulates | ||
+ | |||
+ | // | ||
+ | A Link is technically a set of two Ports sharing Topology. A link can be used to assign shared attributes or to locate the uplink or downlink node. | ||
+ | |||
+ | // | ||
+ | Again, a Slot is a series of ports that can be manipulated as a group, but in this case they share a common slot-id. Slots are mostly used when moving ports between nodes or dealing with stack configurations. | ||
+ | |||
+ | // | ||
+ | Each Client can be allocated one or more IP Supernets (IPv4 and IPv6) that it can use exclusively to extract new IP Subnets from. A Supernet must have an IP-plan assigned that defines how the Supernet may be used to extract the various Subnet-types from. In the NetYCE IP modelling, all subnets are referenced using their name as defined in the IP-plan. The IP-subnet-plan then defines which and how the subnet variables (like Vlan-id) are determined. If no IP-plans can be used (due to non-systematical issuing of ranges), Supernets serve no purpose and custom Subnets must be used. | ||
+ | |||
+ | // | ||
+ | Two types of IPv4 subnets exist in NetYCE, those that conform to an IP-plan and IP-subnet-plan, | ||
+ | |||
+ | // | ||
+ | Subnets are basically a group of IPv4 addresses. Specific addresses can be located and allocated within a subnet or within ranges of a subnet. | ||
+ | |||
+ | // | ||
+ | Two types of IPv6 subnets exist in NetYCE, those that conform to an IP-plan and IP-subnet-plan, | ||
+ | |||
+ | // | ||
+ | IPv6 Subnets are basically a group of IPv6 addresses. Specific addresses can be located and allocated within a subnet or within ranges of a subnet. | ||
+ | |||
+ | // | ||
+ | Every Node has a reference to a Domain. The Domain maintains a large number of attributes that combined define the Network Management environment for that node. Most importantly, | ||
+ | |||
+ | // | ||
+ | Although not strictly a Networking component, Servers and their IP-addresses can have an important role in the various configurations. Often a Client or Site requires a server-related entry that may use addresses or hostname. Servers can also be used to represent access-list entries. NetYCE supports IPv4 and IPV6 or dual-stack based Servers. | ||
+ | |||
+ | // | ||
+ | For VRF definitions and assignments, | ||
+ | |||
+ | // | ||
+ | For VRF definitions and assignments, | ||
+ | |||
+ | // | ||
+ | Every Client is a member of a Region. The Region defines common variables for a series of Clients, regardless of Client_type. Regions use only Custom Attributes. | ||
+ | |||
+ | ===== Alias names ===== | ||
+ | |||
+ | Alias names in Service-types have only local significance. They do not exists outside the running Service-type. So they can have any name you like and nothing will prevent you. | ||
+ | |||
+ | However it is recommended to adopt a naming convention that will be used by all designers creating Service-types. Especially with longer Service-types, | ||
+ | |||
+ | For this reason, we recommend to enclose alias names between carets (‘<‘ and ‘> | ||
+ | |||
+ | Another recommendation is the inclusion of the ’Type’ of the alias. It is not needed since NetYCE knows and checks the type of each alias during the syntactical check before the Service-type starts, but it can greatly improve the readability of your Service-type. | ||
+ | |||
+ | Aliases like < | ||
+ | |||
+ | Especially when linking up nodes with multiple ports and portchannels is a naming convention essential. For example linking up two core nodes with dual links and a portchannel could require these aliases: | ||
+ | |||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | </ | ||
+ | |||
+ | Or an access switch linking up to a redundant set of core switches: | ||
+ | |||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | </ | ||
+ | |||
+ | The following list of alias types could be useful: | ||
+ | |||
+ | < | ||
+ | client - client (customer) | ||
+ | sit - site (location) | ||
+ | srv - service (container) | ||
+ | node - node (device) | ||
+ | dom - domain (management) | ||
+ | port - port (interface) | ||
+ | ports - ports (set of interfaces) | ||
+ | link - topology (2 ports) | ||
+ | slot - module (interfaces using slotid) | ||
+ | srv - server | ||
+ | super - supernet | ||
+ | net - ipv4 subnet | ||
+ | addr - ipv4 address | ||
+ | v6net - ipv6 subnet | ||
+ | v6addr - ipv6 address | ||
+ | vpn - mpls-vrf | ||
+ | vrf - vrf | ||
+ | </ | ||
+ | |||