Skip to content
/ rankd Public

Resource allocation protocol that allow services to reserve resources in a path towards a listener with requirements for computing, network, and time resources.

Notifications You must be signed in to change notification settings

nap-it/rankd

Repository files navigation

Rankd

Rank deamon (Rankd) is an implementation of a service to retrieve information on a machine where a server instance is being ran. Such information ranges from kernel data to userspace applications being used and network capabilities.

This service has the goal to rank a machine against others, in order to allow the creation and allocation of proper paths (path reservation) after a capability negotiation, as required for a certain task to be performed under a given latency- and jitter-strict usage.

Features

  • Resource Types: The protocol supports various resource types, including computational resources (CPU, memory, storage, sensors), network resources (bandwidth, latency, packet loss, technology), and timing resources (synchronization, latency bounds, jitter).
  • Negotiation Mechanisms: Machines engage in negotiation processes to reach resource allocation agreements. Different negotiation models, such as auctions, bargaining, or iterative bidding, can be implemented.
  • Flexible Communication: Machines communicate with each other using a defined message format, exchanging information about capabilities, requirements, bids, and allocation decisions.
  • Decision-Making Algorithms: The protocol incorporates decision-making algorithms to evaluate bids and determine optimal resource allocations. These algorithms consider resource parameters, fairness, efficiency, and potential trade-offs between different resource types.
  • Security and Privacy: The protocol includes security measures to protect the integrity, confidentiality, and privacy of the negotiation process. Authentication, encryption, and access control mechanisms can be implemented.

Getting Started with Rankd

Rankd (to be pronounced rank-ed) while it is being developed, has a first goal to allow clients to retrieve status data from a server instance. Almost like a network management agent (such as an SNMP agent), a Rankd machine can give information about their kernel (such as version, operative system, processor precision and family, among others), and about their userspace items (such as applications being ran, by genre, or even some network capabilities).

As this is still under development, currently there is no release available, but it is expected to launch a version soon enough to be used in a set of equipments of Aveiro City Living Lab's infrastructure, in order to be able to coordinate maintenance actions with no further ado.

Current Development Status

Rankd is still a work in progress, as part of Rui Lopes' PhD work in the scope of Time-sensitive and emergency networks. It is divided onto four main components: a computing resources gatherer (rankd-comp), a time resources gatherer (rankd-time), a network resources gatherer (rankd-net) which is to be tied with the yanp-it project, and a negotiator (negotiator). Below there is the current status of each one of these components.

Tool Currently available
rankd-comp CPU, Memory, Storage, Sensors, and OS metrics
rankd-time PTP current metrics (linuxptp)
rankd-net YANP-it (for iPerf and NCM)
negotiator Nothing yet

Running Rankd

In order to run this project you simply have to run the compiled executable called rankd and, if everything runs well, you should receive a feedback on a server waiting for requests in the port 7265 (T9-code for r-a-n-k).

About

Resource allocation protocol that allow services to reserve resources in a path towards a listener with requirements for computing, network, and time resources.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published