Python 2.6.4 - Urllib2 - Windows XP - Reading streaming HTTP source kills network card ... (believe it or not)

MRAB python at mrabarnett.plus.com
Tue Jan 12 15:23:20 EST 2010


Sandy Walsh wrote:
> This is very odd. Hopefully someone can shed some insight. I've tried 
> this with Python 2.5.2 and recently upgraded to 2.6.4 and see the same 
> problem.
> 
> I'm running on Windows XP sp3. I'm interfacing with an IP camera that 
> streamed jpeg frames at 10fps over HTTP.
> 
> The format of the stream is:
> 
> 4 bytes - size of the frame N
> N bytes - the jpeg frame
> 
> I have the following program to read the data. It works fine for about 
> 30-40 iterations and then my NIC dies. All connectivity to the outside 
> world goes away until I need to reboot. So, first I thought it was a 
> driver problem. I've replaced the NIC, tried other drivers, you name it 
> ... same problem.
> 
> I've tried it on another machine and while it doesn't take down the NIC, 
> all communications to the camera after a while fail with "connection 
> reset by peer" exception.
> 
> The camera attempts to keep sending frame after frame (one every 100ms), 
> but I'm only interested in the first frame. After I grab it I kill the 
> connection to the camera. There is still data coming in. I assume it's 
> in HTTP Chunked format, but have not put Wireshark on it yet. I suspect 
> Python doesn't like me killing the connection when there is still data 
> coming down ... but why would it take down my NIC too?
> 
> The code is very simple:
> 
> #-------------------------------------
> import urllib2
> import struct
> import time
> import datetime
> 
> ip='192.168.1.189'
> username='user'
> password='password'
> 
> password_mgr = urllib2.HTTPPasswordMgrWithDefaultRealm()
> top_level_url = "http://%s" % ip
> password_mgr.add_password(None, top_level_url, username, password)
> 
> handler = urllib2.HTTPBasicAuthHandler(password_mgr)
> 
> opener = urllib2.build_opener(handler)
> urllib2.install_opener(opener)
> 
> url = "http://%s/user/img_stream0.cgi" % (ip, )
> 
> while 1:
>     response = urllib2.urlopen(url)
> 
>     size_bytes = response.read(4)
>     size, = struct.unpack("i", size_bytes)
> 
>     frame = response.read(size)
>     response.close()
> 
>     print "Got ", datetime.datetime.now()
>     time.sleep(1)
> #-------------------------------------
> 
> Which gives the following output:
> 
> testpull.py
> Got  2010-01-12 15:30:08.125000
> Got  2010-01-12 15:30:09.453000
> Got  2010-01-12 15:30:10.812000
> Got  2010-01-12 15:30:12.156000
> Got  2010-01-12 15:30:13.515000
> Got  2010-01-12 15:30:14.890000
> Got  2010-01-12 15:30:16.265000
> Got  2010-01-12 15:30:17.625000
> Got  2010-01-12 15:30:19.031000
> Got  2010-01-12 15:30:20.390000
> Got  2010-01-12 15:30:21.765000
> Got  2010-01-12 15:30:23.093000
> Got  2010-01-12 15:30:24.437000
> Got  2010-01-12 15:30:25.765000
> Got  2010-01-12 15:30:27.109000
> Got  2010-01-12 15:30:28.750000
> Got  2010-01-12 15:30:30.078000
> Got  2010-01-12 15:30:31.437000
> Got  2010-01-12 15:30:32.781000
> Got  2010-01-12 15:30:34.546000
> Got  2010-01-12 15:30:35.906000
> Got  2010-01-12 15:30:37.250000
> Got  2010-01-12 15:30:38.609000
> Got  2010-01-12 15:30:39.953000
> Got  2010-01-12 15:30:41.281000
> Got  2010-01-12 15:30:42.578000
> Got  2010-01-12 15:30:43.921000
> Got  2010-01-12 15:30:45.250000
> Got  2010-01-12 15:30:46.562000
> Got  2010-01-12 15:30:47.890000
> Got  2010-01-12 15:30:49.265000
> Got  2010-01-12 15:30:50.625000
> Got  2010-01-12 15:30:51.968000
> Got  2010-01-12 15:30:53.328000
> Got  2010-01-12 15:30:54.734000
> Traceback (most recent call last):
>   File "C:\dev\5110Snapshot\testpull.py", line 22, in <module>
>     response = urllib2.urlopen(url)
>   File "C:\Python26\lib\urllib2.py", line 124, in urlopen
>     return _opener.open(url, data, timeout)
>   File "C:\Python26\lib\urllib2.py", line 389, in open
>     response = self._open(req, data)
>   File "C:\Python26\lib\urllib2.py", line 407, in _open
>     '_open', req)
>   File "C:\Python26\lib\urllib2.py", line 367, in _call_chain
>     result = func(*args)
>   File "C:\Python26\lib\urllib2.py", line 1146, in http_open
>     return self.do_open(httplib.HTTPConnection, req)
>   File "C:\Python26\lib\urllib2.py", line 1121, in do_open
>     raise URLError(err)
> urllib2.URLError: <urlopen error [Errno 10060] A connection attempt 
> failed because the connected party did not properly
> respond after a period of time, or established connection failed because 
> connected host has failed to respond>
> 
> At which point all connectivity on the PC is dead.
> 
> This is truly bizarre.
> 
> Anyone have any insights as to what might be happening. Or is there 
> something blatantly wrong with my code?
> 
> Help!
> 
Have you tried keeping the connection open and just reading and
discarding the frames you don't want?



More information about the Python-list mailing list