Hello Daniele,

Thank you for the update, however I do not seem to get it to work. Please
let me know if i'm missing something. I start with the following initial
folder structure:

/geoserver/data/workspace/<IMAGEMOSAIC_DIRECTORY>/*.tiffs
/geoserver/data/workspace/<IMAGEMOSAIC_DIRECTORY>/datastore.properties
/geoserver/data/workspace/<IMAGEMOSAIC_DIRECTORY>/indexer.properties
/geoserver/data/workspace/<IMAGEMOSAIC_DIRECTORY>/1/*.tiffs
/geoserver/data/workspace/<IMAGEMOSAIC_DIRECTORY>/1/datastore.properties
/geoserver/data/workspace/<IMAGEMOSAIC_DIRECTORY>/1/indexer.properties
etc.

Note that in the initial folder structure there is no folder named '0', as
the imagepyramid only accepts folder structures as outputted by
gdal_retile. My datastore and indexer properties files look like:

*Datstore.properties:*
SPI=org.geotools.data.postgis.PostgisNGJNDIDataStoreFactory
schema=plantation_ecu_sumifru_144
Loose\ bbox=true
Estimated\ extends=false
validate\ connections=true
Connection\ timeout=10
preparedStatements=true
jndiReferenceName=java:comp/env/jdbc/postgis

*Indexer.properties:*
Caching=false
TimeAttribute=ingestion
Schema=*the_geom:Polygon,location:String,ingestion:java.util.Date:Double
PropertyCollectors=TimestampFileNameExtractorSPI[timeregex](ingestion)
TypeName=imagery0

Note the addition of 'TypeName' to the indexer.properties, which is unique
per folder level. Using this set-up Geoserver returns the following error:

file:///geoserver/data/testworkspace/imagery_pyramid/
java.lang.RuntimeException: Could not list layers for this store, an error
occurred retrieving them: null
at
org.geoserver.web.data.layer.NewLayerPageProvider.getItemsInternal(NewLayerPageProvider.java:158)
at
org.geoserver.web.data.layer.NewLayerPageProvider.getItems(NewLayerPageProvider.java:61)
at
org.geoserver.web.wicket.GeoServerDataProvider.fullSize(GeoServerDataProvider.java:243)
at
org.geoserver.web.wicket.GeoServerTablePanel$PagerDelegate.updateMatched(GeoServerTablePanel.java:583)
at
org.geoserver.web.wicket.GeoServerTablePanel$PagerDelegate.<init>(GeoServerTablePanel.java:576)
at
org.geoserver.web.wicket.GeoServerTablePanel.<init>(GeoServerTablePanel.java:176)
at
org.geoserver.web.wicket.GeoServerTablePanel.<init>(GeoServerTablePanel.java:97)
at org.geoserver.web.data.layer.NewLayerPage$1.<init>(NewLayerPage.java:105)
at org.geoserver.web.data.layer.NewLayerPage.<init>(NewLayerPage.java:105)
at
org.geoserver.web.data.store.CoverageStoreNewPage.onSuccessfulSave(CoverageStoreNewPage.java:86)
at
org.geoserver.web.data.store.CoverageStoreNewPage.onSave(CoverageStoreNewPage.java:74)
at
org.geoserver.web.data.store.AbstractCoverageStorePage$1.onSubmit(AbstractCoverageStorePage.java:122)
at
org.apache.wicket.ajax.markup.html.form.AjaxSubmitLink$1.onSubmit(AjaxSubmitLink.java:111)
at
org.apache.wicket.ajax.form.AjaxFormSubmitBehavior$AjaxFormSubmitter.onSubmit(AjaxFormSubmitBehavior.java:215)
at org.apache.wicket.markup.html.form.Form.delegateSubmit(Form.java:1309)
at org.apache.wicket.markup.html.form.Form.process(Form.java:976)
at org.apache.wicket.markup.html.form.Form.onFormSubmitted(Form.java:797)
at
org.apache.wicket.ajax.form.AjaxFormSubmitBehavior.onEvent(AjaxFormSubmitBehavior.java:171)
at
org.apache.wicket.ajax.AjaxEventBehavior.respond(AjaxEventBehavior.java:155)
at
org.apache.wicket.ajax.AbstractDefaultAjaxBehavior.onRequest(AbstractDefaultAjaxBehavior.java:601)
at sun.reflect.GeneratedMethodAccessor427.invoke(Unknown Source)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at
org.apache.wicket.RequestListenerInterface.internalInvoke(RequestListenerInterface.java:258)
at
org.apache.wicket.RequestListenerInterface.invoke(RequestListenerInterface.java:241)
at
org.apache.wicket.core.request.handler.ListenerInterfaceRequestHandler.invokeListener(ListenerInterfaceRequestHandler.java:248)
at
org.apache.wicket.core.request.handler.ListenerInterfaceRequestHandler.respond(ListenerInterfaceRequestHandler.java:234)
at
org.apache.wicket.request.cycle.RequestCycle$HandlerExecutor.respond(RequestCycle.java:895)
at
org.apache.wicket.request.RequestHandlerStack.execute(RequestHandlerStack.java:64)
at
org.apache.wicket.request.cycle.RequestCycle.execute(RequestCycle.java:265)
at
org.apache.wicket.request.cycle.RequestCycle.processRequest(RequestCycle.java:222)
at
org.apache.wicket.request.cycle.RequestCycle.processRequestAndDetach(RequestCycle.java:293)
at
org.apache.wicket.protocol.http.WicketFilter.processRequestCycle(WicketFilter.java:261)
at
org.apache.wicket.protocol.http.WicketFilter.processRequest(WicketFilter.java:203)
at
org.apache.wicket.protocol.http.WicketServlet.doPost(WicketServlet.java:159)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:660)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
at
org.springframework.web.servlet.mvc.ServletWrappingController.handleRequestInternal(ServletWrappingController.java:158)
at
org.springframework.web.servlet.mvc.AbstractController.handleRequest(AbstractController.java:147)
at
org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter.handle(SimpleControllerHandlerAdapter.java:50)
at
org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:959)
at
org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:893)
at
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:968)
at
org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:870)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:660)
at
org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:844)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at
org.geoserver.filters.ThreadLocalsCleanupFilter.doFilter(ThreadLocalsCleanupFilter.java:28)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at
org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:75)
at org.geoserver.wms.animate.AnimatorFilter.doFilter(AnimatorFilter.java:71)
at
org.geoserver.filters.SpringDelegatingFilter$Chain.doFilter(SpringDelegatingFilter.java:71)
at
org.geoserver.filters.SpringDelegatingFilter.doFilter(SpringDelegatingFilter.java:46)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at
org.geoserver.platform.AdvancedDispatchFilter.doFilter(AdvancedDispatchFilter.java:50)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at
org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:316)
at
org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:69)
at
org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:126)
at
org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:90)
at
org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:73)
at
org.geoserver.security.filter.GeoServerCompositeFilter.doFilter(GeoServerCompositeFilter.java:92)
at
org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at
org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:69)
at
org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:114)
at
org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:73)
at
org.geoserver.security.filter.GeoServerCompositeFilter.doFilter(GeoServerCompositeFilter.java:92)
at
org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at
org.geoserver.security.filter.GeoServerAnonymousAuthenticationFilter.doFilter(GeoServerAnonymousAuthenticationFilter.java:54)
at
org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at
org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:69)
at
org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:205)
at
org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:73)
at
org.geoserver.security.filter.GeoServerCompositeFilter.doFilter(GeoServerCompositeFilter.java:92)
at
org.geoserver.security.filter.GeoServerUserNamePasswordAuthenticationFilter.doFilter(GeoServerUserNamePasswordAuthenticationFilter.java:116)
at
org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at
org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:69)
at
org.springframework.security.web.authentication.rememberme.RememberMeAuthenticationFilter.doFilter(RememberMeAuthenticationFilter.java:157)
at
org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:73)
at
org.geoserver.security.filter.GeoServerCompositeFilter.doFilter(GeoServerCompositeFilter.java:92)
at
org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at
org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:69)
at
org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:91)
at
org.geoserver.security.filter.GeoServerSecurityContextPersistenceFilter$1.doFilter(GeoServerSecurityContextPersistenceFilter.java:53)
at
org.geoserver.security.filter.GeoServerCompositeFilter$NestedFilterChain.doFilter(GeoServerCompositeFilter.java:73)
at
org.geoserver.security.filter.GeoServerCompositeFilter.doFilter(GeoServerCompositeFilter.java:92)
at
org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:330)
at
org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:213)
at
org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:176)
at
org.geoserver.security.GeoServerSecurityFilterChainProxy.doFilter(GeoServerSecurityFilterChainProxy.java:152)
at
org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at
org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:262)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.geoserver.filters.LoggingFilter.doFilter(LoggingFilter.java:87)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at
org.geoserver.filters.XFrameOptionsFilter.doFilter(XFrameOptionsFilter.java:89)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.geoserver.filters.GZIPFilter.doFilter(GZIPFilter.java:42)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at
org.geoserver.filters.SessionDebugFilter.doFilter(SessionDebugFilter.java:48)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.geoserver.filters.FlushSafeFilter.doFilter(FlushSafeFilter.java:44)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at
org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:121)
at
org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at
org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)
at
org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
at
org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:475)
at
org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)
at
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:80)
at
org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:651)
at
org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
at
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)
at
org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:498)
at
org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
at
org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:796)
at
org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1374)
at
org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at
org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:748)
Caused by: java.lang.NullPointerException
at org.geotools.gce.imagepyramid.Utils.checkConsistency(Utils.java:316)
at org.geotools.gce.imagepyramid.Utils.checkSource(Utils.java:201)
at
org.geotools.gce.imagepyramid.ImagePyramidReader.<init>(ImagePyramidReader.java:177)
at
org.geotools.gce.imagepyramid.ImagePyramidFormat.getReader(ImagePyramidFormat.java:249)
at
org.geotools.gce.imagepyramid.ImagePyramidFormat.getReader(ImagePyramidFormat.java:56)
at
org.geoserver.catalog.ResourcePool.getGridCoverageReader(ResourcePool.java:1511)
at
org.geoserver.catalog.ResourcePool.getGridCoverageReader(ResourcePool.java:1441)
at
org.geoserver.catalog.impl.CoverageStoreInfoImpl.getGridCoverageReader(CoverageStoreInfoImpl.java:59)
at sun.reflect.GeneratedMethodAccessor547.invoke(Unknown Source)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at
org.geoserver.catalog.impl.ModificationProxy.invoke(ModificationProxy.java:147)
at com.sun.proxy.$Proxy64.getGridCoverageReader(Unknown Source)
at
org.geoserver.web.data.layer.NewLayerPageProvider.getItemsInternal(NewLayerPageProvider.java:95)
... 137 more

However the folder structure does change to the level structure (e.g. 0, 1,
etc) but only one table is created (in this case the table for folder level
1) and the table name is not named after the TypeName variable, but after
the folder name ('1'). For the other folders no shapefile and no tables are
created. I also tried different combinations, e.g putting the TypeName in
datastore.properties with no success. I did not try the method proposed by
Peter yet (using a indexer.xml instead of properties). Please let me know
if i'm missing something.

Thank you.

Kind regards.
Darell

On Mon, Oct 2, 2017 at 12:34 PM, Daniele Romagnoli <
daniele.romagn...@geo-solutions.it> wrote:

> Hi Darell,
>
> On Mon, Oct 2, 2017 at 11:30 AM, Darell van der Voort <darell...@gmail.com
> > wrote:
>
>> Hello Daniele,
>>
>> Thank you for your input! I now use a schema per workspace, but creating
>> a schema per imagepyramid would indeed solve the problem of duplicate table
>> names. So do I understand correctly that there is no possibility to change
>> the table names?
>>
>
> Nope, you can do that, instead.
> You can specify the same "schema" name in all the level's
> datastore.properties but you should specify a different "TypeName" property
> in each indexer file. The specific ImageMosaic level will index granules in
> that "TypeName" table.
>
> Hope this helps.
> Regards,
> Daniele
>
>
>
>
>> For example to: schema.imagepyramid0, schema.imagepyramid1 etc. In which
>> schema is the unique workspace schema and imagepyramid is the name of the
>> layer. Thank you!
>>
>> Kind regards,
>> Darell
>>
>> On Mon, Oct 2, 2017 at 11:19 AM, Daniele Romagnoli <
>> daniele.romagn...@geo-solutions.it> wrote:
>>
>>> Hi Darell,
>>> as you said, the imagePyramid is basically a set of imageMosaics: an
>>> ImageMosaic for each pyramid level.
>>> Therefore, each level should have its own indexer and, optionally, a
>>> datastore.properties if you want to catalog the granules into a DB instead
>>> of default shapefile.
>>>
>>> When using DB instead of shapefile, you may want to use a single
>>> database (as an instance, "pyramid") and store each level granule's index
>>> into a different schema name. Therefore, the datastore.properties of each
>>> level should define a different schema name, as an instance:
>>>
>>> pyramid/0/datastore.properties contains a "schema=level0" property
>>> pyramid/1/datastore.properties contains a "schema=level1" property
>>> pyramid/2/datastore.properties contains a "schema=level2" property
>>>
>>> Note that you should create the schemas (with "CREATE SCHEMA levelx" sql
>>> statements) in advance on your DB, before configuring the imagePyramid
>>> store in GeoServer.
>>>
>>> Hope this helps.
>>> Regards,
>>> Daniele
>>>
>>>
>>>
>>>
>>>
>>> On Mon, Oct 2, 2017 at 10:54 AM, Darell van der Voort <
>>> darell...@gmail.com> wrote:
>>>
>>>> Hi Peter,
>>>>
>>>> Thank you for the examples, very helpful! Using a indexer.xml indeed
>>>> seems like a better set-up. Have you ever tried this in combination with
>>>> the imagepyramid plugin? I know that the imagepyramid are basically just
>>>> imagemoasics per folder level. However as the folder structure is different
>>>> it causes some problems. My folder structure looks like:
>>>>
>>>> /geoserver/data/workspace/<IMAGEMOSAIC_DIRECTORY>/0/.tiffs
>>>> /geoserver/data/workspace/<IMAGEMOSAIC_DIRECTORY>/1/.tiffs
>>>> /geoserver/data/workspace/<IMAGEMOSAIC_DIRECTORY>/2/.tiffs
>>>> etc..
>>>>
>>>> Where the numbers stand for the pyramid levels which are filled with
>>>> multiple tiffs, the indexer.properties and the foldername.properties. I put
>>>> tiffs from different dates in the same folder and use a unique date in the
>>>> filename. Should I put the indexer.xml and datastore.properties in each
>>>> pyramid directory? I can try it later this week and will let you know if it
>>>> works.
>>>>
>>>> Kind regards,
>>>> Darell
>>>>
>>>> On Fri, Sep 29, 2017 at 11:43 AM, Peter Kovac <
>>>> peter.ko...@microstep-mis.com> wrote:
>>>>
>>>>> I usually configure ImageMosaic for time-series plain GeoTIFF granules
>>>>> so my advice might not be 100% accurate but I hope it helps anyway.
>>>>>
>>>>> Firstly, your schema seems wrong to me: you have two types specified
>>>>> for ingestion - java.util.Date and a Double after that. Perhaps another
>>>>> attribute of double type is missing or the :Double part should be deleted.
>>>>>
>>>>> Otherwise, I recommend using indexer.xml instead of indexer.properties
>>>>> for configuration. In your case it might look like this:
>>>>>
>>>>> <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
>>>>> <Indexer>
>>>>>    <domains>
>>>>>       <domain name="ingestion">
>>>>>          <attributes><attribute ref="timeCollector">ingestion<
>>>>> /attribute></attributes>
>>>>>       </domain>
>>>>>    </domains>
>>>>>    <schemas>
>>>>>       <schema name="default">
>>>>>         <attributes>*the_geom:Polygon,location:String,ingestion:java
>>>>> .util.Date</attributes>
>>>>>       </schema>
>>>>>    </schemas>
>>>>>    <coverages>
>>>>>       <coverage>
>>>>>          <name>your_coverage_name</name>
>>>>>          <schema ref="default"></schema>
>>>>>          <domains>
>>>>>             <domain ref="ingestion"/>
>>>>>          </domains>
>>>>>       </coverage>
>>>>>    </coverages>
>>>>>    <collectors>
>>>>>       <collector name="timeCollector">
>>>>>          
>>>>> <value>regex=([0-9]{14}),format=yyyyMMddHHmmss,fullPath=true</value><!--
>>>>> configure according to your time format-->
>>>>>          <spi>TimestampFileNameExtractorSPI</spi>
>>>>>          <mapped>ingestion</mapped>
>>>>>       </collector>
>>>>>    </collectors>
>>>>>    <parameters>
>>>>>         <parameter name="AbsolutePath" value="true" /><!-- if true,
>>>>> then database table will contain full paths in location column -->
>>>>>         <parameter name="Caching" value="false" />
>>>>>         <parameter name="CanBeEmpty" value="false" />
>>>>>         <parameter name="IndexingDirectories"
>>>>> value="/path/to/directory/to/be/indexed" /><!-- this path might be
>>>>> relative if you know current working directory of your GeoServer/Tomcat
>>>>> instance -->
>>>>>         <parameter name="Name" value="your_coverage_name" /><!-- this
>>>>> value is used as the name of the database table -->
>>>>>         <parameter name="Recursive" value="true" /><!-- true if path
>>>>> specified in IndexingDirectories needs to be traversed recursively which I
>>>>> guess is your case -->
>>>>>         <parameter name="TimeAttribute" value="ingestion" /><!-- your
>>>>> time dimension attribute is called ingestion -->
>>>>>     </parameters>
>>>>> </Indexer>
>>>>> Usually my ImageMosaic folder structure is like this (
>>>>> /opt/geoserver_data is the GEOSERVER_DATA_DIR)
>>>>> * the indexer.xml and datastore.properties files are in a
>>>>> /opt/geoserver_data/data/<IMAGEMOSAIC_DIRECTORY>
>>>>> * there is a subdirectory, usually with a date tree structure for
>>>>> storing granules from separate days in separate directories:
>>>>> /opt/geoserver_data/data/<IMAGEMOSAIC_DIRECTORY>/tiff/YYYY/M
>>>>> M/DD/some_file_YYYYMMDDHHmss.tiff
>>>>> * in indexer.xml I have *Recursive *parameter set to
>>>>> *true ** I usually use absolute path to the tiff directory as
>>>>> *IndexingDirectories* parameter value, e.g.
>>>>> /opt/geoserver_data/data/<IMAGEMOSAIC_DIRECTORY>/tiff
>>>>>
>>>>> Finally, if I encounter any problems during ImageMosaic creation I
>>>>> ensure to:
>>>>> * set GeoServer logging to VERBOSE
>>>>> * drop any database table created (ImageMosaic will refuse to create
>>>>> store if a table with the same name already exists), along with index and
>>>>> metadata (if using Oracle)
>>>>> * try it again and look into the log (usually the problem is not
>>>>> revealed in the last stacktrace in the log, but in some before last)
>>>>> * if it doesn't help or I still cannot figure out what is wrong I
>>>>> launch Eclipse debugger and examine what EXACTLY is wrong (I used it a lot
>>>>> until I figured out how to properly configure time parsing regexes)
>>>>>
>>>>> Regards,
>>>>>
>>>>> Peter Kovac
>>>>>
>>>>>
>>>>>
>>>>> On 29. 9. 2017 10:40, Darell van der Voort wrote:
>>>>>
>>>>> Hi Peter,
>>>>>
>>>>> This is my indexer.properties configuration:
>>>>>
>>>>> Caching=false
>>>>> TimeAttribute=ingestion
>>>>> Schema=*the_geom:Polygon,location:String,ingestion:java.util
>>>>> .Date:Double
>>>>> PropertyCollectors=TimestampFileNameExtractorSPI[timeregex](ingestion)
>>>>>
>>>>> And this is my 0.properties which is automatically generated for the
>>>>> lowest zoomlevel (0):
>>>>>
>>>>> #-Automagically created from GeoTools-
>>>>> #Wed Sep 27 14:50:18 UTC 2017
>>>>> MosaicCRS=EPSG\:32617
>>>>> Levels=0.062,0.062
>>>>> Heterogeneous=false
>>>>> TimeAttribute=ingestion
>>>>> AbsolutePath=false
>>>>> Name=0
>>>>> TypeName=0
>>>>> Caching=false
>>>>> ExpandToRGB=false
>>>>> LocationAttribute=location
>>>>> SuggestedSPI=it.geosolutions.imageioimpl.plugins.tiff.TIFFIm
>>>>> ageReaderSpi
>>>>> CheckAuxiliaryMetadata=false
>>>>> LevelsNum=1
>>>>>
>>>>> So like I said, the plugin automatically configures level 0 to the
>>>>> PostgreSQL DB if I add the datastore.properties files, but refuses to do 
>>>>> so
>>>>> for other levels if I add the datastore.properties file to the folder
>>>>> levels. If I do not add the datastore.properties file to the additional
>>>>> levels, the plugin automatically creates a shapefile for these levels,
>>>>> while using the DB connection for level 0. This combination works, even
>>>>> with a time dimension. However I would like to use the DB connection for
>>>>> all levels and use unique table names in the DB.
>>>>>
>>>>> Kind regards,
>>>>> Darell
>>>>>
>>>>>
>>>>>
>>>>>
>>>>> On Fri, Sep 29, 2017 at 9:59 AM, Peter Kovac <
>>>>> peter.ko...@microstep-mis.com> wrote:
>>>>>
>>>>>> Hi Darell,
>>>>>>
>>>>>> can you post your indexer.xml configuration for the imagemosaic?
>>>>>>
>>>>>> Regards,
>>>>>>
>>>>>> Peter Kovac
>>>>>>
>>>>>> On 28. 9. 2017 9:59, Darell van der Voort wrote:
>>>>>>
>>>>>> Hello everybody,
>>>>>>
>>>>>> I'm running Geoserver 2.11.2 on Java 1.8.0_144 32 bits on Amazon
>>>>>> Linux together with Tomcat 9. The plugins I have installed are 
>>>>>> imagemosaic,
>>>>>> imagepyramid, GeowebCache (internal) and Geofence.
>>>>>>
>>>>>> When using the imagemosaic plugin I am able to use a Postgresql DB
>>>>>> for storing the granules and time dimension via a datastore.properties
>>>>>> file. The file looks like:
>>>>>>
>>>>>> SPI=org.geotools.data.postgis.PostgisNGJNDIDataStoreFactory
>>>>>> schema=database_schema_name
>>>>>> Loose\ bbox=true
>>>>>> Estimated\ extends=false
>>>>>> validate\ connections=true
>>>>>> Connection\ timeout=10
>>>>>> preparedStatements=true
>>>>>> jndiReferenceName=java:comp/env/jdbc/postgis
>>>>>>
>>>>>> Which work as expected. However when I add the same file in the
>>>>>> imagepyramid datastructure, this setup fails. When I add this
>>>>>> datastore.properties in just the lowest level (0) then that level gets
>>>>>> configured in a database table, while the higher levels are configured
>>>>>> using a shapefile. When I add a datastore.properties to all levels,
>>>>>> geoserver returns the following error:
>>>>>>
>>>>>> 2017-09-28 07:39:40,780 ERROR [gce.imagemosaic] -
>>>>>> java.io.IOException
>>>>>> at org.geotools.gce.imagemosaic.ImageMosaicConfigHandler.create
>>>>>> GranuleCatalogFromDatastore(ImageMosaicConfigHandler.java:406)
>>>>>> at org.geotools.gce.imagemosaic.ImageMosaicConfigHandler.create
>>>>>> Catalog(ImageMosaicConfigHandler.java:329)
>>>>>> at org.geotools.gce.imagemosaic.ImageMosaicConfigHandler.buildC
>>>>>> atalog(ImageMosaicConfigHandler.java:962)
>>>>>> at org.geotools.gce.imagemosaic.ImageMosaicConfigHandler.indexi
>>>>>> ngPreamble(ImageMosaicConfigHandler.java:941)
>>>>>> at org.geotools.gce.imagemosaic.ImageMosaicDirectoryWalker$Mosa
>>>>>> icDirectoryWalker.<init>(ImageMosaicDirectoryWalker.java:109)
>>>>>> at org.geotools.gce.imagemosaic.ImageMosaicDirectoryWalker.run(
>>>>>> ImageMosaicDirectoryWalker.java:197)
>>>>>> at org.geotools.gce.imagemosaic.Utils.createMosaic(Utils.java:460)
>>>>>> at org.geotools.gce.imagemosaic.Utils.checkSource(Utils.java:1336)
>>>>>> at org.geotools.gce.imagemosaic.ImageMosaicReader.initReaderFro
>>>>>> mURL(ImageMosaicReader.java:532)
>>>>>> at org.geotools.gce.imagemosaic.ImageMosaicReader.<init>(ImageM
>>>>>> osaicReader.java:479)
>>>>>> at org.geotools.gce.imagemosaic.ImageMosaicFormat.getReader(Ima
>>>>>> geMosaicFormat.java:504)
>>>>>> at org.geotools.gce.imagepyramid.Utils.checkSource(Utils.java:200)
>>>>>> at org.geotools.gce.imagepyramid.ImagePyramidReader.<init>(Imag
>>>>>> ePyramidReader.java:177)
>>>>>> at org.geotools.gce.imagepyramid.ImagePyramidFormat.getReader(I
>>>>>> magePyramidFormat.java:249)
>>>>>> at org.geotools.gce.imagepyramid.ImagePyramidFormat.getReader(I
>>>>>> magePyramidFormat.java:56)
>>>>>> at org.geoserver.catalog.ResourcePool.getGridCoverageReader(Res
>>>>>> ourcePool.java:1511)
>>>>>> at org.geoserver.catalog.ResourcePool.getGridCoverageReader(Res
>>>>>> ourcePool.java:1441)
>>>>>> at org.geoserver.catalog.impl.CoverageStoreInfoImpl.getGridCove
>>>>>> rageReader(CoverageStoreInfoImpl.java:59)
>>>>>> .....
>>>>>> at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.r
>>>>>> un(TaskThread.java:61)
>>>>>> at java.lang.Thread.run(Thread.java:748)
>>>>>> Caused by: java.lang.NullPointerException
>>>>>> at java.lang.Class.forName0(Native Method)
>>>>>> at java.lang.Class.forName(Class.java:264)
>>>>>> at org.geotools.gce.imagemosaic.ImageMosaicConfigHandler.create
>>>>>> GranuleCatalogFromDatastore(ImageMosaicConfigHandler.java:389)
>>>>>> ... 160 more
>>>>>>
>>>>>> Is it possible to configure the granules of all levels in the
>>>>>> database? And if so, how would my datastore.properties file look like? 
>>>>>> Like
>>>>>> I said, it works fine for the lowest level (0) but it fails for all the
>>>>>> levels above. If it may not be possible, is it sufficient to use the
>>>>>> shapefiles as an index for the granules? The geoserver is used in a
>>>>>> production environment and I am worried about performance issues when 
>>>>>> using
>>>>>> the shapefiles as index.
>>>>>>
>>>>>> Furthermore the imagepyramid automatically names the table after the
>>>>>> level folder (0). This folder and table name are automatically created 
>>>>>> when
>>>>>> configuring the datastore. Is there a way to custom name the folder and
>>>>>> thus the table name? Otherwise I could end up with multiple '0' tables in
>>>>>> the same schema.
>>>>>>
>>>>>> Many thanks!
>>>>>>
>>>>>> Kind regards,
>>>>>> Darell
>>>>>>
>>>>>>
>>>>>> ------------------------------------------------------------------------------
>>>>>> Check out the vibrant tech community on one of the world's most
>>>>>> engaging tech sites, Slashdot.org! http://sdm.link/slashdot
>>>>>>
>>>>>>
>>>>>>
>>>>>> _______________________________________________
>>>>>> Geoserver-users mailing list
>>>>>>
>>>>>> Please make sure you read the following two resources before posting to 
>>>>>> this list:
>>>>>> - Earning your support instead of buying it, but Ian Turton: 
>>>>>> http://www.ianturton.com/talks/foss4g.html#/
>>>>>> - The GeoServer user list posting guidelines: 
>>>>>> http://geoserver.org/comm/userlist-guidelines.html
>>>>>> Geoserver-users@lists.sourceforge.nethttps://lists.sourceforge.net/lists/listinfo/geoserver-users
>>>>>>
>>>>>>
>>>>>> --
>>>>>> Peter Kovac
>>>>>> IMS Programmer
>>>>>> microstep-mispeter.ko...@microstep-mis.com
>>>>>>
>>>>>>
>>>>>
>>>>> --
>>>>> Peter Kovac
>>>>> IMS Programmer
>>>>> microstep-mispeter.ko...@microstep-mis.com
>>>>>
>>>>>
>>>>
>>>> ------------------------------------------------------------
>>>> ------------------
>>>> Check out the vibrant tech community on one of the world's most
>>>> engaging tech sites, Slashdot.org! http://sdm.link/slashdot
>>>> _______________________________________________
>>>> Geoserver-users mailing list
>>>>
>>>> Please make sure you read the following two resources before posting to
>>>> this list:
>>>> - Earning your support instead of buying it, but Ian Turton:
>>>> http://www.ianturton.com/talks/foss4g.html#/
>>>> - The GeoServer user list posting guidelines:
>>>> http://geoserver.org/comm/userlist-guidelines.html
>>>>
>>>> Geoserver-users@lists.sourceforge.net
>>>> https://lists.sourceforge.net/lists/listinfo/geoserver-users
>>>>
>>>>
>>>
>>>
>>> --
>>> Regards,
>>> Daniele Romagnoli
>>> ==
>>> GeoServer Professional Services from the experts! Visit
>>> http://goo.gl/it488V for more information.
>>> ==
>>>
>>> Ing. Daniele Romagnoli
>>> Senior Software Engineer
>>>
>>> GeoSolutions S.A.S.
>>> Via di Montramito 3/A
>>> <https://maps.google.com/?q=Via+di+Montramito+3/A55054+%C2%A0Massarosa&entry=gmail&source=g>
>>> 55054  Massarosa
>>> <https://maps.google.com/?q=Via+di+Montramito+3/A55054+%C2%A0Massarosa&entry=gmail&source=g>
>>> (LU)
>>> Italy
>>> phone: +39 0584 962313 <+39%200584%20962313>
>>> fax:      +39 0584 1660272 <+39%200584%20166%200272>
>>>
>>> http://www.geo-solutions.it
>>> http://twitter.com/geosolutions_it
>>>
>>> -------------------------------------------------------
>>> AVVERTENZE AI SENSI DEL D.Lgs. 196/2003
>>> Le informazioni contenute in questo messaggio di posta elettronica e/o
>>> nel/i file/s allegato/i sono da considerarsi strettamente riservate. Il
>>> loro utilizzo è consentito esclusivamente al destinatario del messaggio,
>>> per le finalità indicate nel messaggio stesso. Qualora riceviate questo
>>> messaggio senza esserne il destinatario, Vi preghiamo cortesemente di
>>> darcene notizia via e-mail e di procedere alla distruzione del messaggio
>>> stesso, cancellandolo dal Vostro sistema. Conservare il messaggio stesso,
>>> divulgarlo anche in parte, distribuirlo ad altri soggetti, copiarlo, od
>>> utilizzarlo per finalità diverse, costituisce comportamento contrario ai
>>> principi dettati dal D.Lgs. 196/2003.
>>>
>>> The information in this message and/or attachments, is intended solely
>>> for the attention and use of the named addressee(s) and may be confidential
>>> or proprietary in nature or covered by the provisions of privacy act
>>> (Legislative Decree June, 30 2003, no.196 - Italy's New Data Protection
>>> Code).Any use not in accord with its purpose, any disclosure, reproduction,
>>> copying, distribution, or either dissemination, either whole or partial, is
>>> strictly forbidden except previous formal approval of the named
>>> addressee(s). If you are not the intended recipient, please contact
>>> immediately the sender by telephone, fax or e-mail and delete the
>>> information in this message that has been received in error. The sender
>>> does not give any warranty or accept liability as the content, accuracy or
>>> completeness of sent messages and accepts no responsibility  for changes
>>> made after they were sent or for other risks which arise as a result of
>>> e-mail transmission, viruses, etc.
>>>
>>>
>>
>
>
> --
> Regards,
> Daniele Romagnoli
> ==
> GeoServer Professional Services from the experts! Visit
> http://goo.gl/it488V for more information.
> ==
>
> Ing. Daniele Romagnoli
> Senior Software Engineer
>
> GeoSolutions S.A.S.
> Via di Montramito 3/A
> <https://maps.google.com/?q=Via+di+Montramito+3/A55054+%C2%A0Massarosa+%3Chttps://maps.google.com/?q%3DVia%2Bdi%2BMontramito%2B3/A55054%2B%25C2%25A0Massarosa%26entry%3Dgmail%26source%3Dg%3E&entry=gmail&source=g>
> 55054  Massarosa
> <https://maps.google.com/?q=Via+di+Montramito+3/A55054+%C2%A0Massarosa+%3Chttps://maps.google.com/?q%3DVia%2Bdi%2BMontramito%2B3/A55054%2B%25C2%25A0Massarosa%26entry%3Dgmail%26source%3Dg%3E&entry=gmail&source=g>
> (LU)
> Italy
> phone: +39 0584 962313 <+39%200584%20962313>
> fax:      +39 0584 1660272 <+39%200584%20166%200272>
>
> http://www.geo-solutions.it
> http://twitter.com/geosolutions_it
>
> -------------------------------------------------------
> AVVERTENZE AI SENSI DEL D.Lgs. 196/2003
> Le informazioni contenute in questo messaggio di posta elettronica e/o
> nel/i file/s allegato/i sono da considerarsi strettamente riservate. Il
> loro utilizzo è consentito esclusivamente al destinatario del messaggio,
> per le finalità indicate nel messaggio stesso. Qualora riceviate questo
> messaggio senza esserne il destinatario, Vi preghiamo cortesemente di
> darcene notizia via e-mail e di procedere alla distruzione del messaggio
> stesso, cancellandolo dal Vostro sistema. Conservare il messaggio stesso,
> divulgarlo anche in parte, distribuirlo ad altri soggetti, copiarlo, od
> utilizzarlo per finalità diverse, costituisce comportamento contrario ai
> principi dettati dal D.Lgs. 196/2003.
>
> The information in this message and/or attachments, is intended solely for
> the attention and use of the named addressee(s) and may be confidential or
> proprietary in nature or covered by the provisions of privacy act
> (Legislative Decree June, 30 2003, no.196 - Italy's New Data Protection
> Code).Any use not in accord with its purpose, any disclosure, reproduction,
> copying, distribution, or either dissemination, either whole or partial, is
> strictly forbidden except previous formal approval of the named
> addressee(s). If you are not the intended recipient, please contact
> immediately the sender by telephone, fax or e-mail and delete the
> information in this message that has been received in error. The sender
> does not give any warranty or accept liability as the content, accuracy or
> completeness of sent messages and accepts no responsibility  for changes
> made after they were sent or for other risks which arise as a result of
> e-mail transmission, viruses, etc.
>
>
------------------------------------------------------------------------------
Check out the vibrant tech community on one of the world's most
engaging tech sites, Slashdot.org! http://sdm.link/slashdot
_______________________________________________
Geoserver-users mailing list

Please make sure you read the following two resources before posting to this 
list:
- Earning your support instead of buying it, but Ian Turton: 
http://www.ianturton.com/talks/foss4g.html#/
- The GeoServer user list posting guidelines: 
http://geoserver.org/comm/userlist-guidelines.html

Geoserver-users@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/geoserver-users

Reply via email to