Sunday, May 01, 2011

Fixing MaxItemsInObjectGraph quota Error in WCF Service

I have a WCF Service that occasionally yields a message like this one:
Maximum number of items that can be serialized or deserialized in an object graph is '65536'. Change the object graph or increase the MaxItemsInObjectGraph quota.

Today isn’t the first time I’ve run into this message – I’ve fixed this issue before – but since this is the 2nd or more time I’ve run into it, I thought I’d post a quick resolution here so I can find it again later myself, and perhaps help some others.  There’s a rather long forum thread on this subject that ultimately includes the solution, but digging it out is a bit painful as is the case with so many forum threads, so I’ll sum up here and just give you what you need.

First, you need to realize that to resolve this issue you will need configuration elements to be specified on both the client and the server.  In both cases, the configuration you are looking for is going to be in a named <behavior> as part of a <dataContractSerializer> element.  Your service’s configuration might look like this:

<system.serviceModel> 
        <behaviors> 
            <serviceBehaviors> 
                <behavior name="DefaultBehavior" MaxItemsInObjectGraph="2147483647"> 
                    <dataContractSerializer maxItemsInObjectGraph="2147483647" /> 
                    <serviceMetadata httpGetEnabled="true" /> 
                    <serviceDebug includeExceptionDetailInFaults="true" /> 
                </behavior> 
            </serviceBehaviors> 
        </behaviors> 
        <services> 
            <service behaviorConfiguration="DefaultBehavior" name="MyService"> 
                <endpoint address="" binding="wsHttpBinding" bindingConfiguration="WSHttpBinding_MyService" contract="IMyService"> 
                    <identity> 
                        <dns value="localhost" /> 
                    </identity> 
                </endpoint> 
                <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" /> 
            </service> 
         </services> 
    </system.serviceModel>

I notice that my <behavior /> specifies a MaxItemsInObjectGraph value but I don’t know that that is necessary.  I’ve left it here since it’s what I actually have working in production, but the solution I found online only indicates the need for the dataContractSerializer maxItemsInObjectGraph (note case) value.  For the client, the configuration should look like this:

<system.serviceModel> 
    <behaviors> 
    <endpointBehaviors> 
        <behavior name="ClientBehavior"> 
            <dataContractSerializer maxItemsInObjectGraph="2147483647"/> 

Read more: Steve Smith