Закрыть сокетное соединение в request.js - PullRequest
0 голосов
/ 12 ноября 2018

У меня есть программа, которая использует модуль запроса для получения HTML.

Существует ли способ вручную закрыть сокетное соединение после получения ответа, отличного от прерывания, а также удалить всех прослушивателей из этого конкретного экземпляра запроса.

Основная проблема заключается в том, что, поскольку программа продолжает делать запросы, число файловых дескрипторов и прослушивателей продолжает расти, независимо от использования abort () после завершения выборки.

Наконец, программа завершает работу после достижения размера maxListeners, который уже установлен на 20000.

const request=require('request')
fetchUrl (params, tag, callBack) {
    this.url = params.url
    this.tag = tag
    let headers = { 'User-Agent': params.useragent }
    let options = { followRedirects: false, keepAlive: false, url: params.url, headers: headers, gzip: true, encoding: null }
    let proxy = 'None'
    let userAgent = params.useragent
    
    if (parseInt(ConfigHandler.getConfig().spfUseProxy) === 1) {
      if (parseInt(ConfigHandler.getConfig().spfUseHermesUserAgent) === 1) {
        userAgent = params.useragent + ' Hughes-PFB/' +
          params.agentid + '/' + params.tracetags
        headers['User-Agent'] = userAgent
        headers['Connection'] = 'Close'
      }
      
      proxy = 'http://' + ConfigHandler.getConfig().iosPrefetchProxyIp +
        ':' + ConfigHandler.getConfig().iosPrefetchProxyPort
      options['proxy'] = proxy
    }

    this.httpClient = request.get(options, (err, response, body) => {
      let result = {}
      if (!err) {
        this.response = response
        this.bodyLen = body.length
        logger.debug('%s Response info, %s', this.tag, this.resourceInfo())
        result = {
          statuscode: response.statusCode,
          headers: response.headers,
          body: body
        }
      } else {
        logger.error('%s, fetchUrl() failed! cause=%s, url=%s', JSON.stringify(this), err.message,
          this.url)
      }
      
      if (this.httpClient) {
           logger.debug('%s, fetchUrl() ending connection!', JSON.stringify(this.httpClient))
          this.httpClient.abort()
        }
        if (response && response.socket)         {
          response.socket.destroy()
        } 
      callBack(result, err)
    })
  }

  cancelFetch () {
    if (this.httpClient) {
      logger.debug('%s, Cancelling fetch for url=%s', this.tag, this.url)
      this.httpClient.abort()
      this.httpClient = null
      this.url = null
    }
  this.response.socket.removeAllListeners()
    }
  }

  close () {
    if (this.response && this.response.socket) {

      this.response.socket.destroy()
      //logger.debug('%s, close(), after socket.destroy(), statusTCP=%s', JSON.stringify(this.response), this.response.socket)
    }
    if (this.httpClient) {
      logger.debug('%s, Closing HTTP connection for url=%s', this.tag, this.url)
      this.httpClient.abort()
      this.httpClient = null
      this.url = null
      this.response = null
    }
  }
...