WCF 超出最大配额(65536)

今天通过WCF连接数据库拉取500条数据报出这个错误,百度问题发现大部分解决办法都是修改App.config的’ServiceModel`参数,如下

<bindings>
      <basicHttpBinding>
        <binding name="webIn" sendTimeout="00:30:00"  maxBufferPoolSize="2147483647" maxReceivedMessageSize="2147483647" maxBufferSize="2147483647" transferMode="Streamed">
          <readerQuotas maxDepth="32" maxStringContentLength="2147483647"  maxArrayLength="2147483647" maxBytesPerRead="2147483647" maxNameTableCharCount="2147483647"/>
          <security mode="None"/>
        </binding>

      </basicHttpBinding>
      <netTcpBinding>
        <binding name="NetTcpBinding_IMysqlInfo" transferMode="Streamed" maxBufferPoolSize="2147483647" maxBufferSize="2147483647" maxReceivedMessageSize="2147483647">
          <security mode="None">
          </security>
        </binding>
      </netTcpBinding>
    </bindings>

再修改完这个的时候发现还是报错,于是检查我的启动项

public Post() => _mysqlService = ChannelFactory<IMysqlInfo>.CreateChannel(new BasicHttpBinding(),new EndpointAddress("http://localhost:8084/MySqlInfo.svc") );

觉得应该是初始化WCF之后,会将配置文件中的内容忽视,所以依旧报错,如果需要解决错误只需要降配置加到初始化中即可

/// <summary>
        /// initial
        /// </summary>
        public Post() => _mysqlService = ChannelFactory<IMysqlInfo>.CreateChannel(new BasicHttpBinding()
        {
            MaxBufferPoolSize = 2147483647,
            MaxReceivedMessageSize = 2147483647,
            MaxBufferSize = 2147483647
        },new EndpointAddress("http://localhost:8084/MySqlInfo.svc") );

这样的话就可以解决依旧报错的问题

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值