Gestire risposte API ed errori

Introduzione ad Amazon Bedrock

Nikhil Rangarajan

Data Scientist

Gestire i rate limit

  • Implementa backoff esponenziale
  • Ottimizza l’uso dell’API con retry intelligenti
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))
Introduzione ad Amazon Bedrock

Elaborazione batch delle risposte

  • Elabora più richieste in modo efficiente
  • Gestisci in sicurezza le risposte batch
  • Mantieni prestazioni ottimali
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]]
Introduzione ad Amazon Bedrock

Post-processing della risposta

  • Valida la struttura della risposta
  • Carica e fai il parse del body
  • Verifica la chiave attesa
  • Assicura qualità dati consistente
def postprocess_response(response):

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

Recupero dagli errori

  • Implementa strategie di fallback: piano B se il modello primario ha problemi
  • Gestisci errori specifici del modello
  • Garantisci affidabilità da produzione
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")
Introduzione ad Amazon Bedrock

Ayo berlatih!

Introduzione ad Amazon Bedrock

Preparing Video For Download...