David Adams ATLAS Architecture for ATLAS Distributed Analysis David Adams BNL March 25, 2004 ATLAS Distributed Analysis Meeting.

Slides:



Advertisements
Similar presentations
Database System Concepts and Architecture
Advertisements

Apache Struts Technology
6/4/20151 Introduction LHCb experiment. LHCb experiment. Common schema of the LHCb computing organisation. Common schema of the LHCb computing organisation.
David Adams ATLAS DIAL Distributed Interactive Analysis of Large datasets David Adams BNL March 25, 2003 CHEP 2003 Data Analysis Environment and Visualization.
David Adams ATLAS DIAL Distributed Interactive Analysis of Large datasets David Adams BNL June 23, 2003 GAE workshop Caltech.
WebDynpro for ABAP Short introduction.
QCDgrid Technology James Perry, George Beckett, Lorna Smith EPCC, The University Of Edinburgh.
FALL 2005CSI 4118 – UNIVERSITY OF OTTAWA1 Part 4 Web technologies: HTTP, CGI, PHP,Java applets)
Database System Development Lifecycle © Pearson Education Limited 1995, 2005.
Aurora: A Conceptual Model for Web-content Adaptation to Support the Universal Accessibility of Web-based Services Anita W. Huang, Neel Sundaresan Presented.
ARGONNE  CHICAGO Ian Foster Discussion Points l Maintaining the right balance between research and development l Maintaining focus vs. accepting broader.
David Adams ATLAS DIAL Distributed Interactive Analysis of Large datasets David Adams BNL July 15, 2003 LCG Analysis RTAG CERN.
David Adams ATLAS ATLAS Distributed Analysis David Adams BNL March 18, 2004 ATLAS Software Workshop Grid session.
K. Harrison CERN, 20th April 2004 AJDL interface and LCG submission - Overview of AJDL - Using AJDL from Python - LCG submission.
INFSO-RI Enabling Grids for E-sciencE Logging and Bookkeeping and Job Provenance Services Ludek Matyska (CESNET) on behalf of the.
David Adams ATLAS AJDL: Analysis Job Description Language David Adams BNL December 15, 2003 PPDG Collaboration Meeting LBL.
ATLAS DIAL: Distributed Interactive Analysis of Large Datasets David Adams – BNL September 16, 2005 DOSAR meeting.
David Adams ATLAS DIAL status David Adams BNL July 16, 2003 ATLAS GRID meeting CERN.
David Adams ATLAS ATLAS Distributed Analysis Plans David Adams BNL December 2, 2003 ATLAS software workshop CERN.
1 Schema Registries Steven Hughes, Lou Reich, Dan Crichton NASA 21 October 2015.
Event Data History David Adams BNL Atlas Software Week December 2001.
Datasets on the GRID David Adams PPDG All Hands Meeting Catalogs and Datasets session June 11, 2003 BNL.
Shannon Hastings Multiscale Computing Laboratory Department of Biomedical Informatics.
David Adams ATLAS ADA, ARDA and PPDG David Adams BNL June 28, 2004 PPDG Collaboration Meeting Williams Bay, Wisconsin.
Tool Integration with Data and Computation Grid GWE - “Grid Wizard Enterprise”
INFSO-RI Enabling Grids for E-sciencE ATLAS Distributed Analysis A. Zalite / PNPI.
David Adams ATLAS DIAL status David Adams BNL November 21, 2002 ATLAS software meeting GRID session.
Metadata Mòrag Burgon-Lyon University of Glasgow.
David Adams ATLAS DIAL/ADA JDL and catalogs David Adams BNL December 4, 2003 ATLAS software workshop Production session CERN.
The EDGeS project receives Community research funding 1 Porting Applications to the EDGeS Infrastructure A comparison of the available methods, APIs, and.
ATLAS is a general-purpose particle physics experiment which will study topics including the origin of mass, the processes that allowed an excess of matter.
David Adams ATLAS ADA: ATLAS Distributed Analysis David Adams BNL June 7, 2004 BNL Technology Meeting.
GDB Meeting - 10 June 2003 ATLAS Offline Software David R. Quarrie Lawrence Berkeley National Laboratory
David Adams ATLAS Virtual Data in ATLAS David Adams BNL May 5, 2002 US ATLAS core/grid software meeting.
David Adams ATLAS ATLAS Distributed Analysis David Adams BNL September 30, 2004 CHEP2004 Track 5: Distributed Computing Systems and Experiences.
DGC Paris WP2 Summary of Discussions and Plans Peter Z. Kunszt And the WP2 team.
D. Adams, D. Liko, K...Harrison, C. L. Tan ATLAS ATLAS Distributed Analysis: Current roadmap David Adams – DIAL/PPDG/BNL Dietrich Liko – ARDA/EGEE/CERN.
David Adams ATLAS DIAL: Distributed Interactive Analysis of Large datasets David Adams BNL August 5, 2002 BNL OMEGA talk.
INFSO-RI Enabling Grids for E-sciencE Ganga 4 – The Ganga Evolution Andrew Maier.
INFSO-RI Enabling Grids for E-sciencE ARDA Experiment Dashboard Ricardo Rocha (ARDA – CERN) on behalf of the Dashboard Team.
G.Govi CERN/IT-DB 1 September 26, 2003 POOL Integration, Testing and Release Procedure Integration  Packages structure  External dependencies  Configuration.
David Adams ATLAS DIAL Distributed Interactive Analysis of Large datasets David Adams BNL November 17, 2003 SC2003 Phoenix.
K. Harrison CERN, 3rd March 2004 GANGA CONTRIBUTIONS TO ADA RELEASE IN MAY - Outline of Ganga project - Python support for AJDL - LCG analysis service.
David Adams ATLAS ATLAS distributed data management David Adams BNL February 22, 2005 Database working group ATLAS software workshop.
LCG Distributed Databases Deployment – Kickoff Workshop Dec Database Lookup Service Kuba Zajączkowski Chi-Wei Wang.
Tool Integration with Data and Computation Grid “Grid Wizard 2”
K. Harrison CERN, 22nd September 2004 GANGA: ADA USER INTERFACE - Ganga release status - Job-Options Editor - Python support for AJDL - Job Builder - Python.
David Adams ATLAS ATLAS Distributed Analysis: Overview David Adams BNL December 8, 2004 Distributed Analysis working group ATLAS software workshop.
David Adams ATLAS ATLAS-ARDA strategy and priorities David Adams BNL October 21, 2004 ARDA Workshop.
ATLAS-specific functionality in Ganga - Requirements for distributed analysis - ATLAS considerations - DIAL submission from Ganga - Graphical interfaces.
D. Duellmann - IT/DB LCG - POOL Project1 The LCG Dictionary and POOL Dirk Duellmann.
David Adams ATLAS Datasets for the Grid and for ATLAS David Adams BNL September 24, 2003 ATLAS Software Workshop Database Session CERN.
INFSO-RI Enabling Grids for E-sciencE Using of GANGA interface for Athena applications A. Zalite / PNPI.
1 A Scalable Distributed Data Management System for ATLAS David Cameron CERN CHEP 2006 Mumbai, India.
ATLAS Distributed Analysis Dietrich Liko IT/GD. Overview  Some problems trying to analyze Rome data on the grid Basics Metadata Data  Activities AMI.
David Adams ATLAS ATLAS Distributed Analysis (ADA) David Adams BNL December 5, 2003 ATLAS software workshop CERN.
David Adams ATLAS ATLAS Distributed Analysis and proposal for ATLAS-LHCb system David Adams BNL March 22, 2004 ATLAS-LHCb-GANGA Meeting.
INFSO-RI Enabling Grids for E-sciencE Ganga 4 Technical Overview Jakub T. Moscicki, CERN.
ATLAS Distributed Analysis DISTRIBUTED ANALYSIS JOBS WITH THE ATLAS PRODUCTION SYSTEM S. González D. Liko
David Adams ATLAS AJDL: Abstract Job Description Language David Adams BNL June 29, 2004 PPDG Collaboration Meeting Williams Bay.
David Adams ATLAS ADA: ATLAS Distributed Analysis David Adams BNL December 15, 2003 PPDG Collaboration Meeting LBL.
Ganga/Dirac Data Management meeting October 2003 Gennady Kuznetsov Production Manager Tools and Ganga (New Architecture)
Seven things you should know about Ganga K. Harrison (University of Cambridge) Distributed Analysis Tutorial ATLAS Software & Computing Workshop, CERN,
The EPIKH Project (Exchange Programme to advance e-Infrastructure Know-How) gLite Grid Introduction Salma Saber Electronic.
David Adams ATLAS DIAL Distributed Interactive Analysis of Large datasets David Adams BNL May 19, 2003 BNL Technology Meeting.
(on behalf of the POOL team)
POOL persistency framework for LHC
Dirk Düllmann CERN Openlab storage workshop 17th March 2003
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 2 Database System Concepts and Architecture.
Presentation transcript:

David Adams ATLAS Architecture for ATLAS Distributed Analysis David Adams BNL March 25, 2004 ATLAS Distributed Analysis Meeting

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Contents Scope Model Job-based AJDL Application Task Dataset Job High-level services Analysis service Job management service Catalog services Implementation Strategy Effort providers ARDA Role of GANGA Connection to LHCb More information

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Scope Analysis (not necessarily distributed) Supports the manipulation and extraction of summary data (e.g. histograms) from any type of event data –AOD, ESD, … Supports user-level production of event data –e.g. MC generation, simulation and reconstruction Distributed analysis Extends the extraction and production support to include distributed users, data and processing. Natural extension of non-distributed analysis Easily invoked from any ATLAS analysis environment –including Python, ROOT, command line –easily ported to any future environment (e.g. JAS)

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Model ADA model has the following features Job-based Client-service Architecture Generic interface Extensible interface Components Virtual data Provenance

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Model: Job-based Adopt a job-based model for distributed processing User provides a high-level description of a task to be carried out –Typically a “transformation” and an input dataset Processing system splits jobs, submits and tracks sub- jobs and gathers and merges results User may also provide suggestions or directives about how to do processing –Where place output data –Mechanisms for splitting and merging

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Model: Clients and services Separate clients from services Client should be lightweight and portable Services implemented as web services –Service can be more robust and have a longer lifetime –Does not preclude service from running on the client side –Or even accessing python-based services as plug-ins Services and clients to be developed independently

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Model: Architecture

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Model: Generic interface Define a generic high-level interface Processing system can be constructed using only this interface –Effort to develop and maintain processing systems can and should be shared >Difficult to make a robust and responsive processing system Same comment for user interfaces ATLAS can try out different processing systems but present the same user interface –Production, DIAL, ARDA, other experiments, future developments

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Model: Extensible interface Interface must be extensible Which application used to process data –Athena, atlsim, root, non-atlas, … Different means to install applications Means for user to configure application for a job Different kinds of data –Application- and user-specific access to data

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Model: Components Identify the fundamental concepts Express high-level interface in terms of these components Components: Dataset –Collection of data –Often but not always files Transformation –Specifies means for transforming an input dataset into an output dataset –Application + Task Job –Tracks the transformation of a dataset in processing system

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Model: Virtual data Virtual dataset Prescription to create dataset = transformation + dataset May be multiple concrete representations –Created in separate jobs –Different files sizes –Data in DB vs. file –Copy selected events from a dataset User typically selects a virtual dataset –Selection based on dataset metadata –Processing system chooses best (e.g. nearest) concrete representation –Or starts job to (re)create

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Model: Provenance System should record provenance of any registered dataset Virtual dataset: input dataset + transformation –In VDC = virtual data catalog Concrete dataset: add processing details –Description of job producing dataset ># sub-jobs >Processing nodes >Times >Etc, etc, … –In job catalog

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, AJDL Acronym: Analysis Job Definition Language Type names label the different kinds of components Subtypes extend types E.g. Dataset : EventDataset : EventCollectionDataset Base “data” types include: Application – executable to process data Task – user configuration of application Dataset – describes input and output data Job – Activity to perform on (or off) the grid –Typical: app, task and input dataset  output dataset Following is usual interaction diagram

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Analysis Framework Job 1 Job 2 ApplicationTask Dataset 1 Analysis Service 1. L ocate 2. select3. Create or select 4. select 5. submit(app,tsk,ds) 6. split Dataset Dataset 2 7. create e.g. ROOT e.g. athena Result 9. create 10. gather Result 9. create exe, pkgsscripts, code ADA/DIAL user interface

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, AJDL: Application Application specifies executable used to process data Two entry points Extract and build task Process input dataset to produce output dataset –Application + Task = Dataset transformation Carries enough information to Locate entry points –Or carry the corresponding scripts Enable installation of all required software –E.g. list of packages for use with package management system –Might be subtypes for different package management systems

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, AJDL: Task Task carries the user configuration for an application E.g. runtime configuration or code for shared library Nature of the task specified by the corresponding application At present the task is a collection of embedded text files Task plus application (transformation) should specify the content of input and output datasets Enable users and processing system to –Verify transformation is suitable for given input dataset –Avoid staging unneeded parts of input dataset –Predict the content of output dataset

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, AJDL: Dataset Provides data view Generic properties for use in high-level services: Location of data (files, DB, …) –So data can be staged Content –E.g. for ATLAS events: event ID’s and type-keys (e.g. good electrons) for each event –EventDataset is an important generic subtype Constituents for compound dataset –Natural boundaries for dataset splitting Subtypes provide interface for users and applications to access the data

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, AJDL: Job Interface enables users (and high-level services) to monitor and manage jobs on the grid Generic properties State: running, succeeded, failed, paused, … Input parameters (e.g. application, task and dataset) Result (e.g. output dataset) after completion Management Pause/resume Kill Update status Job management service to implement these

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Nature of AJDL types Nature of components Persistent representation of data –Assume XML –Content specified by DTD or XML schema –AJDL type is XML type Classes (C++, Python, java,…) –Language bindings or re-implementations –These define the API (user interface) –Build tools and GUI on top of these –Class types map to AJDL types –Need methods to write to and create from XML representation Service or resource (as in WSRF)

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, AJDL functions Do we want non-trivial functions associated with AJDL types? Trivial means getters and setters –E.g. EventDataset XML attribute event count maps to >EventDataset::m_event_count >EventDataset::set_event_count() >EventDataset::get_event_count() const –Class headers could be automatically generated from XML DTD/schema or vice versa Yes –Examples follow –Might try to keep generic types trivial

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, AJDL functions (cont) Examples of AJDL functions Creator for EventCollectionDataset opens event collection to read the event count PacmanApplication must call pacman to locate the site- specific entry points for the application Task or Dataset subtype may want to stage files to facilitate local access Job subtype implements method to kill job

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, AJDL functions How to handle multiple languages? Simple functions may be reimplemented Language wrappings may be used in some places –PyLcgDict maps C++ to python Function may be provided by a service Some functions absent in some bindings –E.g. java binding for EventCollectionDataset does not provide access to the C++ POOL event collection interface Cache data in generic classes –Generic EventDataset might hold the event count even though subtypes have means to find this value on demand Handle the problem on case-by-case basis

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, High-level services High-level services use AJDL components Middleware does not Typically high-level services are generic Only use generic properties of AJDL components Same service for different applications and datasets Different experiments or realms can share services –E.g. LHCb and ATLAS Examples Analysis (transformation) service Job management Catalogs

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Analysis service Transformation service might be a better name Provides means to create a concrete dataset Interface functions Request dataset –Input is application, task and dataset –Output is job ID –Associated job carries ID for output dataset Fetch job description –Input is job ID –Output is job

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Analysis service (cont) Example scenario for processing a high-level job Input is application, task, dataset and job configuration Map input virtual dataset to concrete representation Split into sub-datasets Create sub-job for each sub-dataset Stage files for each sub-job Locate and possibly install application Build (e.g. compile) task Run sub-jobs Gather and merge results to create output dataset Register output dataset (including replica) Job provides connection to output dataset and detailed job provenance

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Job management service Provide means to manage jobs Analysis service creating the job provides this May also want this functionality elsewhere Accessed from job interface to implement management functions Might create job service (OGSI) Or job is a resource (WSRF)

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Catalog services Repositories Store AJDL components indexed by ID Selection (metadata) catalogs Help user to select input data, task, … VDC – Virtual Dataset Catalog Prescriptions for creating datasets –Application, task input dataset DRC – Dataset Replica Catalog Mapping between virtual and concrete datasets Job catalog Detailed provenance for concrete datasets

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Implementation strategy Define AJDL Components, nature, interfaces Implement catalogs Tables in AMI Programmatic interface –(C++ with Python binding) Analysis services Start with existing services or analogs –DIAL, ATCOM, Capone, GANGA, … Different implementations for different strategies At least one using ARDA middleware

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Implementation strategy (cont) User interface Programmatic interface to high-level services and AJDL components –C++, python and eventually java bindings GANGA will provide python binding and use it to deliver a GUI –Extensible design: client tools plug into python bus Middleware Whatever works to begin ARDA services will be used in that context –Like to see better integration with other middleware efforts

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Implementation strategy (cont) Web service infrastructure Short term use independent persistent services Mid-term follow ARDA strategy –GAS – grid access service Long term follow standards such as WSRF –Dataset and job become resources? Releases Deliver working prototype in May –Robust enough for average physicist Regular releases adding functionality, improving performance and incorporating new middleware

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, Effort providers Look to the following for effort: GANGA for user interface and more DIAL for interactive analysis service ARDA integration team for ARDA analysis service ARDA/EGEE and US grid projects for middleware POOL for datasets and metadata? SEAL for python-C++ integration –Later java as well? ATLAS physics and computing groups for ATLAS- specific pieces –ATLAS applications and datasets –System testing and evaluation

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, ARDA ARDA begins April 1 Two areas in LCG: Middleware development (1 st report delivered) Integration team ATLAS ARDA prototype Collaboration in context of integration team Deliver at least one analysis service base on ARDA middleware We would also like to collaborate on AJDL and other high-level services –ARDA not interested in short term

David Adams ATLAS Architecture ATLAS Distributed analysisMarch 25, More information ADA home page: This page has links to other projects