[PYTHON-CRYPTO] m2crypto - close_wait when running echod_async

Ng Pheng Siong ngps at POST1.COM
Fri Jun 25 19:43:11 CEST 2004


On Wed, Jun 23, 2004 at 04:03:28PM +0200, Andre Reitz wrote:
> is it legal to use the standard select method on the underlying socket of a
> m2crypto SSL.Connection Object,
> or are there problems bacause of the ssl-protocol lying on the socket?

Ah, I misread your question earlier. Yes it is okay to use select to
test the underlying socket. However, you must use SSL's read/write
functions (i.e., SSL.Connection's read/write methods) when select indicates
the socket is readable/writeable respectively.

This is because the SSL protocol adds crypto overhead to your data; when
select reports that the socket is writeable, say, SSL might need to _read_
and write stuff over the wire that is SSL-specific and has nothing to do
with your data, and the SSL functions handle this properly.

Also take a look at contrib/dave.README, from Dave Brueck in 2002:

    The ssl_connect, ssl_read_nbio, etc. calls don't differentiate between
    SSL_ERROR_WANT_WRITE and SSL_ERROR_WANT_READ when a non-blocking call
    couldn't finish. But without this information, I don't know whether the
    socket needs to do more reading or more writing before a subsequent
    attempt will work without blocking. The demo applications (e.g.
    echod-async.py) don't seem to care about this but they get around it by
    simply trying the operation over and over again, which I can't do for
    performance reasons.

I use ZServerSSL over the net and haven't encountered any performance
problems. I was asking Dave if he has more info on the improvement in
performance, but our email conversation kinda petered out.

Cheers.

--
Ng Pheng Siong <ngps at netmemetic.com>

http://firewall.rulemaker.net     -+- Firewall Version Control
http://sandbox.rulemaker.net/ngps -+- M2Crypto, ZServerSSL/Zope, Blog



More information about the python-crypto mailing list