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

Merge pull request #1054 from oceanprotocol/issue-1041-hosting-provider

Hosting provider
This commit is contained in:
Akshay 2022-07-26 11:06:23 +02:00 committed by GitHub
commit c3eb65e459
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 84 additions and 0 deletions

View File

@ -29,11 +29,15 @@
* [Deploying components](building-with-ocean/deploying-components/README.md)
* [Deploying Marketplace](building-with-ocean/deploying-components/deploying-marketplace.md)
* [Deploying Aquarius](building-with-ocean/deploying-components/deploying-aquarius.md)
<<<<<<< HEAD
* [Deploying Provider](building-with-ocean/deploying-components/deploying-provider.md)
=======
* [Contributing](core-concepts/contributing.md)
* [Contributor Code of Conduct](core-concepts/code-of-conduct.md)
* [Legal Requirements when Contributing Code](core-concepts/legal-reqs.md)
* [Reporting Vulnerabilities](core-concepts/vulnerabilities.md)
* [Funding](core-concepts/get-funding.md)
>>>>>>> d687b4e2d8782db2ea7e3e61fa15e9608451e78d
* [Projects using Ocean Protocol](building-with-ocean/projects-using-ocean.md)
* [API references](api-references/README.md)
* [Aquarius REST API](api-references/aquarius-rest-api.md)

View File

@ -0,0 +1,80 @@
# Deploying Provider
### About Provider
Provider encrypts the URL and metadata during publish and decrypts the URL when the dataset is downloaded or a compute job is started. It enables the access to data assets by streaming data (and never the URL). It performs checks on chain for buyer permissions and payments. It also Provides compute services (connects to C2D environment).
The source code of Provider can be access from [here](https://github.com/oceanprotocol/provider).
### Prerequisites
* Docker and Docker compose are installed. Click [here](https://docs.docker.com/engine/install/) to view guide on installing docker.
* Ethereum API.
See [this](../obtaining-api-key.md) guide on obtaining api key.
### Create a working directory
```
mkdir Provider
cd Provider
```
### Create a \`.env\` file
Copy the below content into the \`.env\` file and edit the values as needed.
{% code title=".env" %}
```
# Mandatory variables
# Update the value to the appropriate tag from here: https://hub.docker.com/r/oceanprotocol/provider-py/tags
PROVIDER_VERSION=latest
PROVIDER_PRIVATE_KEY=<private-key>
NETWORK_URL=<api-key>
AQUARIUS_URL=<aquarius-url>
```
{% endcode %}
### Create docker-compose file
{% code title="docker-compose.provider.yml" %}
```yaml
version: '3'
services:
provider:
image: oceanprotocol/provider-py:v1.0.20
container_name: provider
ports:
- 8030:8030
networks:
- ocean_backend
environment:
NETWORK_URL: ${NETWORK_URL}
PROVIDER_PRIVATE_KEY: ${PROVIDER_PRIVATE_KEY}
LOG_LEVEL: DEBUG
OCEAN_PROVIDER_URL: "http://0.0.0.0:8030"
OCEAN_PROVIDER_WORKERS: "1"
OCEAN_PROVIDER_TIMEOUT: "9000"
# Defining OPERATOR_SERVICE_URL is optional. Set the value only if Provider should support Compute-to-data.
OPERATOR_SERVICE_URL: "<operator-service-url>"
# Defining IPFS_GATEWAY is optional. Set the value if Provider should support resolving IPFS urls.
IPFS_GATEWAY: "<ipfs-url>"
AQUARIUS_URL: ${AQUARIUS_URL}
volumes:
data:
driver: local
networks:
ocean_backend:
driver: bridge
```
{% endcode %}
### Start Provider
```
docker-compose \
-f docker-compose.provider.yml
--env-file .env \
-d \
up
```