Marketplace+
Overview
The Fluence marketplace is a blockchain-based matcher of offers provided by data center operators (Providers) interested in monetizing their resources and offers put forward by developers looking for compute capacity to host and execute their serverless functions. Matching is based on attribute parameters provided by both providers and developer offers, respectively, where offer attributes include but are not limited to (escrowed) willingness to pay and accept and duration of capacity commitment. See link to finalized deal sol. Both Provider and Developer Offers are on-chain commitments which, upon matching, result in a contract called a Deal that governs the compute capacity provisioning and compensation over the agreed upon period of time between a developer and one or more providers. See Figure 1.
Figure 1: Stylized On-Chain Deal Generation From Offer Commitments mermaid
stateDiagram Provider_1 --> Contract: register offer Provider_2 --> Contract: register offer Provider_k --> Contract: register offer Developer_1 --> Contract: register offer Developer_2 --> Contract: register offer Developer_m --> Contract: register offer Contract --> ContractMatcher ContractMatcher --> Deal_1: Provider_1, Provider_2, Developer_2 ContractMatcher --> Deal_2: Provider_1, Provider_3, Developer_M ContractMatcher --> Deal_n: Provider_3, Developer_1
stateDiagram Provider_1 --> Contract: register offer Provider_2 --> Contract: register offer Provider_k --> Contract: register offer Developer_1 --> Contract: register offer Developer_2 --> Contract: register offer Developer_m --> Contract: register offer Contract --> ContractMatcher ContractMatcher --> Deal_1: Provider_1, Provider_2, Developer_2 ContractMatcher --> Deal_2: Provider_1, Provider_3, Developer_M ContractMatcher --> Deal_n: Provider_3, Developer_1
The remainder of this chapter presents developers with the core concepts of the capacity supply side and then dives into the processes developers need to follow to construct deals that reflect their compute, availability and budget requirements.
Capacity Units And Capacity Compensation
Capacity providers (Providers) agree to operate protocol-compliant Fluence peers on servers with specific CPU and RAM capacity that is provable and verifiable on-chain with Fluence's Proof of Capacity protocol. Moreover, provider capacity is denominated, addressed and staked in terms of capacity units (CU) where one (1) CU is one core, two threads and four (4) GB of RAM. The Fluence peer allows providers to dynamically re-allocate CUs from the capacity commitment prover (CCP) to a worker and vice versa. Capacity allocated to deployment no longer produces proofs of capacity (PoC) and no longer generates commitment rewards. Instead, these resources now generate Deal rewards for the provider. See Figure 2.
Figure 2: Overview Of Verifiable Provider Capacity And Compute Units mermaid
stateDiagram Provider --> DataCenter_1 Provider --> DataCenter_2 Provider --> DataCenter_k DataCenter_1 --> Server_1: Nox 1 DataCenter_1 --> Server_2: Nox 2 DataCenter_1 --> Server_k: Nox k Server_k --> CU_1: Stake on Core 1 + RAM Server_k --> CU_2: Stake on Core 2 + RAM Server_k --> CU_k: Stake on Core k + RAM Server_k --> CU_64: Stake on Core 64 + RAM Deal --> Worker: USDC payment state if_state <<choice>> CU_k --> if_state if_state --> Worker: Host developer artifacts if Deal in place if_state --> PoC: Execute Proof of Capacity otherwise CommitmentRewards --> PoC: FLT payment
stateDiagram Provider --> DataCenter_1 Provider --> DataCenter_2 Provider --> DataCenter_k DataCenter_1 --> Server_1: Nox 1 DataCenter_1 --> Server_2: Nox 2 DataCenter_1 --> Server_k: Nox k Server_k --> CU_1: Stake on Core 1 + RAM Server_k --> CU_2: Stake on Core 2 + RAM Server_k --> CU_k: Stake on Core k + RAM Server_k --> CU_64: Stake on Core 64 + RAM Deal --> Worker: USDC payment state if_state <<choice>> CU_k --> if_state if_state --> Worker: Host developer artifacts if Deal in place if_state --> PoC: Execute Proof of Capacity otherwise CommitmentRewards --> PoC: FLT payment
TODO: Clean up/Expand
See Capacity Commitment Protocol for a detailed presentation.
Providers monetize CUs not utilized by developer request by computing Proofs of Capacity which result in capacity rewards. This allows the network to always have readily available capacity to server developer demands.
Deals are imperative not only their capacity to provide escrowed developer funds for provider billing but also to "seed" a very specific Fluence subnetwork with the necessary network and duration parameters.
The takeaway from this short review for developers is that
- providers commit compute capacity that is verifiable on-chain
- capacity commitments are provided in form of specific compute units (CU) defined by one core and 4GiB of RAM
- for CUs to be discoverable for matching with developer offers, each CU requires (delegated) stake and additional offer attributes including CU price per epoch committed to the Fluence IPC blockchain
- these on-chain commitments result in provider offers eligible for matching with developer offers on a per CU basis
- the capacity provided through the Fluence marketplace is indeed decentralized hardware
- deals not only are the basis for settlement between developers and providers but also hold the parameters needed to create a subnet, i.e., the off-chain network overlay connecting CUs hosting developer artifacts across peers and providers
Deploying On DePin
Decentralized physical infrastructure (DePin) is the "critical first mile" to make decentralized solutions a reality. There is little point devising and implementing decentralized protocols when the resulting peers or nodes are deployed on centralized infrastructure such as AWS EC2, for example. That is, decentralized middleware and applications need to execute on decentralized infrastructure in order to be able to live up to their namesake.
DePin, as explained by Technopedia is a peer-to-peer network that meets hardware demand through and open and decentralized marketplace. While brief, the above sections should make it clear that staked, verifiable capacity committed to the on-chain marketplace is in fact DePin allowing Fluence developers to build their decentralized serverless compute applications on DePin: decentralization without compromise from the bottom up!
From Deployment Plans to Deployment And Payments
The Fluence platform gives you, the developer, a fairly fine-grained approach toward managing your decentralized applications especially with respect to availability. For example, if you require your application to be highly available across different geographies and data centers, you can specify these requirements in your deployment plan and deploy your compute function(s) to the desired number of peers with the desired providers. Of course, high availability comes at a price.
So, you have compiled your business logic to Wasm, have done all your testing and are ready to deploy your code to the peers for hosting and on-demand execution.
TODO:
- peer selection: provider, number and impact on HA and costs
- deployment plan specification
- deployment plan implementation: CLI
Currently, function pricing is based on an epoch model. That is, regardless of your function requests, you will be charged a fixed amount per time period per worker, i.e., epoch. The epoch model is a stopgap measure for FLuence to roll-out and test its mainnet and will be replaced shortly with a request based pricing model common to serverless compute.