1
0
mirror of https://github.com/oceanprotocol/docs.git synced 2024-11-26 19:49:26 +01:00
docs/infrastructure/setup-server.md

7.6 KiB

description
The following tutorial shows how to create a server ready for hosting Ocean Protocol's components.

Setup a Server

Now that you know the components of the Ocean Protocol stack and what each does, it's time to learn how to deploy these components in your environment. There are many ways in which the components can be deployed, from simple configurations used for development and testing to complex configurations, used for production systems.

All the Ocean Protocol components (Provider, Aquarius, Subgraph) are designed to run in Docker containers, on a Linux operating system. For simple configurations, we rely on Docker Engine and Docker Compose products to deploy and run our components, while for complex configurations we use Kubernetes with Docker Engine.

Each deployment starts with setting up a server on which the component will be installed, either on-premise or hosted in a cloud platform.

Prerequisites

For simple configurations:

For complex configurations:

  • Operating System: Linux distribution supported by Kubernetes and Docker Engine. Please refer to this link for details: Kubernetes with Docker Engine.

Server Size

The required CPU and memory for the server depend on the number of requests the component is expected to serve, however, the minimum configuration of the server is:

  • 1 core
  • 1 GB RAM

Steps

The steps for setting up a server on which to deploy the Ocean components are the following:

For simple configurations:

  1. Install the operating system
  2. Install Docker Engine and Docker Compose

For complex configurations:

  1. Install the operating system
  2. Install Kubernetes with Docker Engine

Install the operating system

As mentioned earlier, you can use either an on-premise server or one hosted in the cloud (AWS, Azure, Digitalocean, etc.). To install the operating system on an on-premise server, please refer to the installation documentation of the operating system.

If you choose to use a server hosted in the cloud, you need to create the server using the user interface provided by the cloud platform. Following is an example of how to create a server in Digitalocean.

Example: Creating an Ubuntu Linux server in the Digitalocean cloud

  1. Creating account and setting billing

Go to https://www.digitalocean.com/ and create an account. Provide the appropriate information for billing and accounting.

  1. Create a server

Click on Create button and choose Droplets options from dropdown.

Select Droplet

  1. Select a server configuration

Select Ubuntu OS, and choose a plan and a configuration.

Configure the server

  1. Select the region and set the root password

Select the region where you want the component to be hosted and a root password.

Select the region and set the root password

  1. Finish the configuration and create the server

Specify a hostname for the server, specify the project to which you assign the server and then click on Create Droplet.

Finalize and create the server

  1. Access the server's console

After the server is ready, select the Access console option from the dropdown list to open a terminal window.

Access the server's console

Install Docker Engine and Docker Compose

From the terminal window, run the following commands to install Docker and Docker Compose.

sudo apt-get update
sudo apt-get install ca-certificates curl gnupg lsb-release
sudo mkdir -p /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg
echo \
  "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu \
  $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-compose-plugin

# Now install docker-compose
sudo apt-get update
sudo apt-get install docker-compose-plugin

Install Kubernetes with Docker Engine

Kubernetes is an orchestration engine for containerized applications and the initial setup is dependent on the platform on which it is deployed - presenting how this product must be installed and configured is outside the scope of this document.

For cloud deployment, most of the cloud providers have dedicated turnkey solutions for Kubernetes. A comprehensive list of such cloud providers in presented here.

For an on-premise deployment of Kubernetes, please refer to this link.

Now that the execution environment is prepared and the prerequisites installed, we can proceed to deploy the Ocean's components.

<< test Mermaid mindmap >>

mindmap
root(ddo)
  @context
  id
  version
  chainID
  NFTaddress
  metadata
    created
    updated
    description
    copyrightHolder
    name
    type
    author
    license
    links
    contentLanguage
    tags
    categories
    additionalInformation
    algorithm
      algorithmMedatada
        language
        version
        consumerParameters
        container
          entrypoint
          image
          tag
          checksum
  services
  credentials

<< test Mermaid Entity Relationship Diagram >>

erDiagram
DDO ||--|{ Metadata : contains
DDO ||--|{ Services : contains
Metadata ||--|{ AlgorithmMetadata : contains
AlgorithmMetadata ||--|{ Container : contains
    DDO {
        arrayOfString context
        string id
        string version
        number chainID
        string nftAddress 
        Metadata metadata
        Services services
        Credentials credentials       
}
    Metadata {
        ISODateTimeString created
        ISODateTimeString updated
        string description
        string copyrightHolder
        string name
        string type
        string author
        string license
        arrayOfString links
        string contentLanguage
        arrayOfString tags
        arrayOfStrings categories
        Object additionalInformation
        AlgorithmMetadata algorithm
}

AlgorithmMetadata {
    string language
    string version
    ConsumerParameters consumerParameters
    Container container
}

Container {
string entrypoint
string image
string tag
string checksum
}

Services {
string id
string type
string name
string description
string datatokenAddress
string serviceEndpoint
Files files
number timeout
Compute compute
ConsumerParameters consumerParameters
Object additionalInformation
}