API-responses en fouten afhandelen

Introductie tot Amazon Bedrock

Nikhil Rangarajan

Data Scientist

Snelheidslimieten beheren

  • Implementeer exponentiële backoff
  • Optimaliseer API-gebruik met slimme retries
def backoff_retry(max_retries=3, 
                  init_delay=1):

for attempt in range(max_retries): try: response = bedrock.invoke_model()
# Retries when we have an exception except Exception as e: if "ThrottlingException" in str(e): # Exponential backoff time.sleep(base_delay * (2 ** attempt))
Introductie tot Amazon Bedrock

Batch-responses verwerken

  • Verwerk meerdere requests efficiënt
  • Handel batch-responses veilig af
  • Behoud optimale performance
def process_batch(prompts, batch=5):
  results = []
  for i in range(0, len(prompts), 
                 batch):
    responses = [invoke_model(p) for p 
                 in prompts[i:i+batch]]
Introductie tot Amazon Bedrock

Responses nabewerken

  • Valideer de responsstructuur
  • Laad en parse de response body
  • Check op verwachte key
  • Borg consistente datakwaliteit
def postprocess_response(response):

data=json.loads(response['body'] .read())
if 'content' in data: return data['content'].strip()
return None
Introductie tot Amazon Bedrock

Foutherstel

  • Implementeer fallback-strategieën: back-up bij issues met primair model
  • Handel model-specifieke fouten af
  • Zorg voor productieklare betrouwbaarheid
try:
    response = bedrock.invoke_model(modelId="anthropic.claude-3-5-sonnet-v2:0", 
        body=json.dumps(request_body))

except ClientError: response = bedrock.invoke_model(modelId="amazon.nova-lite-v1:0")
Introductie tot Amazon Bedrock

Laten we oefenen!

Introductie tot Amazon Bedrock

Preparing Video For Download...