Skip to content

Latest commit

 

History

History
130 lines (87 loc) · 7.54 KB

README.md

File metadata and controls

130 lines (87 loc) · 7.54 KB

Manifesto

image

Version 0.1.0 (see tags)
Prepared-By VS
Status Draft
Latest-Version DOI

Purpose of ODA

Multi-Messenge Online Data Analysis (MMODA, or sometimes ODA for brevity) is collection of interfaces, adapters, and tools to leverage existing data analysis workflows and workflow management platforms.

Fit-for-purpose and community-driven

We focus on features motivated directly by involved projects. Original development was supported by mutualization efforts of UNIGE but since then ODA evolved into a collective multi-instutute multi-project effort.

Open Data = Interoperability Frameworks + Open Policies

Open data does not just mean the data which can be freely downloaded. The data needs to be comprehensively described, in order to make re-use posssble. This can be achived with interoperability frameworks.

On the hand, interoperability alone does not guaratnee free and attribution-respecing reuse towards goals of the scientific commons. Sharing should be governed with *open policies.

Attribution for Data And Software: Provencance

The core platform itself contain very few (if any) additions to scientific data analysis workflows. In all cases, these workflows are provided by the experts, and our role is to facilitate the contributions, and make access to the live workflows as well as the workflow results easiers for the users.

It is vital to recognize that ODA services are not themselves providing the data. We attach Data and Software Provenance to the produced results in order to clearly recognize the collective effort, supported by a varienty of institutions and individuals.

Right To Replicate

Since we provide Software as a Service, users may be in danger of locking-in the platform and depending on our continious support. While this situation could benefitial for us (and is indeed major part of business model of some top services), we consider this kind of behavior immoral, and make effort to allow full deployment of the platform in alternative locations.

In principle, it should be always possible to move the platform elsewhere, respecting the right to replicate

We provide full open software and data, and following the best we can good design practices for cloud-based deployment. But we can not make unreasonable effort to assist every alternative deployment.

We can not be responsible for any damage caused by the unsafe deployments (as described in detail in the licences).

Multi-site ODA federation

Maintaining capacity to replicate allows us to deploy multiple sites. There are currently three publicly-facing sites:

Co-existence of these sites is based on the following principles:

  • Every frontend, dispatcher, instrument plugin and backend is equally deployable at any site.
  • Different sites may have favorable access to some data, enabling some special requests.
    • E.g. UNIGE site has access to realtime INTEGRAL data.
  • Sites also send requests to each other. For example, INTEGRAL SPI-ACS plugin in APC forwards requests to near-realtime data at UNIGE.
  • Some requests lead to identical results in different places, ensuring redundancy.
  • Discovery of sites is facilitated by linked data mechanisms, building distributed knowledge Graph.

Discovery of services may be facilitated by EOSC Portal.

Diverse Analysis Platforms and Federation

As the need to develop web-based Scientific Data Center services got more and more broadly recognized, multiple independent projects developed a number of different platforms. Even without our scope of activity, we are directly or indirectly involved in the following projects:

  • MMODA platform by AstroORDAS project
  • Galaxy platform and EuroScienceGateway project
  • DACE platform and project
  • Renku platform by SDSC
  • DataLabs platform by ESA

Many other similar projects and platforms exist. Some platforms have wide variety of features while others focus on particular aspects. We identify the following common patterns and features a platform has:

  • UI
    • customized browser UI for performing data analysis tasks, with UI elements for input and visualization
    • interactive jupyter environment
    • command line enviroment
    • http API
  • catalog of data analysis tools and workflows
    • MMODA workflow catalog (gitlab with optional KG)
    • galaxy toolsched
    • workflowhub
  • means to discover and stage data stored in data archives
    • archive interfaces, e.g. IVOA
    • tools to orchestrate data transfers, like rucio
  • means to make use of large computing clusters
    • computing resource interfaces like ARC, UWS

We find that some degree of plurality in the platforms landscape does not lead to divergence of efforts but can be a strength of this ecosystem, if platform architecure respects principles of design interoperability.

  • For example, Jupyter (and often jupyterhub) is almost a must-have component in all of these platforms as it is explicitly made with the idea of reusable software.
  • Another case, AladinLite, is a UI element for astrophysical images which is currently de-factor standard in web-based astronomical platforms.
  • Data Models and ontologies deriving from Linked Data (e.g. JSON-LD) are used in a wide range of platforms to label assets (data, code, etc).

Requirements for deployment

  • A kubernetes cluster, API > v1.23
    • CSI with ReadWriteMany persistent volumes

Base platform: frontend and dispatcher

  • 5 CPU, 10 Gb RAM, 50Gb persistent storage

Contributed notebook backends

Per typical backend, but may depend strongly on the backend:

  • 2 CPU, 10 Gb RAM, 10Gb persistent storage

INTEGRAL backend

  • on kubernetes cluster:
    • 4 CPU, 10 Gb RAM, 100Gb persistent storage
  • HPC cluster, e.g. slurm scheduler, and service account (possibly serveral)
    • typical capacity 100 jobs to run at the same time
    • egress from the HPC cluster to kubernetes cluster
    • shared storage for intermediate results, 20 Tb
  • INTEGRAL archive which can be:
    • mounted in k8s pods, e.g. with NFS
    • accessing on the HPC cluster