使用适用于 Python 的 AWS SDK(Boto3)运行 Amazon Bedrock API 请求示例
本部分将指导您在 Amazon Bedrock 中尝试使用 AWS Python 来执行一些常见操作,以测试您的权限和身份验证设置是否正确。在运行以下示例之前,应检查您是否满足了以下先决条件:
先决条件
-
您拥有 AWS 账户并有权使用具有 Amazon Bedrock 必要使用权限的角色。否则,请按照已有 AWS 账户中的步骤操作。
-
您已请求 Amazon Titan Text G1 - Express 模型的访问权限。否则,请按照请求访问 Amazon Bedrock 基础模型中的步骤操作。
-
您已收到您的 IAM 用户的访问密钥,并使用这些密钥配置了配置文件。否则,请按照获取凭证以向用户授予编程访问权限中适用于您的应用情况的步骤操作。
使用您创建的 Amazon Bedrock 角色,测试是否已针对 Amazon Bedrock 设置正确的权限和访问密钥。这些示例均假设您已使用访问密钥配置了环境。请注意以下几点:
-
您必须至少指定 AWS 访问密钥 ID 和 AWS 秘密访问密钥。
-
如果您使用的是临时凭证,则还必须包含一个 AWS 会话令牌。
如果您未在环境中指定凭证,则可以在为 Amazon Bedrock 操作创建客户端aws_access_key_id
、aws_secret_access_key
和(如果使用的是短期凭证)aws_session_token
参数。
列出 Amazon Bedrock 必须提供的基础模型
以下示例使用 Amazon Bedrock 客户端运行 ListFoundationModels 操作。ListFoundationModels
会列出您所在区域的 Amazon Bedrock 中可用的基础模型(FM)。运行以下适用于 Python 的 SDK 脚本来创建 Amazon Bedrock 客户端并测试 ListFoundationModels 操作:
# Use the ListFoundationModels API to show the models that are available in your region. import boto3 # Create an &BR; client in the ®ion-us-east-1; Region. bedrock = boto3.client( service_name="bedrock" ) bedrock.list_foundation_models()
如果此脚本成功,响应会返回一个包含 Amazon Bedrock 中可用基础模型的列表。
向模型提交文本提示并使用 InvokeModel 生成文本响应
以下示例使用 Amazon Bedrock 客户端运行 InvokeModel 操作。InvokeModel
允许您提交提示以生成模型响应。运行以下适用于 Python 的 SDK 脚本来创建 Amazon Bedrock 运行时客户端,并使用 操作生成文本响应:
# Use the native inference API to send a text message to Amazon Titan Text G1 - Express. import boto3 import json from botocore.exceptions import ClientError # Create an Amazon Bedrock Runtime client. brt = boto3.client("bedrock-runtime") # Set the model ID, e.g., Amazon Titan Text G1 - Express. model_id = "amazon.titan-text-express-v1" # Define the prompt for the model. prompt = "Describe the purpose of a 'hello world' program in one line." # Format the request payload using the model's native structure. native_request = { "inputText": prompt, "textGenerationConfig": { "maxTokenCount": 512, "temperature": 0.5, "topP": 0.9 }, } # Convert the native request to JSON. request = json.dumps(native_request) try: # Invoke the model with the request. response = brt.invoke_model(modelId=model_id, body=request) except (ClientError, Exception) as e: print(f"ERROR: Can't invoke '{model_id}'. Reason: {e}") exit(1) # Decode the response body. model_response = json.loads(response["body"].read()) # Extract and print the response text. response_text = model_response["results"][0]["outputText"] print(response_text)
如果此命令成功,响应会返回模型为响应提示而生成的文本。
向模型提交文本提示并使用 Converse 生成文本响应
以下示例使用 Amazon Bedrock 客户端运行 Converse 操作。我们建议在支持时用 Converse
来代替 InvokeModel
操作,因为前者可以统一各个 Amazon Bedrock 模型的推理请求并简化多轮对话的管理。运行以下适用于 Python 的 SDK 脚本来创建 Amazon Bedrock 运行时客户端,并使用 Converse
操作生成文本响应:
# Use the Conversation API to send a text message to Amazon Titan Text G1 - Express. import boto3 from botocore.exceptions import ClientError # Create an Amazon Bedrock Runtime client. brt = boto3.client("bedrock-runtime") # Set the model ID, e.g., Amazon Titan Text G1 - Express. model_id = "amazon.titan-text-express-v1" # Start a conversation with the user message. user_message = "Describe the purpose of a 'hello world' program in one line." conversation = [ { "role": "user", "content": [{"text": user_message}], } ] try: # Send the message to the model, using a basic inference configuration. response = brt.converse( modelId=model_id, messages=conversation, inferenceConfig={"maxTokens": 512, "temperature": 0.5, "topP": 0.9}, ) # Extract and print the response text. response_text = response["output"]["message"]["content"][0]["text"] print(response_text) except (ClientError, Exception) as e: print(f"ERROR: Can't invoke '{model_id}'. Reason: {e}") exit(1)
如果此命令成功,响应会返回模型为响应提示而生成的文本。