官术网_书友最值得收藏!

Support from httpstat.us and simulation in Python

In addition to different options for status codes, the httpstat.us website additionally provides a way to simulate a delay in its response when we send in requests. Specifically, we can customize the delay time (in milliseconds) with a query argument in our GET request. For example, httpstat.us/200?sleep=5000 will return a response after five seconds of delay.

Now, let us see how a delay like this would affect the execution of our program. Consider the Chapter05/example5.py file, which contains the current request logic of our ping test application but has a different URL list:

# Chapter05/example5.py

import threading
import requests

class MyThread(threading.Thread):
def __init__(self, url):
threading.Thread.__init__(self)
self.url = url
self.result = None

def run(self):
res = requests.get(self.url)
self.result = f'{self.url}: {res.text}'

urls = [
'http://httpstat.us/200',
'http://httpstat.us/200?sleep=20000',
'http://httpstat.us/400'
]

threads = [MyThread(url) for url in urls]
for thread in threads:
thread.start()
for thread in threads:
thread.join()
for thread in threads:
print(thread.result)

print('Done.')

Here we have a URL that will take around 20 seconds to return a response. Considering that we will block the main program until all threads finish their execution (with the join() method), our program will most likely appear to be hanging for 20 seconds before any response is printed out.

Run the program to experience this for yourself. A 20 second delay will occur (which will make the execution take significantly longer to finish) and we will obtain the following output:

http://httpstat.us/200: 200 OK
http://httpstat.us/200?sleep=20000: 200 OK
http://httpstat.us/400: 400 Bad Request
Took 22.60 seconds
Done.
主站蜘蛛池模板: 银川市| 永福县| 九龙城区| 莫力| 资源县| 兴化市| 密云县| 越西县| 兰坪| 南丰县| 璧山县| 霍州市| 枞阳县| 榆中县| 屏东县| 焉耆| 衡南县| 大名县| 沁源县| 张家口市| 北安市| 财经| 和林格尔县| 高唐县| 鸡东县| 土默特右旗| 安吉县| 松江区| 绥芬河市| 库伦旗| 襄汾县| 山东省| 长春市| 沧州市| 麻阳| 禄丰县| 凤山市| 开封市| 禄丰县| 罗田县| 华蓥市|