Publishing and using a geoprocessing model within a map document

One of the exciting new aspects of ArcGIS Server 9.2 is the ability to publish geoprocessing models and scripts to the server.  A model can be published either as a tool that can be used directly on top of any map service, or it can be published with an associated map service so that you can control the symbology of the generated layer. 

 

To illustrate the power of geoprocessing on the server, I built an example that uses a map service and an embedded model that allows users to execute an interpolation on the server and view those results in the web mapping application.  The map service contains a point dataset describing the potential water yield from water wells drilled in Douglas County, Kansas (data courtesy of the Kansas Geological Survey and the Kansas Geospatial Community Commons).  The model takes in the water well dataset and a user-defined cell size.  This information is passed as input parameters to the Natural Neighbors GP tool.  The output is a raster dataset.  The output is then rendered using a predefined layer symbology file (a layer file).

 

 

If you looked closely, you may have noticed that the model includes an embedded Python script.  This script allows me to put a limit on the input cell size parameter.  I want to allow the user to set the cell size (in meters) of the output raster dataset from within the web application.  However, I want to make sure that the user does not enter so small of a cell size that it will negatively affect the speed of the web application.  The script ensures that if the user enters anything less than 30 meters, the application will default to a cell size of 30 meters.  I will have more on this in a future post. 

 

Here are some key steps to remember when publishing a geoprocessing tool embedded in a map service.

 

  • Create an MXD with the input layer and any other background layers that you want in your map service.
  • Create a toolbox in your project directory.
  • Add a new model to your new toolbox.
  • The model should use one of the layers in the map document as an input parameter.
  • Ensure that your map document and input map layers are at the same projection.
  • Your output dataset should be written to the scratch workspace.
  • Set your toolbox scratch workspace environment variable equal to a directory that is visible to your ArcGIS Server Object Container (SOC) account.
  • Move your finished model to your ArcMap table of contents. This is called a tool layer.
  • Execute the model from within ArcMap and verify the results.
  • Turn off the output layer in ArcMap and publish to the server.

 

The easiest way to publish a map service with an embedded geoprocessing service is to publish the map document (using the right-click option on the map document, “Publish to ArcGIS Server”).  ArcGIS Server will see that the map service has a tool layer and will load that tool as a geoprocessing service. 

 

Once deployed to the server, it is relatively straightforward to deploy the map service and associated geoprocessing task as a web application using ArcGIS Server Manager. 

 

Check it out here:  http://serverx.esri.com/interpolationexample

 

Try building and publishing your own models.

 

What do you think?

Jeremy

This entry was posted in Services and tagged , , . Bookmark the permalink.

Leave a Reply

6 Comments

  1. grocha says:

    Hi Jeremy,

    I think your examples help us so much.
    What do you think become avaliable the source (all codes like .py, Microsoft Visual Studio Solution, .tbx…) of the examples?

    Thanks!

  2. Mapor says:

    Jeremy,

    The Interpolated results layer has a Transparency look, this is an autmotatic process , or you can set it in the Model Builder?

  3. Jeremy says:

    @grocha
    The python script is under the Python Script link above. I will try and post most examples for download in future posts. Thanks for the comments!

    @Mapor
    In this case transparency is handled by the ADF. There is a transparency setting in Geoprocessing task properties that I have set at 35. But, you could also set transparency in the layer file that you use to symbolize the raster output.

    Cheers,
    Jeremy

  4. Jeremy says:

    Thanks Dave! Look for more raster processing in the future.

    Cheers,
    Jeremy

  5. leo_montero says:

    I canĀ“t get this application running, the model works fine for me in ArcMap but in ArcGIS server it doesn’t show the results.

    Could anyone upload the source (mxd, tbx, etc) of the example?

    Thanks in advance …

  6. vojvod says:

    Hi leo_montero

    Did you find the solution? Because I have the same problem.

    Thanks