/sagemaker-bedrock-workshop

Primary LanguageJupyter NotebookMIT No AttributionMIT-0

Amazon Bedrock Workshop

This hands-on workshop, aimed at developers and solution builders, introduces how to leverage foundation models (FMs) through Amazon Bedrock.

Amazon Bedrock is a fully managed service that provides access to FMs from third-party providers and Amazon; available via an API. With Bedrock, you can choose from a variety of models to find the one that’s best suited for your use case.

Within this series of labs, you'll explore some of the most common usage patterns we are seeing with our customers for Generative AI. We will show techniques for generating text and images, creating value for organizations by improving productivity. This is achieved by leveraging foundation models to help in composing emails, summarizing text, answering questions, building chatbots, and creating images. You will gain hands-on experience implementing these patterns via Bedrock APIs and SDKs, as well as open-source software like LangChain and FAISS.

Day 1 - Agenda:

  1. 10 to 10.30 am - Intro & Voice of customer [30 mins]
  2. 10.30 to 11 am – AWS GenAI Overview [30 mins]
  3. 11 to 11.30 am - Text Generation [30 mins]
  4. 11.30 to 12.00 pm - Text Summarization [30 mins]
  5. 12.00 to 1 pm – Lunch
  6. 1.00 to 1.45 pm - Questions Answering (RAG) [45 mins]
  7. 1.45 to 2.15 pm - Chatbot (RAG) [30 mins]
  8. 2.15 to 2.30 pm - EntityExtraction [15 mins]
  9. 2.30 to 2.45 pm - Break [15 mins]
  10. 2.45 to 3.15 pm - Code Generation [30 mins]
  11. 3.15 to 3.45 pm - Chatbot Guardrails [30 mins]

Day 2 - Agenda:

  1. 10 to 10.30 am – Recap of Day 1
  2. 10.30 to 11 am - Semantic Search with Metadata Filtering [30min]
  3. 11.00 to 11.30 am - Semantic Search with Document Summaries [30min]
  4. 11.30 to 12 pm – Semantic Search with Re-Ranking [30min]
  5. 12 to 1 pm - Lunch
  6. 1 to 2.00 pm - Bedrock Agents [60min]
  7. 2.00 to 2.30 pm - Wrap up and Next steps

The above agenda is based on selected labs from the following two workshops:

Getting started

self-guided / personal AWS account

Choose a notebook environment

This workshop is presented as a series of Python notebooks, which you can run from the environment of your choice:

Launch CloudFormation Stack


Enable AWS IAM permissions for Bedrock

The AWS identity you assume from your notebook environment (which is the Studio/notebook Execution Role from SageMaker, or could be a role or IAM User for self-managed notebooks), must have sufficient AWS IAM permissions to call the Amazon Bedrock service.

To grant Bedrock access to your identity, you can:

  • Open the AWS IAM Console
  • Find your Role (if using SageMaker or otherwise assuming an IAM Role), or else User
  • Select Add Permissions > Create Inline Policy to attach new inline permissions, open the JSON editor and paste in the below example policy:
{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Sid": "BedrockFullAccess",
            "Effect": "Allow",
            "Action": ["bedrock:*"],
            "Resource": "*"
        }
    ]
}

⚠️ Note: With Amazon SageMaker, your notebook execution role will typically be separate from the user or role that you log in to the AWS Console with. If you'd like to explore the AWS Console for Amazon Bedrock, you'll need to grant permissions to your Console user/role too.

For more information on the fine-grained action and resource permissions in Bedrock, check out the Bedrock Developer Guide.

Enable LLMs in Bedrock console

ℹ️ Note: In Within the Amazon Bedrock console, ensure you have agreed to the terms and conditions and enabled the respective LLMs.

Clone and use the notebooks

ℹ️ Note: In SageMaker Studio, you can open a "System Terminal" to run these commands by clicking File > New > Terminal

Once your notebook environment is set up, clone this workshop repository into it.

sudo yum install -y unzip
git clone https://github.com/aws-samples/amazon-bedrock-workshop.git
cd amazon-bedrock-workshop

You're now ready to explore the lab notebooks! Start with [day1/00_Intro/bedrock_boto3_setup.ipynb]for details on how to install the Bedrock SDKs, create a client, and start calling the APIs from Python.