Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 22 Next »


Prerequisites

This test requires restart of infrastructure components (database and jms broker). These steps must be coordinated with the other testers.

Resubmit jobs after restart, restart of failed jobs, upload of old files at harvester restart, scheduler skips old jobs.

 

Install and Start System

On test@kb-prod-udv-001.kb.dk:

 

export TESTX=TEST6
export PORT=807?
export MAILRECEIVERS=foo@bar.dk
stop_test.sh
cleanup_all_test.sh
prepare_test.sh deploy_config_database.xml
install_test.sh
start_test.sh

Check that the GUI is available that the System Status doesn not show any startup problems.

Start a selective harvest

Start a hourly selective harvest for the 'netarkivet.dk' domain.

Create a new template:

  • Download the template "default_orderxml" 
  • Edit the template so that max-size-bytes is 5000 in the WARCWriterProcessor
  • Upload the template with a new name, for example "Small Warcfiles"

Modify domain templates 

  • Configure the defaultconfig for  kum.dk to use template 'small_arcfiles_order.xml'.
  • Configure the  defaultconfig for  dbc.dk to use template 'frontpages'
  • Configure the  defaultconfig for  bs.dk to use template 'path_10levels_order.xml'. 

Make a new snapshot harvest definition with a name you can remember

  • Create a new snapshot harvest Set 'Max number of bytes per domain’ 1.000.000 bytes (1 mbyte).
  • Check that the job is started correctly in the  'Harvest status'->'All Jobs' in the left menu and that no errors or warnings are present in the system overview.

Stop the Test Automatically During Upload

  • Using the GUI, find the job number and the name of the harvest machine for the job in which kum.dk is being harvested.
  • Download the attached script and modify it to point at the correct harvester and job number
  • Copy the script to kb-prod-udv-001.kb.dk and run it. It monitors the "warcs" directory and as soon as the first warcfile is uploaded it detects that uploading has started and shuts down the test instance.

Save the Metadata Warcfile

  • Log into the harvester where kum.dk was being harvested
  • Find the crawldir in TEST6/harvester_low
  • Find the metadata warcfile in the metadata subdirectory and copy it to /tmp

Create a Fake Crawl Dir

  • ssh netarkiv@sb-test-har-001.statsbiblioteket.dk
  • cd TEST6/harvester_high 
  • cp -r ~netarkiv/testdata/TEST6/23-fakejobdir
  • mkdir 23-fakejobdir/logs
  • touch 23-fakejobdir/logs/crawl.log

Wait 3 Hours then Restart the System

Wait 3 Hours then Restart the System

Verify the restarted system. On kb-test-adm-001

  1. Check the log for warnings and errors.

    cd /home/test/$TESTX/log/
    grep SEVERE *.log.0
    grep WARNING *.log.0

    The following entries are normal: 

    arcrepositoryapplication0.log.0:WARNING: AdminDataFile (./admin.data) was not found.
    guiapplication0.log.0:WARNING: Refusing to schedule harvest definition 'netarkivet' in the past. Skipped 18 events. Old nextDate was Mon Dec 18 14:29:30 CET 2006 new nextDate is Tue Dec 19 09:29:30 CET 2006
    GUIApplication0.log.0:WARNING: Job 2 failed: HarvestErrors = dk.netarkivet.common.exceptions.IOFailure: Crawl probably interrupted by shutdown of HarvestController

    The following warning may occur after a while: 

    WARNING: Error processing message '
    Class:                  com.sun.messaging.jmq.jmsclient.ObjectMessageImpl
    getJMSMessageID():      ID:40-130.225.27.140(d2:1:3:b1:10:de)-46478-1197902260630
    getJMSTimestamp():      1197902260630
    getJMSCorrelationID():  null
    JMSReplyTo:             null
    JMSDestination:         TEST6_COMMON_THE_SCHED
    getJMSDeliveryMode():   PERSISTENT
    getJMSRedelivered():    false
    getJMSType():           null
    getJMSExpiration():     0
    getJMSPriority():       4
    Properties:             null'
    dk.netarkivet.common.exceptions.UnknownID: Job id 23 is not known in persistent storage
            at dk.netarkivet.harvester.datamodel.JobDBDAO.read(JobDBDAO.java:294)
            at dk.netarkivet.harvester.scheduler.HarvestSchedulerMonitorServer.processCrawlStatusMessage(HarvestSchedulerMonitorServer.java:103)
            at dk.netarkivet.harvester.scheduler.HarvestSchedulerMonitorServer.visit(HarvestSchedulerMonitorServer.java:285)
            at dk.netarkivet.harvester.harvesting.distribute.CrawlStatusMessage.accept(CrawlStatusMessage.java:133)
            at dk.netarkivet.harvester.distribute.HarvesterMessageHandler.onMessage(HarvesterMessageHandler.java:67)
            at com.sun.messaging.jmq.jmsclient.MessageConsumerImpl.deliverAndAcknowledge(MessageConsumerImpl.java:330)
            at com.sun.messaging.jmq.jmsclient.MessageConsumerImpl.onMessage(MessageConsumerImpl.java:265)
            at com.sun.messaging.jmq.jmsclient.SessionReader.deliver(SessionReader.java:102)
            at com.sun.messaging.jmq.jmsclient.ConsumerReader.run(ConsumerReader.java:174)
            at java.lang.Thread.run(Thread.java:595)
  2. Go to the system overview page and check that all the expected applications are listen and are without warnings or errors.
  3. Check that the scheduler schedules only one job for the hourly selective harvest.

Check that a job can be resubmitted

  1. Check that you can reject a job for resubmission using the "Reject?" button so that it is no longer visible when you list failed jobs.
  2. Check that you can see the rejected job when you now list all jobs.
  3. Click on one or more "Genstart"/"Resubmit" buttons. Note that you only can resubmit jobs failed due to harvesting errors, not due to upload errors.
  4. Check that the job-status changes to "resubmitted" and that a new Job is made from the same harvestdefinition with the same configurations.
  5. Check that resubmitted jobs contain information about which job they were resubmitted (FR770)

Følgende udføres på sb-test-bar-001.statsbiblioteket.dk som bruger netarkiv

Kør følgende, som laver to sorterede lister af dels indhold i ARC-filerne, dels indhold i CDX-filerne og sammenligner:
(NB: Der skrives nu igen til /netarkiv/0001 er fyldt op)
export TESTX=TEST?

cd /netarkiv/0001/$TESTX/filedir
grep -a '^http://[^ ] [0-9.]+ [0-9]+' *.dk.arc | sort >/tmp/$TESTX-arc-headers
grep -a '^http://[^ ] [0-9.]+ [0-9]+' *-metadata-1.arc | cut -d' ' -f1-5 | sort >/tmp/$TESTX-cdx-headers
diff -a /tmp/$TESTX-arc-headers /tmp/$TESTX-cdx-headers

Dette skulle ikke give noget output.
Kør følgende, som udregner mængden af høstede sider, mængden af duplikater og mængden af DNS-opslag for 'netarkivet.dk':

grep '^http://[^ /]*netarkivet.dk/.*\ ' *-metadata-1.arc |wc -l
grep '[0-9]\ http://[^ /]*netarkivet.dk.*\ .*duplicate' *-metadata-1.arc| wc -l
grep '[0-9]\ dns:[^ /]*netarkivet.dk.*' *-metadata-1.arc| wc -l

Disse tre tal skulle tilsammen antallet af dokumenter der er høstet fra netarkivet.dk. Det skulle være mindst det samme som summen af dokumenter høstet der vises under Høstnings-historie for netarkivet.dk (http://kb-test-adm-001.kb.dk:807?/History/Harveststatus-perdomain.jsp?domainName=netarkivet.dk).
Hvis {sum af tal fra grep's} < {sum af tal fra Høstnings-historik} så gøres følgende:
Hvis tallet er højere er det fordi der er høstet noget netarkiv-data i jobs der ikke er nået tilbage til GUI'en eller som subdele af høstninger der ikke angiver netarkivet.dk som et domæne. I så fald findes jobnumre der har høstet i http://kb-test-adm-001.kb.dk:807?/History/Harveststatus-perdomain.jsp?domainName=netarkivet.dk. Så køres:

grep '^http://[^ /]*netarkivet.dk/.*\ ' {<<id>>,<<id>>,<<id>>}-metadata-1.arc |wc -l
grep '[0-9]\ http://[^ /]*netarkivet.dk.*\ .*duplicate' {<<id>>,<<id>>,<<id>>}-metadata-1.arc| wc -l
grep '[0-9]\ dns:[^ /]*netarkivet.dk.*' {<<id>>,<<id>>,<<id>>}-metadata-1.arc| wc -l

hvor <> er jobid'erne.
Læs metadata-arc filen. se evt.heritrix doku på http://crawler.archive.org/articles/user_manual.html#creating
Check:
At den starter med en "filedesc:" indgang
At der følger et antal "metadata:" indgange som i URL-en har følgende parametre:

  • heritrix version, dog ikke i cdx-metadata-indgangen, og jobids for duplicate reduction-indgangen.
  • harvestid=<nummeret på den foretagne høstning>
  • jobid=<nummberet på jobbet>
  • IP på høstermaskinen
  • timestamp=<tidspunktet høstningen gik i gang> (i UTC tidszone)
  • har passende mime-type
  • At der findes en efterfølgende duplicatereductionjobs metadata-sektion med passende krop [Er der kun, hvis jobbet laver deduplicatereduction på basis af nogle bestemte jobs, som dette job kan opfattes som en fortsættelse af; hvis listen af disse jobs er tom, laves denne sektion ikke!!]
  • At def findes en efterfølgende crawl-manifest metadata-sektion med passende krop
  • At der findes en efterfølgende harvestInfo metadata-sektion med passende krop
  • At der findes en efterfølgende crawl-order metadata-sektion med passende krop
  • At der findes en efterfølgende seedlist metadata-sektion med passende krop
  • At der findes en efterfølgende crawlreport metadata-sektion med passende krop
  • At der findes en efterfølgende frontier-report metadata-sektion med passende krop
  • At der findes en efterfølgende hosts-report metadata-sektion med passende krop
  • At der findes en efterfølgende mimetype-report metadata-sektion med passende krop
  • At der findes en efterfølgende processors-report metadata-sektion med passende krop
  • At der findes en efterfølgende responsecode-report metadata-sektion med passende krop
  • At der findes en efterfølgende seedsreport metadata-sektion med passende krop
  • At der findes en efterfølgende crawllog metadata-sektion med passende krop
  • At der findes en efterfølgende heritrix.out metadata-sektion med passende krop
  • At der findes en efterfølgende heritrix_dmesg.log metadata-sektion med passende krop
  • At der findes en efterfølgende local-errorslog metadata-sektion med passende krop
  • At der findes en efterfølgende progress-statistics metadata-sektion med passende krop
  • At der findes en efterfølgende runtime-errorslog metadata-sektion med passende krop
  • At der findes en efterfølgende uri-errorslog metadata-sektion med passende krop
  • At der findes en efterfølgende crawl/index metadata-sektion med passende krop
  • NB: En passende krop kan være den tomme streng (f.eks i runtime-errors, local-errors, og uri-errors)

Check at scheduleren overspringer forældede hændelser

Shutdown the system

 

  • No labels