Download presentation
Presentation is loading. Please wait.
Published byMeryl Lane Modified over 6 years ago
1
Our Experiences and Analysis of the POOL Storage Manager for Relational Back-ends
By: S.S.Tomar Computer Center CAT, Indore, India On Behalf of CAT-POOL TEAM
2
Topics Of Discussion Introduction The POOL Storage Manager
The two “proof-of-concept” tests RelationalStorageSvc prototype details Storage Manager – Our Feedback from the implementation for Relational back ends Summary Thank You CAT POOL Team
3
Introduction POOL project. POOL, File Catalog. POOL, Storage Manager
Objective -Persistency of Objects for the LHC. The Basic Concept. POOL, File Catalog. Provides unique ID to a Database/File in POOL. PFN, FID & LFN POOL, Storage Manager Provides Interfaces for diverse Storage Technologies. CAT POOL Team
4
(Cont…) Storage option in current version of the POOL.
ROOT (by using RootStorageSvc component) RelationalStorageSvc prototype Storage of Objects in Relational Backends. Proof-of-concept for the POOL Storage Manager. CAT, India’s contribution to the POOL project Back… CAT POOL Team
5
Persistency – What is it?
Transient Persistent C++ pointer => object ID Objects & pointers Objects, object IDs, collections & DBs CAT POOL Team Back…
6
The POOL – Basic Concept
A application may access databases (eg ROOT files) from a set of catalogs Each database has containers of one specific technology (eg ROOT trees) Smart Pointers are used to transparently load objects into a client side cache define object associations across file or technology boundaries Storage Manager Back… CAT POOL Team
7
POOL File Catalog POOL uses GUID implementation for FileID
Logical Naming Object Lookup POOL uses GUID implementation for FileID unique and immutable identifier for a file (generated at create time) allows to produce sets of file with internal references without requiring a central ID allocation service catalog fragments created independently can later be merged without modification to data files. Object lookup is based only on right side box! Logical filenames are supported but not required Back… CAT POOL Team
8
POOL Storage Manager Objectives/Goals. Conceptual Architecture.
Diverse storage Tech. support (Root, RDBMS,…). Manage on-demand use of storage technologies. Rapid adoption of new storage technologies. Conceptual Architecture. POOL Storage Hierarchy. Internal Data Structures in a database/file. Token – The persistent object ID Back… CAT POOL Team
9
POOL Storage Hierarchy
Back… CAT POOL Team
10
Internal Data Structures in a Database
DataBase Context ##Shapes ##Links EntryID LinkID ShapeID pShape ##Params NameValue CAT POOL Team Back…
11
Token – The Persistent Object ID
StorageMgr Cont Token = Tech + DB + Cont_name Full Token = Cont Token + RowID OID = oid.first:oid.second Oid.first => EntryID =>Cont Token Oid.second => RowID Storage type DB name Cont.name Item ID Disk Storage database Database Container Objects CAT POOL Team Back…
12
The Two “Proof-of-concept” tests
Navigation, storage and retrieval of objects with primitive data members. Test2: Navigation, storage and retrieval of objects with referenced data members. CAT POOL Team
13
(Cont…) Test2 : Various Cases:
Case1: Same Technology Same Database Reference Test: Objects in one Technology referencing objects in same technology and same database. Case2: Same Technology Different Database Reference Test: Objects in one Technology referencing objects in same technology but in different database. Case3: Cross Technology Reference Test: Objects in one Technology (RDBMS) referencing objects in Different Technology (ROOT). Back… CAT POOL Team
14
Case1: Same Technology Same Database Reference Test
Cont_1 Cont_2 CAT POOL Team Back…
15
Case2: Same Technology different Database Reference test
Cont_1 Cont_2 CAT POOL Team Back…
16
Case3: Cross Technology Reference Test
Cont_1 Cont_2 Database1 Database2 CAT POOL Team Back…
17
RelationalStorageSvc prototype
RSSvc Introduction. Objectives/Goals. Design Considerations. The Design. Token Dereferencing. Writing/Reading Illustration Back… CAT POOL Team
18
RSSvc’s place in POOL Architecture
CAT POOL Team
19
RSSvc Introduction RelationalStorageSvc has been implemented using a design similar to RootStorageSvc component. A plug-in in POOL framework - for persistency of c++ objects in RDBMS. RDBMS vendor independent (oracle/mysql/sqlserver/…) CAT POOL Team
20
(Cont…) Uses ODBC connectivity option.
Implements POOL StorageSvc interfaces and uses ODBC APIs. Prototype development using RedHat Linux 7.3 as OS. Oracle 9i(9.2.0) as RDBMS. Oracle wire protocol driver from DataDirect. POOL ver 1.2 to for testing Back… CAT POOL Team
21
RSSvc Design Objectives/Goals
Store/Retrieve/Navigate simple C++ objects in RDBMS. Achieve RDBMS vendor independency (as much as possible). Use SEAL dictionary and plugin services for converting transient object to persistent object representation in RDBMS. for implementing the component as a plug-in Back… CAT POOL Team
22
Design Considerations
POOL Database = User schema Every user has a different context in RDBMS. Physical reference to a database to be made using the DSN (data source name) concept of Relational technology. A Class is mapped to a table in database. A data member of a class is mapped to a column in the database table. Member classifiers/qualifiers to be stored along with persistent shape of the class Back… CAT POOL Team
23
The Design File Catalog related Physical file name mapping.
Storage Manager related Data Structures mapping. Primitive data type mapping. Reference data type mapping Back… CAT POOL Team
24
Physical file name mapping
PFN(in file catalog) = DSN:Username:Password E.g PFN = OracleWP2:tomar:catpool refers to database on host oradev9.cern.ch with SID=D9,running on port number 1521 accessible to user tomar using password catpool.For establishing connectivity with the database it uses the odbc driver located at /afs/cern.ch/sw/lcg/app/pool/drivers/odbc/lib/ivora19.so CAT POOL Team
25
Typical DSN entry in ODBC.ini
[OracleWP2] Driver=//afs/cern.ch/sw/lcg/app/pool/drivers/odbc/lib/ivora19.so Description=DataDirect 4.20 Oracle Wire Protocol Hostname=oradev9.cern.ch LogonID=tomar Password=****** PortNumber=1521 SID=D9 CAT POOL Team
26
Typical FileCatalog entries
<File ID="B2B6AA42-E882-D811-8CDF-00D0B7B86B36"> <physical> <pfn filetype="Oracle" name="OracleWP2:tomar:catpool"/> </physical> <logical> </logical> </File> <File ID="B E882-D811-81CF-00D0B7B86B36"> <pfn filetype="Oracle" name="OracleWP3:tomar2:tomar2"/> <logical/> </File> Back… CAT POOL Team
27
Storage Manager related Data Structures mapping
##Shapes(ShapeID, pShape) = Table Shapes## With columns ShapeID and pShape. ##Links(LinkID) = Table Links## With column LinkID. ##Params(NameValue) =Table Params## With column NameValue Back… CAT POOL Team
28
Primitive data type mapping
Persistent shape of a class with primitive datatype members is stored as e.g : where P-public,R-private,O-protected Primitive data types are mapped to RDBMS datatypes as Back… CAT POOL Team
29
unsigned long int number
long double number double number float float long number char varchar unsigned char varchar signed char varchar int number long int number short int number unsigned int number signed int number unsigned long int number CAT POOL Team
30
signed short int number unsigned short int number ulonglong number
signed long int number signed short int number unsigned short int number ulonglong number unsigned long long int number longlong number long long int number signed long long int number Back… CAT POOL Team
31
Reference Data Type Mapping
Persistent shape of a class with reference data type member is stored as Eg.: The table column stores the string oid.first : oid.second ( oid.first indicates the entryID – in local link table- corresponding to the ref’s container Token entry, and oid.second indicates the rowID inside the actual ref container ) for the referenced member. The link table - in local db - contains one column (Link id). Link Id stores the container Token for the referenced object Back… CAT POOL Team
32
Token Dereferencing Full Token = Container Token + RowID
Container Token = TechID + Database + Container = TechID + PFN + Cont_Name = “ ” + DSN:UserID:Passwd + Cont_Name DSN = IP, PORT, SID, Driver Hence: Full Token = “ ” +DSN:UserID:Passwd Cont_Name + RowID Thus any object stored in RDBMS can be located Back… CAT POOL Team
33
Illustration: Writing/Reading
Cont token=DB+Tech+ContName DB=RemoteDB, Tech=Relational, Cont=Cont_50 Full token=Rel. + ReDB + Cont_50 + 4(RowID) ShapeID for Classes Database Context DSN=OracleWP2 Cont_50 Cont_51 Shapes## User=tomar Passwd=** IP=oradev9 Port=1521 SID=D9 RowID a1 RowID a2 ShapeID pShape 1 10 1 5:4 2 100 2 5:1 3 18 Links## 3 5:2 4 11 EntryID LinkID Params## 2 Cont token NameValue 3 Cont token PFN 4 Cont token FID 5 Cont token POOL_VSN CAT POOL Team Back…
34
Typical Table entries Shapes## (on local DB) Back… SHAPEID PSHAPE
{ID=4FFF4DBB-FFE4-4F0D-95D AD8} {CL=TestClass2} {NCOL=1} {CNT=0} {COL= {{NAME=TestClass2} {CLASS=TestClass2} {TYP=21}{OPT=0}{OFF=0}{SIZ=0}{CNT=1}}} {ID=4FFF4DBB-FFE4-4F0D-95D AD7}{CL=TestClass1}{NCOL=1}{CNT=0} {COL={{NAME=TestClass1}{CLASS=TestClass1} {TYP=21}{OPT=0}{OFF=0}{SIZ=0}{CNT=1}}} PSHAPE CAT POOL Team
35
(Cont…) Shapes## (on Remote DB) Back… SHAPEID PSHAPE
{ID=4FFF4DBB-FFE4-4F0D-95D AD8} {CL=TestClass2} {NCOL=1} {CNT=0} {COL= {{NAME=TestClass2} {CLASS=TestClass2} {TYP=21}{OPT=0}{OFF=0}{SIZ=0}{CNT=1}}} PSHAPE CAT POOL Team
36
(Cont…) Links## (on local DB) Back… LINKID
[DB=<localDB>][CNT=##Params][CLID=DA8F479C-09BC-49D4-94BC-99D025A23A3B][TECH= ][OID= FFFFFFFF] [DB=<localDB>][CNT=cont_50][CLID=4FFF4DBB-FFE2-4F0D-95D AD8][TECH= ][OID= FFFFFFFF] [DB=<localDB>][CNT=cont_51][CLID=4FFF4DBB-FFE2-4F0D-95D AD7][TECH= ][OID= FFFFFFFF] [DB=B E882-D811-81CF-00D0B7B86B36] [CNT=cont_50] [CLID=4FFF4DBB-FFE2-4F0D-95D AD8] [TECH= ][OID= ] CAT POOL Team
37
(Cont…) Links## (on remote DB) Back… LINKID
[DB=<localDB>][CNT=##Params][CLID=DA8F479C-09BC-49D4-94BC-99D025A23A3B] [TECH= ] [OID= FFFFFFFF] [DB=<localDB>][CNT=cont_50][CLID=4FFF4DBB-FFE2-4F0D-95D AD8] [TECH= ] [OID= FFFFFFFF] CAT POOL Team
38
(Cont…) Params## (on local DB) Back… NAMEVALUE
[NAME=FID][VALUE=B2B6AA42-E882-D811-8CDF-00D0B7B86B36] [NAME=PFN][VALUE=OracleWP2:tomar:catpool] [NAME=POOL_VSN][VALUE=1.1] CAT POOL Team
39
(Cont…) Params## (on remote DB) Back… NAMEVALUE
[NAME=FID][VALUE=B E882-D811-81CF-00D0B7B86B36] [NAME=PFN][VALUE=OracleWP3:tomar2:tomar2] [NAME=POOL_VSN][VALUE=1.1] CAT POOL Team
40
Storage Manager – Our feedback from implementation for Relational backend
Either change names of ##Links, ##Shapes,##Params or provide a function for checking supported grammar for table names, especially for ##Links, ##Shapes and ##Params and then changing names. Provide function for querying access rights of the tables. Provide function for querying transaction capabilities and then force upper layer functions to make use of the database transaction features Back… CAT POOL Team
41
Summary POOL Storage Manager passed all “proof-of-concept” tests for Relational backends. We have some feedback on the relational backend specific interface changes in the storage manager, which we will be submitting as a document Back… CAT POOL Team
42
Thank You Questions ??? CAT POOL Team
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.