A U.S. Department of Energy Office of Science Laboratory Operated by The University of Chicago Argonne National Laboratory Office of Science U.S. Department of Energy IRMIS PV Crawler Auto-populating the IRMIS PV Schema
Pioneering Science and Technology Office of Science U.S. Department of Energy 2 IRMIS PV Crawler Requirements -Perl 5 with DBI and DBD:mysql modules -MySQL 4.x (4.1 preferred) -EPICS msi tool (for now…) -Reasonably consistent ioc boot process -Some ability to write/edit perl code - To create *BootScan module - To handle site-specific boot peculiarities
Pioneering Science and Technology Office of Science U.S. Department of Energy 3 IRMIS PV Crawler db.properties path.properties pv_crawler.pl *BootScan Parser DBIDBI bootparams st.cmd dbd db IOC boot file system(s) MySQL ioc Ioc_boot, ioc_resource Rec,fld,…
Pioneering Science and Technology Office of Science U.S. Department of Energy 4 IRMIS PV Crawler What pv_crawler does (every 5 minutes): -Identify ioc’s to be scanned and their last known boot date (ie. APSBootScan.pm or SNSBootScan.pm) -foreach ioc - Check for new boot date If so, insert new ioc_boot record in db and proceed If not, skip to next ioc - Parse st.cmd (collecting all info on dbd and db files) - Check for any dbd or db file time mods If so, insert all pv and field data in db for ioc
Pioneering Science and Technology Office of Science U.S. Department of Energy 5 IRMIS PV Crawler Sample output from test run [bacchus]saunders> pv_crawler.pl --go --boot-scan=APSBootScan --test --debug-level=debug I| |pv crawler beginning usage: msi -V -Ipath... -Msub... -Ssubfile template Specifying path will replace the default '.' stdin is used if template is not given D| |PVCrawlerDBLayer: begin ioc_find D| |iocs to be boot scanned: iocpar01 I| |Processing ioc iocpar01, boot date: I| |Parsing /usr/local/iocapps/R /ioc/par/3/iocBoot/iocpar01/st.cmd D| |script mod time = D| |sl = < cdCommands D| |script mod time = D| |sl = startup = "/net/helios/iocapps/R /ioc/par/3/iocBoot/iocpar01" D| |sl = dbLoadDatabase("dbd/par01App.dbd") D| |parse_function_call D| |function dbLoadDatabase with args ("dbd/par01App.dbd") D| |opening /net/helios/iocapps/R /ioc/par/3/dbd/par01App.dbd D| |sl = dbLoadRecords "par01App/commonDb/par01status.db" D| |parse_function_call D| |function dbLoadRecords with args "par01App/commonDb/par01status.db" D| |calling parse_db with /net/helios/iocapps/R /ioc/par/3/par01App/commonDb/par 01status.db D| |check_for_file_mods(): no record found in db, so return 1 I| |IOC Resources changed: 1, Parse error: 0 I| |Write data to DB I| |pv crawler done
Pioneering Science and Technology Office of Science U.S. Department of Energy 6 IRMIS PV Crawler What info do we store over time for a given IOC? -Boot history - Each new ioc boot is recorded with date, regardless of whether any configuration has changed - If there is an identifiable problem with the boot, or inability to parse it’s configuration, an associated error is recorded -File system resources (only if changed from last crawl) - Path to each dbd and db file that make up configuration, along with file modified date and any text substitutions applied -Record type definitions (dbd) (only if changed from last crawl) - The set of fields defined for each record type at that time -Record definitions (db) (only if changed from last crawl) - Record name, fields and their default/overriden values
Pioneering Science and Technology Office of Science U.S. Department of Energy 7 IRMIS PV Crawler rdbCore PV Schema
Pioneering Science and Technology Office of Science U.S. Department of Energy 8 IRMIS PV Crawler Experience to date -Running continuously for weeks now -No involvement of ioc developers time -All but 3 of 265 IOCs crawled successfully (including soft iocs) -Continual crawler parser improvement required, but has settled down to trivial cases now. -Crawler log raised useful issues for about 16 IOCs - Ioc’s registered as active in ioc table, but were not - Some file system resources unreachable due to perms - Identified ioc’s booting out of home directory - Identified references to non-existent st.cmd, dbd, db files - Fields defined in db files that don’t exist in record type - Identified ioc’s outside of general boot guidelines - Duplicate record definitions