[Mapserver-dev] RE: [UMN_MAPSERVER-USERS] Oracle Spatial Performance
Smith, Michael ERDC-CRREL-NH
Michael.Smith at erdc.usace.army.mil
Sun Sep 26 14:38:55 EDT 2004
This message is in MIME format. Since your mail reader does not understand
this format, some or all of this message may not be legible.
------_=_NextPart_001_01C4A3F7.F6FEF972
Content-Type: text/plain;
charset="iso-8859-1"
Content-Transfer-Encoding: quoted-printable
I don't see one, and we have recommended this change before I believe.=20
Mike Smith
-----Original Message-----
From: Paul Ramsey
To: Smith, Michael ERDC-CRREL-NH
Cc: mapserver-dev at lists.gis.umn.edu
Sent: 9/26/2004 10:45 AM
Subject: Re: [UMN_MAPSERVER-USERS] Oracle Spatial Performance
Any reason not to simply apply this change to the standard source?
On Sunday, September 26, 2004, at 05:47 AM, Smith, Michael =20
ERDC-CRREL-NH wrote:
> It is also very important for performance reasons to increase the =20
> array size in maporaclespatial.c and recompile. We generally =
recommend
> setting array size to ~ 1000. We generally see an order of magnitude =
> increase in speed with this change.
>
> Mike Smith
> USACE-CRREL
> Remote Sensing GIS Center of Expertise
> Hanover, NH
>
> -----Original Message-----
> From: Frank Warmerdam
> To: MAPSERVER-USERS at LISTS.UMN.EDU
> Sent: 9/25/2004 7:34 PM
> Subject: Re: [UMN_MAPSERVER-USERS] Oracle Spatial Performance
>
> Vladimir Guzm=E1n wrote:
> > Hello, List.
> >
> > I don't know if this is an off-topic question but, I really need
some
> help.
> > I've worked a lot with mapserver, specially with phpmapscript, and
> with
> > shape files and postgis data.
> > Finally, about 6 months ago, we received a request from a customer
in
> > order to develop a web application that would be able to connect
with
> > oracle data.
> > Well, after face all kinds of issues with oracle spatial, =
everything
> is
> > working fine now.=A0 Except the speed.
> > Every map request to oracle spatial takes at least 20 seconds, with
> very
> > small geometries, and in some cases it takes 2 minutes or more.
> > I would like you to give me some clue, because I've worked with
> postgis
> > and shps and I've never had this kind of problems.
> > All the geometries are indexed.
> > The time responses are almost the same working with ORACLESPATIAL
and
> > OGR connection.
> >
> > For example:
> > The command:
> > ogrinfo OCI:xxx/xxx at xxx -sql "SELECT ID, ORA_GEOMETRY, NOMBRE FROM
> > SIG_DEPTOS"
> > Takes 1 minute.
> > The same geometry in shp:
> > ogrinfo -al departamentos.shp
> > Takes less than one second.
>
> Vladimir,
>
> I can think of a couple of issues.
>
> First, the connection overhead to Oracle tends to be pretty =
expensive.
> In my work it was several seconds to a local Oracle instance.=A0 When
> using
> MapServer in "cgi" mode where a new process is forked and needs to
> connect
> to Oracle for each map request the extra overhead can be quite
> devestating.
> The presume solution to this is to keep the process resident, for
> instance
> by using FastCGI and caching the oracle connection.=A0 This is =
currently
> not supported by MapServer, but I am working on FastCGI support again
> on
> behalf of Refractions and so a solution may become available in the
> coming
> months.
>
> Second, by default OGR will collect schema information from all the
> tables (or at least spatial tables) in your database. This can be =
very
> expensive for a database with alot of tables.=A0 However, this issue =
is
> unique to OGR connections to Oracle, and should not occur with the
more
> direct Oracle support in MapServer.
>
> Best regards,
> --
> ---------------------------------------=20
> +--------------------------------
> ------
> I set the clouds in motion - turn up=A0=A0 | Frank Warmerdam,
> warmerdam at pobox.com
> light and sound - activate the windows | http://pobox.com/~warmerdam
> and watch the world go round - Rush=A0=A0=A0 | Geospatial Programmer =
for
Rent
>
>
Paul Ramsey
Refractions Research
Email: pramsey at refractions.net
Phone: (250) 885-0632
------_=_NextPart_001_01C4A3F7.F6FEF972
Content-Type: text/html;
charset="iso-8859-1"
Content-Transfer-Encoding: quoted-printable
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2//EN">
<HTML>
<HEAD>
<META HTTP-EQUIV=3D"Content-Type" CONTENT=3D"text/html; =
charset=3Diso-8859-1">
<META NAME=3D"Generator" CONTENT=3D"MS Exchange Server version =
5.5.2655.35">
<TITLE>RE: [UMN_MAPSERVER-USERS] Oracle Spatial Performance</TITLE>
</HEAD>
<BODY>
<P><FONT SIZE=3D2>I don't see one, and we have recommended this change =
before I believe. </FONT>
</P>
<P><FONT SIZE=3D2>Mike Smith</FONT>
</P>
<P><FONT SIZE=3D2>-----Original Message-----</FONT>
<BR><FONT SIZE=3D2>From: Paul Ramsey</FONT>
<BR><FONT SIZE=3D2>To: Smith, Michael ERDC-CRREL-NH</FONT>
<BR><FONT SIZE=3D2>Cc: mapserver-dev at lists.gis.umn.edu</FONT>
<BR><FONT SIZE=3D2>Sent: 9/26/2004 10:45 AM</FONT>
<BR><FONT SIZE=3D2>Subject: Re: [UMN_MAPSERVER-USERS] Oracle Spatial =
Performance</FONT>
</P>
<P><FONT SIZE=3D2>Any reason not to simply apply this change to the =
standard source?</FONT>
</P>
<P><FONT SIZE=3D2>On Sunday, September 26, 2004, at 05:47 AM, Smith, =
Michael </FONT>
<BR><FONT SIZE=3D2>ERDC-CRREL-NH wrote:</FONT>
</P>
<P><FONT SIZE=3D2>> It is also very important for performance =
reasons to increase the </FONT>
<BR><FONT SIZE=3D2>> array size in maporaclespatial.c and recompile. =
We generally recommend</FONT>
</P>
<P><FONT SIZE=3D2>> setting array size to ~ 1000. We generally see =
an order of magnitude </FONT>
<BR><FONT SIZE=3D2>> increase in speed with this change.</FONT>
<BR><FONT SIZE=3D2>></FONT>
<BR><FONT SIZE=3D2>> Mike Smith</FONT>
<BR><FONT SIZE=3D2>> USACE-CRREL</FONT>
<BR><FONT SIZE=3D2>> Remote Sensing GIS Center of Expertise</FONT>
<BR><FONT SIZE=3D2>> Hanover, NH</FONT>
<BR><FONT SIZE=3D2>></FONT>
<BR><FONT SIZE=3D2>> -----Original Message-----</FONT>
<BR><FONT SIZE=3D2>> From: Frank Warmerdam</FONT>
<BR><FONT SIZE=3D2>> To: MAPSERVER-USERS at LISTS.UMN.EDU</FONT>
<BR><FONT SIZE=3D2>> Sent: 9/25/2004 7:34 PM</FONT>
<BR><FONT SIZE=3D2>> Subject: Re: [UMN_MAPSERVER-USERS] Oracle =
Spatial Performance</FONT>
<BR><FONT SIZE=3D2>></FONT>
<BR><FONT SIZE=3D2>> Vladimir Guzm=E1n wrote:</FONT>
<BR><FONT SIZE=3D2>> > Hello, List.</FONT>
<BR><FONT SIZE=3D2>> ></FONT>
<BR><FONT SIZE=3D2>> > I don't know if this is an off-topic =
question but, I really need</FONT>
<BR><FONT SIZE=3D2>some</FONT>
<BR><FONT SIZE=3D2>> help.</FONT>
<BR><FONT SIZE=3D2>> > I've worked a lot with mapserver, =
specially with phpmapscript, and</FONT>
<BR><FONT SIZE=3D2>> with</FONT>
<BR><FONT SIZE=3D2>> > shape files and postgis data.</FONT>
<BR><FONT SIZE=3D2>> > Finally, about 6 months ago, we received a =
request from a customer</FONT>
<BR><FONT SIZE=3D2>in</FONT>
<BR><FONT SIZE=3D2>> > order to develop a web application that =
would be able to connect</FONT>
<BR><FONT SIZE=3D2>with</FONT>
<BR><FONT SIZE=3D2>> > oracle data.</FONT>
<BR><FONT SIZE=3D2>> > Well, after face all kinds of issues with =
oracle spatial, everything</FONT>
<BR><FONT SIZE=3D2>> is</FONT>
<BR><FONT SIZE=3D2>> > working fine now.=A0 Except the =
speed.</FONT>
<BR><FONT SIZE=3D2>> > Every map request to oracle spatial takes =
at least 20 seconds, with</FONT>
<BR><FONT SIZE=3D2>> very</FONT>
<BR><FONT SIZE=3D2>> > small geometries, and in some cases it =
takes 2 minutes or more.</FONT>
<BR><FONT SIZE=3D2>> > I would like you to give me some clue, =
because I've worked with</FONT>
<BR><FONT SIZE=3D2>> postgis</FONT>
<BR><FONT SIZE=3D2>> > and shps and I've never had this kind of =
problems.</FONT>
<BR><FONT SIZE=3D2>> > All the geometries are indexed.</FONT>
<BR><FONT SIZE=3D2>> > The time responses are almost the same =
working with ORACLESPATIAL</FONT>
<BR><FONT SIZE=3D2>and</FONT>
<BR><FONT SIZE=3D2>> > OGR connection.</FONT>
<BR><FONT SIZE=3D2>> ></FONT>
<BR><FONT SIZE=3D2>> > For example:</FONT>
<BR><FONT SIZE=3D2>> > The command:</FONT>
<BR><FONT SIZE=3D2>> > ogrinfo OCI:xxx/xxx at xxx -sql "SELECT =
ID, ORA_GEOMETRY, NOMBRE FROM</FONT>
<BR><FONT SIZE=3D2>> > SIG_DEPTOS"</FONT>
<BR><FONT SIZE=3D2>> > Takes 1 minute.</FONT>
<BR><FONT SIZE=3D2>> > The same geometry in shp:</FONT>
<BR><FONT SIZE=3D2>> > ogrinfo -al departamentos.shp</FONT>
<BR><FONT SIZE=3D2>> > Takes less than one second.</FONT>
<BR><FONT SIZE=3D2>></FONT>
<BR><FONT SIZE=3D2>> Vladimir,</FONT>
<BR><FONT SIZE=3D2>></FONT>
<BR><FONT SIZE=3D2>> I can think of a couple of issues.</FONT>
<BR><FONT SIZE=3D2>></FONT>
<BR><FONT SIZE=3D2>> First, the connection overhead to Oracle tends =
to be pretty expensive.</FONT>
<BR><FONT SIZE=3D2>> In my work it was several seconds to a local =
Oracle instance.=A0 When</FONT>
<BR><FONT SIZE=3D2>> using</FONT>
<BR><FONT SIZE=3D2>> MapServer in "cgi" mode where a new =
process is forked and needs to</FONT>
<BR><FONT SIZE=3D2>> connect</FONT>
<BR><FONT SIZE=3D2>> to Oracle for each map request the extra =
overhead can be quite</FONT>
<BR><FONT SIZE=3D2>> devestating.</FONT>
<BR><FONT SIZE=3D2>> The presume solution to this is to keep the =
process resident, for</FONT>
<BR><FONT SIZE=3D2>> instance</FONT>
<BR><FONT SIZE=3D2>> by using FastCGI and caching the oracle =
connection.=A0 This is currently</FONT>
<BR><FONT SIZE=3D2>> not supported by MapServer, but I am working on =
FastCGI support again</FONT>
</P>
<P><FONT SIZE=3D2>> on</FONT>
<BR><FONT SIZE=3D2>> behalf of Refractions and so a solution may =
become available in the</FONT>
<BR><FONT SIZE=3D2>> coming</FONT>
<BR><FONT SIZE=3D2>> months.</FONT>
<BR><FONT SIZE=3D2>></FONT>
<BR><FONT SIZE=3D2>> Second, by default OGR will collect schema =
information from all the</FONT>
<BR><FONT SIZE=3D2>> tables (or at least spatial tables) in your =
database. This can be very</FONT>
<BR><FONT SIZE=3D2>> expensive for a database with alot of =
tables.=A0 However, this issue is</FONT>
<BR><FONT SIZE=3D2>> unique to OGR connections to Oracle, and should =
not occur with the</FONT>
<BR><FONT SIZE=3D2>more</FONT>
<BR><FONT SIZE=3D2>> direct Oracle support in MapServer.</FONT>
<BR><FONT SIZE=3D2>></FONT>
<BR><FONT SIZE=3D2>> Best regards,</FONT>
<BR><FONT SIZE=3D2>> --</FONT>
<BR><FONT SIZE=3D2>> --------------------------------------- </FONT>
<BR><FONT SIZE=3D2>> +--------------------------------</FONT>
<BR><FONT SIZE=3D2>> ------</FONT>
<BR><FONT SIZE=3D2>> I set the clouds in motion - turn up=A0=A0 | =
Frank Warmerdam,</FONT>
<BR><FONT SIZE=3D2>> warmerdam at pobox.com</FONT>
<BR><FONT SIZE=3D2>> light and sound - activate the windows | <A =
HREF=3D"http://pobox.com/~warmerdam" =
TARGET=3D"_blank">http://pobox.com/~warmerdam</A></FONT>
<BR><FONT SIZE=3D2>> and watch the world go round - Rush=A0=A0=A0 | =
Geospatial Programmer for</FONT>
<BR><FONT SIZE=3D2>Rent</FONT>
<BR><FONT SIZE=3D2>></FONT>
<BR><FONT SIZE=3D2>></FONT>
<BR><FONT SIZE=3D2> Paul Ramsey</FONT>
<BR><FONT SIZE=3D2> Refractions =
Research</FONT>
<BR><FONT SIZE=3D2> Email: =
pramsey at refractions.net</FONT>
<BR><FONT SIZE=3D2> Phone: (250) =
885-0632</FONT>
</P>
</BODY>
</HTML>
------_=_NextPart_001_01C4A3F7.F6FEF972--
More information about the mapserver-dev
mailing list