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

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.
主站蜘蛛池模板: 安泽县| 涡阳县| 西青区| 湖州市| 壤塘县| 通化县| 连平县| 自贡市| 临夏市| 宝清县| 陈巴尔虎旗| 通山县| 滕州市| 九江县| 九龙县| 蕲春县| 浦江县| 金乡县| 义马市| 叶城县| 安溪县| 桓仁| 天津市| 公安县| 陕西省| 梁山县| 吉首市| 喀喇| 嘉鱼县| 方城县| 弥勒县| 阳泉市| 抚州市| 晴隆县| 财经| 龙泉市| 文昌市| 精河县| 客服| 馆陶县| 西和县|