스팀 API 노드를 사용하는 경우에 해당되는 문제이며, 현재 블러트 API 노드에는 이러한 제약이 없습니다.
파이썬 beem에서 특정 계정의 트랜잭션 이력을 조회하는 account history API를 사용할 때 주의할 점을 얼마전에도 포스팅한 적이 있습니다. 아래의 링크입니다.
파이썬 beem에서 Account 객체의 history_reverse() 함수 사용할 때 유의점
account_history_reverse() 함수를 사용할 때 1회당 조회수(batch_size)를 20개 이하로 설정해야 된다는 내용이었습니다.
그런데 최근에 또 다른 제약 사항이 있음을 발견했습니다. 동일한 IP주소에서 요청을 전송할 경우 1초당 10회 미만이 되어야 합니다. 이것은 공식 스팀 API 노드(api.steemit.com)에서 확인한 내용이며, 다른 API 노드에는 이러한 제약이 없을 수도 있습니다.
어쨌든 이력을 조회할 때 통상 for 반복문을 사용하는데, 너무 자주 조회 요청이 나가지 않도록 time.sleep() 함수를 이용해서 최소한 0.1초 이상 쉬는 시간이 있도록 하지 않으면 응답이 제대로 오지 않고 예외(exception)가 발생합니다.
이전 포스트의 코드 예시에 time.sleep()을 추가하면 아래와 같이 될 것입니다. 좀 여유 있게 0.3초 기다린 후에 다음 트랜잭션을 조회하도록 수정한 경우입니다.
from beem import Steem
from beem.account import Account
import time
steem_node = ["https://api.steemit.com"]
steem = Steem(node=steem_node)
account = Account('joviansummer', blockchain_instance=steem)
history_data = account.history(start=1, stop=5, use_block_num=False, batch_size=20)
for record in history_data:
print(record)
# 0.3초 기다리기
time.sleep(0.3)