Step 1: Launch the stack
This automated AWS CloudFormation template deploys the QnABot on AWS solution in the AWS Cloud. You must set up an AWS account before launching the stack.
Note
You are responsible for the cost of the AWS services used while running this solution. For more details, see the Cost section in this guide, and reference to the pricing webpage for each AWS service used in this solution.
-
Sign in to the AWS Management Console
and select the button to launch the qnabot-on-aws-main.template
AWS CloudFormation template. -
The template launches in the US East (N. Virginia) Region by default. To launch the solution in a different AWS Region, use the Region selector in the console navigation bar.
Note
This solution uses Amazon Lex, which is not currently available in all AWS Regions. You must launch this solution in an AWS Region where Amazon Lex is available. For the most current availability by Region, see the AWS Services by Region
list. -
On the Create stack page, verify that the correct template URL is in the Amazon S3 URL text box and choose Next.
-
On the Specify stack details page, assign a name to your solution stack. For information about naming character limitations, see IAM and AWS STS quotas in the AWS Identity and Access Management User Guide.
-
Under Parameters, review the parameters for this solution template and modify them as necessary. This solution uses the following default values.
Note
Amazon Lex V1 has been deprecated and removed from QnABot v6.1.0. Amazon Lex V2 is used by default.
Parameter Default Description Authentication Email <Requires input>
Email address for the admin user. This email address will receive a temporary password to access the QnABot on AWS content designer. Username <Requires input>
This username will be used to sign in to the QnABot on AWS content designer console and client if the client is private. PublicorPrivate PUBLIC
Choose whether access to the QnABot on AWS client should be publicly available or restricted to users in the QnABot in the Cognito user pool. Language English
The primary language for your QnABot on AWS deployment.
Note
Selecting
non-English
might correspond with limited functionalities.Amazon Kendra Integration Amazon KendraWebPageIndexId <Optional input> ID of the Amazon Kendra index to use for the web crawler. A custom data source will automatically be added to the specified index. Amazon KendraFaqIndexId <Optional input> ID of the Amazon Kendra index to use for syncing OpenSearch questions and answers. AltSearchAmazon KendraIndexes <Optional input> A comma separated string value specifying IDs of one or more Amazon Kendra indexes to be used for Amazon Kendra fallback. AltSearchAmazon KendraIndexAuth FALSE
Choosing
TRUE
enables the solution to send an OpenID token to Amazon Kendra index(es) to limit results to which the user is entitled.Amazon OpenSearch Service OpenSearchInstanceType m6g.large.search
OpenSearch instance type to use for the domain. Default recommendation for production deployments is
m6g.large.search
. For details, see Supported instance types in Amazon OpenSearch Service in the Amazon OpenSearch Service Developer Guide.OpenSearchNodeCount 4
Number of nodes in Amazon OpenSearch Service domain. We recommend 4 for fault-tolerant production deployments. OpenSearchEBSVolumeSize 10
The size in GB of the OpenSearch node instances.
10
is the minimum default volume size.OpenSearchDashboardsRetentionMinutes 43200
To conserve storage in Amazon OpenSearch Service, metrics and feedback data used to populate the OpenSearch Dashboards are automatically deleted after this period (default
43200
minutes = 30 days). Monitor the free storage space for your OpenSearch Service domain to ensure that you have sufficient space available to store data for the desired retention period.OpenSearchFineGrainAccessControl TRUE
Set to
FALSE
if fine-grained access control does not need to be enabled by default. Once fine-grained access control is enabled, it cannot be disabled. Note that it may take an additional 30-60 minutes for OpenSearch Service to apply these settings to the OpenSearch domain after the stack has been deployed. For details, see Fine-grained access control in Amazon OpenSearch Service in the Amazon OpenSearch Service Developer Guide.Amazon LexV2 LexV2BotLocaleIds en_US,es_US,fr_CA
Languages for QnABot on AWS voice interaction using LexV2. Specify as a comma-separated list of valid locale IDs without empty spaces. For details, see the Supported languages section in the GitHub repository. Semantic Search and Embeddings EmbeddingsApi DISABLED
Enable QnABot semantics search using embeddings from a pre-trained LLM. If set to
SAGEMAKER
, anml.g4dn.xlarge
SageMaker AI endpoint is automatically provisioned with Hugging Faceintfloat/e5-large
model. SelectingLAMBDA
allows for configuration with other models. Disabled by default.SagemakerInitialInstanceCount 1
Required when EmbeddingsApi is set to
SAGEMAKER
. Sets the number of instances to deploy. Default instance size isml.m5.xlarge
.EmbeddingsLambdaArn <Requires input>
Required when EmbeddingsApi is set to
LAMBDA
. Provide the ARN for a Lambda function that takes JSON{"inputtext":"string"},
and returns JSON{"embedding":[...]}.
EmbeddingsLambdaDimensions 1536
Required when EmbeddingsApi is set to
LAMBDA
. Provides the number of dimensions for embeddings returned from the Lambda function.EmbeddingsBedrockModelId amazon.titan-embed-text-v1
Required when EmbeddingsApi is set to
BEDROCK
. Select the embeddings model from the list of available models. Check account and Region availability and ensure that the model is enabled in the Amazon Bedrock console before deploying. For details, see Model support by AWS Region in the Amazon Bedrock User Guide.LLM Integration LLMApi DISABLED
Enable question disambiguation and generative responses using an LLM model. If set to
SAGEMAKER
, a SageMaker AI endpoint is automatically provisioned. Selecting theLAMBDA
option allows for configuration with other LLMs.LLMSagemakerInstanceType ml.g5.12xlarge
Required if LLMApi is set to
SAGEMAKER
. Provide the SageMaker AI endpoint instance type. Defaults to ml.g5.12xlarge. Check account and Region availability through AWS service quotas before deploying.LLMSagemakerInitialInstanceCount 1
Required if LLMApi is set to
SAGEMAKER
. Provide initial instance count. Serverless Inference is not currently available for the built-in LLM model.LLMBedrockModelId anthropic.claude-instant-v1
Required when LLMApi is set to
BEDROCK
. Select the LLM model from the list of available models. Check account and Region availability and ensure that the model is enabled in the Amazon Bedrock console before deploying.LLMLambdaArn <Requires input>
Required if LLMApi is set to
LAMBDA
. Provide the ARN for a Lambda function that takes JSON{"prompt":"string", "settings":{key:value,..}},
and returns JSON{"generated_text":"string"}.
BedrockKnowledgeBaseId <Optional input> ID of an existing Amazon Bedrock knowledge base. This setting enables the use of Amazon Bedrock knowledge bases as a fallback mechanism when a match is not found in OpenSearch. BedrockKnowledgeBaseModel anthropic.claude-instant-v1
Required if BedrockKnowledgeBaseId is not empty. Sets the preferred LLM model to use with the Amazon Bedrock knowledge base. Other parameters InstallLexResponseBots TRUE
Configures your chatbot to ask questions and process your end user's answers for surveys and quizzes. If the Elicit Response feature is not needed, choose
FALSE
to skip the installation of the sample Lex response bots. For details, see Configuring the chatbot to ask the questions and use response bots.FulfillmentConcurrency 0
The amount of provisioned concurrency for the
Fulfillment
Lambda function. For details, see Configuring reserved concurrency.VPCSubnetIdList <Optional input> Set to a comma delimited list of subnet IDs belonging to the target VPC you want to deploy QnABot on AWS in. VPCSecurityGroupIdList <Optional input> Set to a comma delimited list of security group IDs used by QnABot when deployed within a VPC. XraySetting FALSE
Configure Lambda functions with AWS X-Ray enabled. LogRetentionPeriod 0
The number of days that logs are kept before expiring. By default, logs never expire. -
Choose Next.
-
On the Configure stack options page, keep the default settings.
-
On the Review and create page, review and confirm the settings. Check the box acknowledging that the template might create IAM resources with custom names, and the box acknowledging that AWS CloudFormation might require the CAPABILITY_AUTO_EXPAND capability.
-
Choose Submit to deploy the stack.
You can view the status of the stack in the AWS CloudFormation console in the Status column. You should receive a CREATE_COMPLETE status in approximately 30-45 minutes.
When the stack deployment is complete, the Output tab displays the following information:
-
ContentDesignerURL – URL to launch the content designer UI
-
ClientURL – URL to launch the end user client webpage
-
DashboardUrl – URL to launch the CloudWatch dashboard for monitoring
-
FeedbackSNSTopic – Topic name to allow feedback notifications
-
LexV2 bot information – Data for configuring integration with contact centers and web clients.
Note
In addition to the primary AWS Lambda functions,this solution includes the
solution-helper
Lambda function, which runs only during initial configuration
or when resources are updated or deleted.
When you run this solution, the solution-helper
Lambda function is not
regularly active; however, you must not delete it because it is necessary to manage
associated resources.