如何关闭requests.Session()?

时间:2018-03-13 10:02:51

标签: python session https get python-requests

我正在尝试关闭requests.Session(),但它没有关闭。

s = requests.Session()
s.verify = 'cert.pem'
res1 = s.get("https://<ip>:<port>/<route>")
s.close() #Not working
res2 = s.get("https://<ip>:<port>/<route>") # this is still working which means s.close() didn't work.

如何关闭会话? s.close()也没有抛出任何错误,这意味着它是一个有效的语法,但我不明白它到底在做什么。

1 个答案:

答案 0 :(得分:2)

requests的源代码中,Session.close仅关闭所有基础Adapter。进一步关闭Adapter正在清除基础PoolManager。然后全部 此PoolManager中已建立的连接将被关闭。但是,如果没有可用的连接,PoolManager将创建一个全新的连接。

关键代码:

# requests.Session
def close(self):
    """Closes all adapters and as such the session"""
    for v in self.adapters.values():
        v.close()

# requests.adapters.HTTPAdapter
def close(self):
    """Disposes of any internal state.

    Currently, this closes the PoolManager and any active ProxyManager,
    which closes any pooled connections.
    """
    self.poolmanager.clear()
    for proxy in self.proxy_manager.values():
        proxy.clear()

# urllib3.poolmanager.PoolManager
def connection_from_pool_key(self, pool_key, request_context=None):
    """
    Get a :class:`ConnectionPool` based on the provided pool key.

    ``pool_key`` should be a namedtuple that only contains immutable
    objects. At a minimum it must have the ``scheme``, ``host``, and
    ``port`` fields.
    """
    with self.pools.lock:
        # If the scheme, host, or port doesn't match existing open
        # connections, open a new ConnectionPool.
        pool = self.pools.get(pool_key)
        if pool:
            return pool

        # Make a fresh ConnectionPool of the desired type
        scheme = request_context['scheme']
        host = request_context['host']
        port = request_context['port']
        pool = self._new_pool(scheme, host, port, request_context=request_context)
        self.pools[pool_key] = pool

    return pool

因此,如果我很好地了解其结构,当您关闭Session时,您几乎与创建新Session并将其分配给旧版CriteriaBuilder criteriaBuilder = em.getCriteriaBuilder(); CriteriaQuery<User> criteriaQuery = criteriaBuilder.createQuery(User.class); Root<User> rootUser = criteriaQuery.from(User.class); List<Predicate> predList = new ArrayList<Predicate>(); Join<User, User> selfJoin = rootUser.join("userId", JoinType.LEFT); //not sure about this line predList.add(criteriaBuilder.equal(selfJoin.<String>get("userId"), supervisorId)); //supervisorId is the id of the supervisor that I want to find TypedQuery<User> typedQuery = em.createQuery(criteriaQuery); List<User> resultList = typedQuery.getResultList(); 相同。所以你仍然可以用它来发送请求。

或者,如果我误解了任何事情,欢迎纠正我:D