Initial commit
Browse files- .gitattributes +35 -0
- .github/check-file-size.yaml +14 -0
- .github/workflows/sync-to-hf.yaml +33 -0
- README_HF.md +15 -0
- app.py +21 -12
- dockerfile +2 -2
- questions/Amazon.AIF-C01.v2024-09-02.json +110 -0
- questions/Amazon.SAA-C03.v2024-10-25.json +434 -0
- requirements.txt +1 -0
- static/script.js +29 -6
- templates/host.html +4 -4
.gitattributes
ADDED
@@ -0,0 +1,35 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
*.7z filter=lfs diff=lfs merge=lfs -text
|
2 |
+
*.arrow filter=lfs diff=lfs merge=lfs -text
|
3 |
+
*.bin filter=lfs diff=lfs merge=lfs -text
|
4 |
+
*.bz2 filter=lfs diff=lfs merge=lfs -text
|
5 |
+
*.ckpt filter=lfs diff=lfs merge=lfs -text
|
6 |
+
*.ftz filter=lfs diff=lfs merge=lfs -text
|
7 |
+
*.gz filter=lfs diff=lfs merge=lfs -text
|
8 |
+
*.h5 filter=lfs diff=lfs merge=lfs -text
|
9 |
+
*.joblib filter=lfs diff=lfs merge=lfs -text
|
10 |
+
*.lfs.* filter=lfs diff=lfs merge=lfs -text
|
11 |
+
*.mlmodel filter=lfs diff=lfs merge=lfs -text
|
12 |
+
*.model filter=lfs diff=lfs merge=lfs -text
|
13 |
+
*.msgpack filter=lfs diff=lfs merge=lfs -text
|
14 |
+
*.npy filter=lfs diff=lfs merge=lfs -text
|
15 |
+
*.npz filter=lfs diff=lfs merge=lfs -text
|
16 |
+
*.onnx filter=lfs diff=lfs merge=lfs -text
|
17 |
+
*.ot filter=lfs diff=lfs merge=lfs -text
|
18 |
+
*.parquet filter=lfs diff=lfs merge=lfs -text
|
19 |
+
*.pb filter=lfs diff=lfs merge=lfs -text
|
20 |
+
*.pickle filter=lfs diff=lfs merge=lfs -text
|
21 |
+
*.pkl filter=lfs diff=lfs merge=lfs -text
|
22 |
+
*.pt filter=lfs diff=lfs merge=lfs -text
|
23 |
+
*.pth filter=lfs diff=lfs merge=lfs -text
|
24 |
+
*.rar filter=lfs diff=lfs merge=lfs -text
|
25 |
+
*.safetensors filter=lfs diff=lfs merge=lfs -text
|
26 |
+
saved_model/**/* filter=lfs diff=lfs merge=lfs -text
|
27 |
+
*.tar.* filter=lfs diff=lfs merge=lfs -text
|
28 |
+
*.tar filter=lfs diff=lfs merge=lfs -text
|
29 |
+
*.tflite filter=lfs diff=lfs merge=lfs -text
|
30 |
+
*.tgz filter=lfs diff=lfs merge=lfs -text
|
31 |
+
*.wasm filter=lfs diff=lfs merge=lfs -text
|
32 |
+
*.xz filter=lfs diff=lfs merge=lfs -text
|
33 |
+
*.zip filter=lfs diff=lfs merge=lfs -text
|
34 |
+
*.zst filter=lfs diff=lfs merge=lfs -text
|
35 |
+
*tfevents* filter=lfs diff=lfs merge=lfs -text
|
.github/check-file-size.yaml
ADDED
@@ -0,0 +1,14 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
name: Check File Size
|
2 |
+
on:
|
3 |
+
pull_request:
|
4 |
+
branches: [main]
|
5 |
+
workflow_dispatch:
|
6 |
+
|
7 |
+
jobs:
|
8 |
+
check-large-files:
|
9 |
+
runs-on: ubuntu-latest
|
10 |
+
steps:
|
11 |
+
- name: Check large files
|
12 |
+
uses: ActionsDesk/lfs-warning@v2.0
|
13 |
+
with:
|
14 |
+
filesizelimit: 10485760 # 10MB
|
.github/workflows/sync-to-hf.yaml
ADDED
@@ -0,0 +1,33 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
name: Sync to Hugging Face Space
|
2 |
+
on:
|
3 |
+
push:
|
4 |
+
branches: [main]
|
5 |
+
workflow_dispatch:
|
6 |
+
|
7 |
+
jobs:
|
8 |
+
sync-to-hub:
|
9 |
+
runs-on: ubuntu-latest
|
10 |
+
steps:
|
11 |
+
- uses: actions/checkout@v3
|
12 |
+
with:
|
13 |
+
fetch-depth: 0
|
14 |
+
lfs: true
|
15 |
+
|
16 |
+
# Step to replace README.md with README_HF.md
|
17 |
+
- name: Replace README.md for Hugging Face
|
18 |
+
run: |
|
19 |
+
mv README.md README_GITHUB.md
|
20 |
+
cp README_HF.md README.md
|
21 |
+
|
22 |
+
# Push to Hugging Face Space
|
23 |
+
- name: Push to Hugging Face Space
|
24 |
+
env:
|
25 |
+
HF_TOKEN: ${{ secrets.HF_TOKEN }}
|
26 |
+
run: |
|
27 |
+
git remote add space https://huggingface.co/spaces/ruslanmv/Real-Time-Quiz-Application || true
|
28 |
+
git push --force https://ruslanmv:${HF_TOKEN}@huggingface.co/spaces/ruslanmv/Real-Time-Quiz-Application main
|
29 |
+
|
30 |
+
# Step to restore original README.md
|
31 |
+
- name: Restore GitHub README.md
|
32 |
+
run: |
|
33 |
+
mv README_GITHUB.md README.md
|
README_HF.md
ADDED
@@ -0,0 +1,15 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
---
|
2 |
+
title: Real Time Quiz Application
|
3 |
+
emoji: 🔥
|
4 |
+
colorFrom: green
|
5 |
+
colorTo: pink
|
6 |
+
sdk: docker
|
7 |
+
pinned: false
|
8 |
+
short_description: 'About A Python-based real-time quiz application designed to '
|
9 |
+
---
|
10 |
+
|
11 |
+
A Python-based real-time quiz application designed to mimic the functionality of Mentimeter, allowing a host to control the quiz and participants (clients) to join, answer questions, and receive immediate feedback. The application is built using Flask and Socket.IO for seamless web-based interaction, and it offers a clean, responsive front-end using HTML, CSS, and Bootstrap.
|
12 |
+
|
13 |
+
|
14 |
+
|
15 |
+
Check out the configuration reference at https://huggingface.co/docs/hub/spaces-config-reference
|
app.py
CHANGED
@@ -1,3 +1,6 @@
|
|
|
|
|
|
|
|
1 |
from flask import Flask, render_template, request
|
2 |
from flask_socketio import SocketIO, emit, join_room, leave_room
|
3 |
import backend # Import backend functions
|
@@ -5,10 +8,13 @@ import matplotlib.pyplot as plt
|
|
5 |
import base64
|
6 |
from io import BytesIO
|
7 |
import random
|
|
|
8 |
|
|
|
|
|
9 |
app = Flask(__name__)
|
10 |
app.config['SECRET_KEY'] = 'your_secret_key'
|
11 |
-
socketio = SocketIO(app)
|
12 |
|
13 |
exams = backend.load_question_sets() # Load available exams
|
14 |
selected_questions = [] # Global variable to store the selected questions
|
@@ -47,13 +53,13 @@ def on_leave():
|
|
47 |
|
48 |
@socketio.on('load_quiz')
|
49 |
def load_quiz(data):
|
50 |
-
global selected_questions
|
51 |
exam_name = data['exam_name']
|
52 |
-
start_question = data
|
53 |
selected_questions = backend.select_exam(exam_name)
|
54 |
if selected_questions:
|
55 |
num_questions = len(selected_questions)
|
56 |
-
current_question['index'] = start_question
|
57 |
emit('quiz_loaded', {"success": True, "num_questions": num_questions, "start_question": start_question + 1}, room=request.sid)
|
58 |
else:
|
59 |
emit('quiz_loaded', {"success": False}, room=request.sid)
|
@@ -62,10 +68,14 @@ def load_quiz(data):
|
|
62 |
def start_quiz():
|
63 |
if participants and selected_questions:
|
64 |
current_question['started'] = True
|
65 |
-
|
66 |
-
|
67 |
-
|
68 |
-
emit('
|
|
|
|
|
|
|
|
|
69 |
|
70 |
@socketio.on('restart_quiz')
|
71 |
def restart_quiz():
|
@@ -106,13 +116,12 @@ def next_question():
|
|
106 |
if current_question['index'] < len(selected_questions):
|
107 |
question = selected_questions[current_question['index']]
|
108 |
emit('clear_results', room='quiz')
|
109 |
-
emit('new_question', question, room='quiz')
|
110 |
-
# Also emit the question to the host
|
111 |
-
emit('new_question', question, room=request.sid)
|
112 |
else:
|
113 |
final_results = calculate_final_results()
|
114 |
emit('display_final_results', final_results, room='quiz')
|
115 |
|
|
|
116 |
@socketio.on('end_quiz')
|
117 |
def end_quiz():
|
118 |
if current_question['started']: # Ensure the quiz has started before ending it
|
@@ -148,4 +157,4 @@ def reset_quiz():
|
|
148 |
participant["score"] = 0
|
149 |
|
150 |
if __name__ == '__main__':
|
151 |
-
socketio.run(app, host='0.0.0.0', port=7860, debug=
|
|
|
1 |
+
import eventlet
|
2 |
+
# Force eventlet to be used as the async mode for Flask-SocketIO
|
3 |
+
eventlet.monkey_patch()
|
4 |
from flask import Flask, render_template, request
|
5 |
from flask_socketio import SocketIO, emit, join_room, leave_room
|
6 |
import backend # Import backend functions
|
|
|
8 |
import base64
|
9 |
from io import BytesIO
|
10 |
import random
|
11 |
+
import logging
|
12 |
|
13 |
+
# Configure the logging level
|
14 |
+
logging.getLogger('eventlet.wsgi.server').setLevel(logging.ERROR)
|
15 |
app = Flask(__name__)
|
16 |
app.config['SECRET_KEY'] = 'your_secret_key'
|
17 |
+
socketio = SocketIO(app, async_mode='eventlet')
|
18 |
|
19 |
exams = backend.load_question_sets() # Load available exams
|
20 |
selected_questions = [] # Global variable to store the selected questions
|
|
|
53 |
|
54 |
@socketio.on('load_quiz')
|
55 |
def load_quiz(data):
|
56 |
+
global selected_questions, current_question
|
57 |
exam_name = data['exam_name']
|
58 |
+
start_question = data.get('start_question', 1) - 1 # Default to question 1 if not provided
|
59 |
selected_questions = backend.select_exam(exam_name)
|
60 |
if selected_questions:
|
61 |
num_questions = len(selected_questions)
|
62 |
+
current_question['index'] = start_question # Set the starting question index
|
63 |
emit('quiz_loaded', {"success": True, "num_questions": num_questions, "start_question": start_question + 1}, room=request.sid)
|
64 |
else:
|
65 |
emit('quiz_loaded', {"success": False}, room=request.sid)
|
|
|
68 |
def start_quiz():
|
69 |
if participants and selected_questions:
|
70 |
current_question['started'] = True
|
71 |
+
index = current_question['index']
|
72 |
+
question = selected_questions[index]
|
73 |
+
# Send the starting question to all clients
|
74 |
+
emit('new_question', {"question": question["question"], "options": question["options"], "index": index + 1}, room='quiz')
|
75 |
+
emit('enable_end_quiz', room=request.sid) # Enable "End Quiz" for the host
|
76 |
+
|
77 |
+
|
78 |
+
|
79 |
|
80 |
@socketio.on('restart_quiz')
|
81 |
def restart_quiz():
|
|
|
116 |
if current_question['index'] < len(selected_questions):
|
117 |
question = selected_questions[current_question['index']]
|
118 |
emit('clear_results', room='quiz')
|
119 |
+
emit('new_question', {"question": question["question"], "options": question["options"], "index": current_question['index'] + 1}, room='quiz')
|
|
|
|
|
120 |
else:
|
121 |
final_results = calculate_final_results()
|
122 |
emit('display_final_results', final_results, room='quiz')
|
123 |
|
124 |
+
|
125 |
@socketio.on('end_quiz')
|
126 |
def end_quiz():
|
127 |
if current_question['started']: # Ensure the quiz has started before ending it
|
|
|
157 |
participant["score"] = 0
|
158 |
|
159 |
if __name__ == '__main__':
|
160 |
+
socketio.run(app, host='0.0.0.0', port=7860, debug=False)
|
dockerfile
CHANGED
@@ -25,5 +25,5 @@ COPY --chown=user . /app
|
|
25 |
# Expose the application port (7860) for Hugging Face Spaces
|
26 |
EXPOSE 7860
|
27 |
|
28 |
-
# Set the command to run the application using
|
29 |
-
CMD ["
|
|
|
25 |
# Expose the application port (7860) for Hugging Face Spaces
|
26 |
EXPOSE 7860
|
27 |
|
28 |
+
# Set the command to run the application using Flask-SocketIO and eventlet
|
29 |
+
CMD ["python", "app.py"]
|
questions/Amazon.AIF-C01.v2024-09-02.json
ADDED
@@ -0,0 +1,110 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
[
|
2 |
+
{
|
3 |
+
"question": "A medical company deployed a disease detection model on Amazon Bedrock. To comply with privacy policies, the company wants to prevent the model from including personal patient information in its responses. The company also wants to receive notification when policy violations occur. Which solution meets these requirements?",
|
4 |
+
"options": [
|
5 |
+
"Use Amazon Macie to scan the model's output for sensitive data and set up alerts for potential violations.",
|
6 |
+
"Configure AWS CloudTrail to monitor the model's responses and create alerts for any detected personal information.",
|
7 |
+
"Use Guardrails for Amazon Bedrock to filter content. Set up Amazon CloudWatch alarms for notification of policy violations.",
|
8 |
+
"Implement Amazon SageMaker Model Monitor to detect data drift and receive alerts when model quality degrades."
|
9 |
+
],
|
10 |
+
"correct": [
|
11 |
+
"C"
|
12 |
+
]
|
13 |
+
},
|
14 |
+
{
|
15 |
+
"question": "A large retailer receives thousands of customer support inquiries about products every day. The customer support inquiries need to be processed and responded to quickly. The company wants to implement Agents for Amazon Bedrock. What are the key benefits of using Amazon Bedrock agents that could help this retailer?",
|
16 |
+
"options": [
|
17 |
+
"Generation of custom foundation models (FMs) to predict customer needs",
|
18 |
+
"Automation of repetitive tasks and orchestration of complex workflows",
|
19 |
+
"Automatically calling multiple foundation models (FMs) and consolidating the results",
|
20 |
+
"Selecting the foundation model (FM) based on predefined criteria and metrics"
|
21 |
+
],
|
22 |
+
"correct": [
|
23 |
+
"B"
|
24 |
+
]
|
25 |
+
},
|
26 |
+
{
|
27 |
+
"question": "A company is building an ML model. The company collected new data and analyzed the data by creating a correlation matrix, calculating statistics, and visualizing the data. Which stage of the ML pipeline is the company currently in?",
|
28 |
+
"options": [
|
29 |
+
"Data pre-processing",
|
30 |
+
"Feature engineering",
|
31 |
+
"Exploratory data analysis",
|
32 |
+
"Hyperparameter tuning"
|
33 |
+
],
|
34 |
+
"correct": [
|
35 |
+
"C"
|
36 |
+
]
|
37 |
+
},
|
38 |
+
{
|
39 |
+
"question": "Which feature of Amazon OpenSearch Service gives companies the ability to build vector database applications?",
|
40 |
+
"options": [
|
41 |
+
"Integration with Amazon S3 for object storage",
|
42 |
+
"Support for geospatial indexing and queries",
|
43 |
+
"Scalable index management and nearest neighbor search capability",
|
44 |
+
"Ability to perform real-time analysis on streaming data"
|
45 |
+
],
|
46 |
+
"correct": [
|
47 |
+
"C"
|
48 |
+
]
|
49 |
+
},
|
50 |
+
{
|
51 |
+
"question": "A company wants to use a large language model (LLM) to develop a conversational agent. The company needs to prevent the LLM from being manipulated with common prompt engineering techniques to perform undesirable actions or expose sensitive information. Which action will reduce these risks?",
|
52 |
+
"options": [
|
53 |
+
"Create a prompt template that teaches the LLM to detect attack patterns.",
|
54 |
+
"Increase the temperature parameter on invocation requests to the LLM.",
|
55 |
+
"Avoid using LLMs that are not listed in Amazon SageMaker.",
|
56 |
+
"Decrease the number of input tokens on invocations of the LLM."
|
57 |
+
],
|
58 |
+
"correct": [
|
59 |
+
"A"
|
60 |
+
]
|
61 |
+
},
|
62 |
+
{
|
63 |
+
"question": "Which option is a use case for generative AI models?",
|
64 |
+
"options": [
|
65 |
+
"Improving network security by using intrusion detection systems",
|
66 |
+
"Creating photorealistic images from text descriptions for digital marketing",
|
67 |
+
"Enhancing database performance by using optimized indexing",
|
68 |
+
"Analyzing financial data to forecast stock market trends"
|
69 |
+
],
|
70 |
+
"correct": [
|
71 |
+
"B"
|
72 |
+
]
|
73 |
+
},
|
74 |
+
{
|
75 |
+
"question": "A company wants to use a large language model (LLM) on Amazon Bedrock for sentiment analysis. The company wants to know how much information can fit into one prompt. Which consideration will inform the company's decision?",
|
76 |
+
"options": [
|
77 |
+
"Temperature",
|
78 |
+
"Context window",
|
79 |
+
"Batch size",
|
80 |
+
"Model size"
|
81 |
+
],
|
82 |
+
"correct": [
|
83 |
+
"B"
|
84 |
+
]
|
85 |
+
},
|
86 |
+
{
|
87 |
+
"question": "A company needs to choose a model from Amazon Bedrock to use internally. The company must identify a model that generates responses in a style that the company's employees prefer. What should the company do to meet these requirements?",
|
88 |
+
"options": [
|
89 |
+
"Evaluate the models by using built-in prompt datasets.",
|
90 |
+
"Evaluate the models by using a human workforce and custom prompt datasets.",
|
91 |
+
"Use public model leaderboards to identify the model.",
|
92 |
+
"Use the model InvocationLatency runtime metrics in Amazon CloudWatch when trying models."
|
93 |
+
],
|
94 |
+
"correct": [
|
95 |
+
"B"
|
96 |
+
]
|
97 |
+
},
|
98 |
+
{
|
99 |
+
"question": "A company wants to use a large language model (LLM) on Amazon Bedrock for sentiment analysis. The company needs the LLM to produce more consistent responses to the same input prompt. Which adjustment to an inference parameter should the company make to meet these requirements?",
|
100 |
+
"options": [
|
101 |
+
"Decrease the temperature value",
|
102 |
+
"Increase the temperature value",
|
103 |
+
"Decrease the length of output tokens",
|
104 |
+
"Increase the maximum generation length"
|
105 |
+
],
|
106 |
+
"correct": [
|
107 |
+
"A"
|
108 |
+
]
|
109 |
+
}
|
110 |
+
]
|
questions/Amazon.SAA-C03.v2024-10-25.json
ADDED
@@ -0,0 +1,434 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
[
|
2 |
+
{
|
3 |
+
"question": "A company has a serverless website with millions of objects in an Amazon S3 bucket. The company uses the S3 bucket as the origin for an Amazon CloudFront distribution. The company did not set encryption on the S3 bucket before the objects were loaded. A solutions architect needs to enable encryption for all existing objects and for all objects that are added to the S3 bucket in the future. Which solution will meet these requirements with the LEAST amount of effort?",
|
4 |
+
"options": [
|
5 |
+
"Create a new S3 bucket. Turn on the default encryption settings for the new S3 bucket. Download all existing objects to temporary local storage. Upload the objects to the new S3 bucket.",
|
6 |
+
"Turn on the default encryption settings for the S3 bucket. Use the S3 Inventory feature to create a .csv file that lists the unencrypted objects. Run an S3 Batch Operations job that uses the copy command to encrypt those objects.",
|
7 |
+
"Create a new encryption key by using AWS Key Management Service (AWS KMS). Change the settings on the S3 bucket to use server-side encryption with AWS KMS managed encryption keys (SSE- KMS). Turn on versioning for the S3 bucket.",
|
8 |
+
"Navigate to Amazon S3 in the AWS Management Console. Browse the S3 bucket's objects. Sort by the encryption field. Select each unencrypted object. Use the Modify button to apply default encryption settings to every unencrypted object in the S3 bucket."
|
9 |
+
],
|
10 |
+
"correct": [
|
11 |
+
"B"
|
12 |
+
]
|
13 |
+
},
|
14 |
+
{
|
15 |
+
"question": "A data analytics company wants to migrate its batch processing system to AWS. The company receives thousands of small data files periodically during the day through FTP. A on-premises batch job processes the data files overnight. However, the batch job takes hours to finish running. The company wants the AWS solution to process incoming data files are possible with minimal changes to the FTP clients that send the files. The solution must delete the incoming data files the files have been processed successfully. Processing for each file needs to take 3-8 minutes. Which solution will meet these requirements in the MOST operationally efficient way?",
|
16 |
+
"options": [
|
17 |
+
"Use an Amazon EC2 instance that runs an FTP server to store incoming files as objects in Amazon S3 Glacier Flexible Retrieval. Configure a job queue in AWS Batch. Use Amazon EventBridge rules to invoke the job to process the objects nightly from S3 Glacier Flexible Retrieval. Delete the objects after the job has processed the objects.",
|
18 |
+
"Use an Amazon EC2 instance that runs an FTP server to store incoming files on an Amazon Elastic Block Store (Amazon EBS) volume. Configure a job queue in AWS Batch. Use Amazon EventBridge rules to invoke the process the files nightly from the EBS volume. Delete the files after the job has processed the files.",
|
19 |
+
"Use AWS Transfer Family to create an FTP server to store incoming files on an Amazon Elastic Block Store (Amazon EBS) volume. Configure a job queue in AWS Batch. Use an Amazon S3 event notification when each files arrives to invoke the job in AWS Batch. Delete the files after the job has processed the files.",
|
20 |
+
"Use AWS Transfer Family to create an FTP server to store incoming files in Amazon S3 Standard.Create an AWS Lambda function to process the files and to delete the files after they are proessed.yse an S3 event notification to invoke the lambda function when the fils arrive"
|
21 |
+
],
|
22 |
+
"correct": [
|
23 |
+
"D"
|
24 |
+
]
|
25 |
+
},
|
26 |
+
{
|
27 |
+
"question": "A company recently started using Amazon Aurora as the data store for its global ecommerce application When large reports are run developers report that the ecommerce application is performing poorly After reviewing metrics in Amazon CloudWatch, a solutions architect finds that the ReadlOPS and CPUUtilization metrics are spiking when monthly reports run. What is the MOST cost-effective solution?",
|
28 |
+
"options": [
|
29 |
+
"Migrate the monthly reporting to Amazon Redshift.",
|
30 |
+
"Migrate the monthly reporting to an Aurora Replica",
|
31 |
+
"Migrate the Aurora database to a larger instance class",
|
32 |
+
"Increase the Provisioned IOPS on the Aurora instance"
|
33 |
+
],
|
34 |
+
"correct": [
|
35 |
+
"B"
|
36 |
+
]
|
37 |
+
},
|
38 |
+
{
|
39 |
+
"question": "A company has a business-critical application that runs on Amazon EC2 instances. The application stores data in an Amazon DynamoDB table. The company must be able to revert the table to any point within the last 24 hours. Which solution meets these requirements with the LEAST operational overhead?",
|
40 |
+
"options": [
|
41 |
+
"Configure point-in-time recovery for the table.",
|
42 |
+
"Use AWS Backup for the table.",
|
43 |
+
"Use an AWS Lambda function to make an on-demand backup of the table every hour.",
|
44 |
+
"Turn on streams on the table to capture a log of all changes to the table in the last 24 hours Store a copy of the stream in an Amazon S3 bucket."
|
45 |
+
],
|
46 |
+
"correct": [
|
47 |
+
"A"
|
48 |
+
]
|
49 |
+
},
|
50 |
+
{
|
51 |
+
"question": "A company wants to move a multi-tiered application from on premises to the AWS Cloud to improve the application's performance. The application consists of application tiers that communicate with each other by way of RESTful services. Transactions are dropped when one tier becomes overloaded. A solutions architect must design a solution that resolves these issues and modernizes the application. Which solution meets these requirements and is the MOST operationally efficient?",
|
52 |
+
"options": [
|
53 |
+
"Use Amazon API Gateway and direct transactions to the AWS Lambda functions as the application layer. Use Amazon Simple Queue Service (Amazon SQS) as the communication layer between application services.",
|
54 |
+
"Use Amazon CloudWatch metrics to analyze the application performance history to determine the server's peak utilization during the performance failures. Increase the size of the application server's Amazon EC2 instances to meet the peak requirements.",
|
55 |
+
"Use Amazon Simple Notification Service (Amazon SNS) to handle the messaging between application servers running on Amazon EC2 in an Auto Scaling group. Use Amazon CloudWatch to monitor the SNS queue length and scale up and down as required.",
|
56 |
+
"Use Amazon Simple Queue Service (Amazon SQS) to handle the messaging between application servers running on Amazon EC2 in an Auto Scaling group. Use Amazon CloudWatch to monitor the SQS queue length and scale up when communication failures are detected."
|
57 |
+
],
|
58 |
+
"correct": [
|
59 |
+
"A"
|
60 |
+
]
|
61 |
+
},
|
62 |
+
{
|
63 |
+
"question": "A company containerized a Windows job that runs on .NET 6 Framework under a Windows container. The company wants to run this job in the AWS Cloud. The job runs every 10 minutes. The job's runtime varies between 1 minute and 3 minutes. Which solution will meet these requirements MOST cost-effectively?",
|
64 |
+
"options": [
|
65 |
+
"Create an AWS Lambda function based on the container image of the job. Configure Amazon EventBridge to invoke the function every 10 minutes.",
|
66 |
+
"Use AWS Batch to create a job that uses AWS Fargate resources. Configure the job scheduling to run every 10 minutes.",
|
67 |
+
"Use Amazon Elastic Container Service (Amazon ECS) on AWS Fargate to run the job. Create a scheduled task based on the container image of the job to run every 10 minutes.",
|
68 |
+
"Use Amazon Elastic Container Service (Amazon ECS) on AWS Fargate to run the job. Create a standalone task based on the container image of the job. Use Windows task scheduler to run the job every 10 minutes."
|
69 |
+
],
|
70 |
+
"correct": [
|
71 |
+
"A"
|
72 |
+
]
|
73 |
+
},
|
74 |
+
{
|
75 |
+
"question": "A company has a nightly batch processing routine that analyzes report files that an on- premises file system receives daily through SFTP. The company wants to move the solution to the AWS Cloud. The solution must be highly available and resilient. The solution also must minimize operational effort. Which solution meets these requirements?",
|
76 |
+
"options": [
|
77 |
+
"Deploy AWS Transfer for SFTP and an Amazon Elastic File System (Amazon EFS) file system for storage. Use an Amazon EC2 instance in an Auto Scaling group with a scheduled scaling policy to run the batch operation.",
|
78 |
+
"Deploy an Amazon EC2 instance that runs Linux and an SFTP service. Use an Amazon Elastic Block Store {Amazon EBS) volume for storage. Use an Auto Scaling group with the minimum number of instances and desired number of instances set to 1.",
|
79 |
+
"Deploy an Amazon EC2 instance that runs Linux and an SFTP service. Use an Amazon Elastic File System (Amazon EFS) file system for storage. Use an Auto Scaling group with the minimum number of instances and desired number of instances set to 1.",
|
80 |
+
"Deploy AWS Transfer for SFTP and an Amazon S3 bucket for storage. Modify the application to pull the batch files from Amazon S3 to an Amazon EC2 instance for processing. Use an EC2 instance in an Auto Scaling group with a scheduled scaling policy to run the batch operation."
|
81 |
+
],
|
82 |
+
"correct": [
|
83 |
+
"D"
|
84 |
+
]
|
85 |
+
},
|
86 |
+
{
|
87 |
+
"question": "A solutions architect needs to copy files from an Amazon S3 bucket to an Amazon Elastic File System (Amazon EFS) file system and another S3 bucket. The files must be copied continuously. New files are added to the original S3 bucket consistently. The copied files should be overwritten only if the source file changes. Which solution will meet these requirements with the LEAST operational overhead?",
|
88 |
+
"options": [
|
89 |
+
"Create an AWS DataSync location for both the destination S3 bucket and the EFS file system. Create a task for the destination S3 bucket and the EFS file system. Set the transfer mode to transfer only data that has changed.",
|
90 |
+
"Create an AWS Lambda function. Mount the file system to the function. Set up an S3 event notification to invoke the function when files are created and changed in Amazon S3. Configure the function to copy files to the file system and the destination S3 bucket.",
|
91 |
+
"Create an AWS DataSync location for both the destination S3 bucket and the EFS file system. Create a task for the destination S3 bucket and the EFS file system. Set the transfer mode to transfer all data.",
|
92 |
+
"Launch an Amazon EC2 instance in the same VPC as the file system. Mount the file system. Create a script to routinely synchronize all objects that changed in the origin S3 bucket to the destination S3 bucket and the mounted file system."
|
93 |
+
],
|
94 |
+
"correct": [
|
95 |
+
"A"
|
96 |
+
]
|
97 |
+
},
|
98 |
+
{
|
99 |
+
"question": "A company is hosting a web application on AWS using a single Amazon EC2 instance that stores user- uploaded documents in an Amazon EBS volume. For better scalability and availability, the company duplicated the architecture and created a second EC2 instance and EBS volume in another Availability Zone placing both behind an Application Load Balancer After completing this change, users reported that, each time they refreshed the website, they could see one subset of their documents or the other, but never all of the documents at the same time. What should a solutions architect propose to ensure users see all of their documents at once?",
|
100 |
+
"options": [
|
101 |
+
"Copy the data so both EBS volumes contain all the documents.",
|
102 |
+
"Configure the Application Load Balancer to direct a user to the server with the documents",
|
103 |
+
"Copy the data from both EBS volumes to Amazon EFS Modify the application to save new documents to Amazon EFS",
|
104 |
+
"Configure the Application Load Balancer to send the request to both servers Return each document from the correct server."
|
105 |
+
],
|
106 |
+
"correct": [
|
107 |
+
"C"
|
108 |
+
]
|
109 |
+
},
|
110 |
+
{
|
111 |
+
"question": "A company hosts a data lake on AWS. The data lake consists of data in Amazon S3 and Amazon RDS for PostgreSQL. The company needs a reporting solution that provides data visualization and includes all the data sources within the data lake. Only the company's management team should have full access to all the visualizations. The rest of the company should have only limited access. Which solution will meet these requirements?",
|
112 |
+
"options": [
|
113 |
+
"Create an analysis in Amazon QuickSight. Connect all the data sources and create new datasets. Publish dashboards to visualize the data. Share the dashboards with the appropriate IAM roles.",
|
114 |
+
"Create an analysis in Amazon OuickSighl. Connect all the data sources and create new datasets. Publish dashboards to visualize the data. Share the dashboards with the appropriate users and groups.",
|
115 |
+
"Create an AWS Glue table and crawler for the data in Amazon S3. Create an AWS Glue extract, transform, and load (ETL) job to produce reports. Publish the reports to Amazon S3. Use S3 bucket policies to limit access to the reports.",
|
116 |
+
"Create an AWS Glue table and crawler for the data in Amazon S3. Use Amazon Athena Federated Query to access data within Amazon RDS for PoslgreSQL. Generate reports by using Amazon Athena.Publish the reports to Amazon S3. Use S3 bucket policies to limit access to the reports."
|
117 |
+
],
|
118 |
+
"correct": [
|
119 |
+
"B"
|
120 |
+
]
|
121 |
+
},
|
122 |
+
{
|
123 |
+
"question": "A company runs an application that uses Amazon RDS for PostgreSQL The application receives traffic only on weekdays during business hours The company wants to optimize costs and reduce operational overhead based on this usage. Which solution will meet these requirements?",
|
124 |
+
"options": [
|
125 |
+
"Use the Instance Scheduler on AWS to configure start and stop schedules.",
|
126 |
+
"Turn off automatic backups. Create weekly manual snapshots of the database.",
|
127 |
+
"Create a custom AWS Lambda function to start and stop the database based on minimum CPU utilization.",
|
128 |
+
"Purchase All Upfront reserved DB instances"
|
129 |
+
],
|
130 |
+
"correct": [
|
131 |
+
"A"
|
132 |
+
]
|
133 |
+
},
|
134 |
+
{
|
135 |
+
"question": "A company hosts a marketing website in an on-premises data center. The website consists of static documents and runs on a single server. An administrator updates the website content infrequently and uses an SFTP client to upload new documents. The company decides to host its website on AWS and to use Amazon CloudFront. The company's solutions architect creates a CloudFront distribution. The solutions architect must design the most cost-effective and resilient architecture for website hosting to serve as the CloudFront origin. Which solution will meet these requirements?",
|
136 |
+
"options": [
|
137 |
+
"Create a virtual server by using Amazon Lightsail. Configure the web server in the Lightsail instance. Upload website content by using an SFTP client.",
|
138 |
+
"Create an AWS Auto Scaling group for Amazon EC2 instances. Use an Application Load Balancer. Upload website content by using an SFTP client.",
|
139 |
+
"Create a private Amazon S3 bucket. Use an S3 bucket policy to allow access from a CloudFront origin access identity (OAI). Upload website content by using theAWSCLI.",
|
140 |
+
"Create a public Amazon S3 bucket. Configure AWS Transfer for SFTP. Configure the S3 bucket for website hosting. Upload website content by using the SFTP client."
|
141 |
+
],
|
142 |
+
"correct": [
|
143 |
+
"C"
|
144 |
+
]
|
145 |
+
},
|
146 |
+
{
|
147 |
+
"question": "A company is creating an application that runs on containers in a VPC. The application stores and accesses data in an Amazon S3 bucket During the development phase, the application will store and access 1 TB of data in Amazon S3 each day. The company wants to minimize costs and wants to prevent traffic from traversing the internet whenever possible. Which solution will meet these requirements?",
|
148 |
+
"options": [
|
149 |
+
"Enable S3 Intelligent-Tiering for the S3 bucket.",
|
150 |
+
"Enable S3 Transfer Acceleration for the S3 bucket.",
|
151 |
+
"Create a gateway VPC endpoint for Amazon S3. Associate this endpoint with all route tables in the VPC.",
|
152 |
+
"Create an interface endpoint for Amazon S3 in the VPC. Associate this endpoint with all route tables in the VPC."
|
153 |
+
],
|
154 |
+
"correct": [
|
155 |
+
"C"
|
156 |
+
]
|
157 |
+
},
|
158 |
+
{
|
159 |
+
"question": "A company wants to run a gaming application on Amazon EC2 instances that are part of an Auto Scaling group in the AWS Cloud. The application will transmit data by using UDP packets. The company wants to ensure that the application can scale out and in as traffic increases and decreases. What should a solutions architect do to meet these requirements?",
|
160 |
+
"options": [
|
161 |
+
"Attach a Network Load Balancer to the Auto Scaling group",
|
162 |
+
"Attach an Application Load Balancer to the Auto Scaling group.",
|
163 |
+
"Deploy an Amazon Route 53 record set with a weighted policy to route traffic appropriately",
|
164 |
+
"Deploy a NAT instance that is configured with port forwarding to the EC2 instances in the Auto Scaling group."
|
165 |
+
],
|
166 |
+
"correct": [
|
167 |
+
"A"
|
168 |
+
]
|
169 |
+
},
|
170 |
+
{
|
171 |
+
"question": "A company has an application that is running on Amazon EC2 instances A solutions architect has standardized the company on a particular instance family and various instance sizes based on the current needs of the company. The company wants to maximize cost savings for the application over the next 3 years. The company needs to be able to change the instance family and sizes in the next 6 months based on application popularity and usage Which solution will meet these requirements MOST cost-effectively?",
|
172 |
+
"options": [
|
173 |
+
"Compute Savings Plan",
|
174 |
+
"EC2 Instance Savings Plan",
|
175 |
+
"Zonal Reserved Instances",
|
176 |
+
"Standard Reserved Instances"
|
177 |
+
],
|
178 |
+
"correct": [
|
179 |
+
"A"
|
180 |
+
]
|
181 |
+
},
|
182 |
+
{
|
183 |
+
"question": "A company hosts multiple applications on AWS for different product lines. The applications use different compute resources, including Amazon EC2 instances and Application Load Balancers. The applications run in different AWS accounts under the same organization in AWS Organizations across multiple AWS Regions. Teams for each product line have tagged each compute resource in the individual accounts. The company wants more details about the cost for each product line from the consolidated billing feature in Organizations. Which combination of steps will meet these requirements? (Select TWO.)",
|
184 |
+
"options": [
|
185 |
+
"Select a specific AWS generated tag in the AWS Billing console.",
|
186 |
+
"Select a specific user-defined tag in the AWS Billing console.",
|
187 |
+
"Select a specific user-defined tag in the AWS Resource Groups console.",
|
188 |
+
"Activate the selected tag from each AWS account.",
|
189 |
+
"Activate the selected tag from the Organizations management account."
|
190 |
+
],
|
191 |
+
"correct": [
|
192 |
+
"B",
|
193 |
+
"E"
|
194 |
+
]
|
195 |
+
},
|
196 |
+
{
|
197 |
+
"question": "A company recently signed a contract with an AWS Managed Service Provider (MSP) Partner for help with an application migration initiative. A solutions architect needs to share an Amazon Machine Image (AMI) from an existing AWS account with the MSP Partner's AWS account. The AMI is backed by Amazon Elastic Block Store (Amazon EBS) and uses a customer managed customer master key (CMK) to encrypt EBS volume snapshots. What is the MOST secure way for the solutions architect to share the AMI with the MSP Partner's AWS account?",
|
198 |
+
"options": [
|
199 |
+
"Make the encrypted AMI and snapshots publicly available. Modify the CMK's key policy to allow the MSP Partner's AWS account to use the key",
|
200 |
+
"Modify the launchPermission property of the AMI. Share the AMI with the MSP Partner's AWS account only. Modify the CMK's key policy to allow the MSP Partner's AWS account to use the key.",
|
201 |
+
"Modify the launchPermission property of the AMI Share the AMI with the MSP Partner's AWS account only. Modify the CMK's key policy to trust a new CMK that is owned by the MSP Partner for encryption.",
|
202 |
+
"Export the AMI from the source account to an Amazon S3 bucket in the MSP Partner's AWS account.Encrypt the S3 bucket with a CMK that is owned by the MSP Partner Copy and launch the AMI in the MSP Partner's AWS account."
|
203 |
+
],
|
204 |
+
"correct": [
|
205 |
+
"B"
|
206 |
+
]
|
207 |
+
},
|
208 |
+
{
|
209 |
+
"question": "What should a solutions architect do to ensure that all objects uploaded to an Amazon S3 bucket are encrypted?",
|
210 |
+
"options": [
|
211 |
+
"Update the bucket policy to deny if the PutObject does not have an s3 x-amz-acl header set",
|
212 |
+
"Update the bucket policy to deny if the PutObject does not have an s3:x-amz-aci header set to private.",
|
213 |
+
"Update the bucket policy to deny if the PutObject does not have an aws SecureTransport header set to true",
|
214 |
+
"Update the bucket policy to deny if the PutObject does not have an x-amz-server-side-encryption header set."
|
215 |
+
],
|
216 |
+
"correct": [
|
217 |
+
"D"
|
218 |
+
]
|
219 |
+
},
|
220 |
+
{
|
221 |
+
"question": "A company has an On-premises volume backup solution that has reached its end of life. The company wants to use AWS as part of a new backup solution and wants to maintain local access to all the data while it is backed up on AWS. The company wants to ensure that the data backed up on AWS is automatically and securely transferred. Which solution meets these requirements?",
|
222 |
+
"options": [
|
223 |
+
"Use AWS Snowball to migrate data out of the on-premises solution to Amazon S3. Configure on- premises systems to mount the Snowball S3 endpoint to provide local access to the data.",
|
224 |
+
"Use AWS Snowball Edge to migrate data out of the on-premises solution to Amazon S3.Use the Snowball Edge file interface to provide on-premises systems with local access to the data.",
|
225 |
+
"Use AWS Storage Gateway and configure a cached volume gateway. Run the Storage Gateway software application on premises and configure a percentage of data to cache locally. Mount the gateway storage volumes to provide local access to the data.",
|
226 |
+
"Use AWS Storage Gateway and configure a stored volume gateway. Run the Storage software 11 application on premises and map the gateway storage volumes to on-premises storage. Mount the gateway storage volumes to provide local access to the data."
|
227 |
+
],
|
228 |
+
"correct": [
|
229 |
+
"D"
|
230 |
+
]
|
231 |
+
},
|
232 |
+
{
|
233 |
+
"question": "A company's website handles millions of requests each day, and the number of requests continues to increase. A solutions architect needs to improve the response time of the web application. The solutions architect determines that the application needs to decrease latency when retrieving product details from the Amazon DynamoDB table. Which solution will meet these requirements with the LEAST amount of operational overhead?",
|
234 |
+
"options": [
|
235 |
+
"Set up a DynamoDB Accelerator (DAX) cluster. Route all read requests through DAX.",
|
236 |
+
"Set up Amazon ElastiCache for Redis between the DynamoDB table and the web application. Route all read requests through Redis.",
|
237 |
+
"Set up Amazon ElastiCache for Memcached between the DynamoDB table and the web application. Route all read requests through Memcached.",
|
238 |
+
"Set up Amazon DynamoDB Streams on the table, and have AWS Lambda read from the table and populate Amazon ElastiCache. Route all read requests through ElastiCache."
|
239 |
+
],
|
240 |
+
"correct": [
|
241 |
+
"A"
|
242 |
+
]
|
243 |
+
},
|
244 |
+
{
|
245 |
+
"question": "A company is designing an application where users upload small files into Amazon S3. After a user uploads a file, the file requires one-time simple processing to transform the data and save the data in JSON format for later analysis. Each file must be processed as quickly as possible after it is uploaded. Demand will vary. On some days, users will upload a high number of files. On other days, users will upload a few files or no files. Which solution meets these requirements with the LEAST operational overhead?",
|
246 |
+
"options": [
|
247 |
+
"Configure Amazon EMR to read text files from Amazon S3. Run processing scripts to transform the data. Store the resulting JSON file in an Amazon Aurora DB cluster.",
|
248 |
+
"Configure Amazon S3 to send an event notification to an Amazon Simple Queue Service (Amazon SQS) queue. Use Amazon EC2 instances to read from the queue and process the data. Store the resulting JSON file in Amazon DynamoDB.",
|
249 |
+
"Configure Amazon S3 to send an event notification to an Amazon Simple Queue Service (Amazon SQS) queue. Use an AWS Lambda function to read from the queue and process the data. Store the resulting JSON file in Amazon DynamoDB. Most Voted",
|
250 |
+
"Configure Amazon EventBridge (Amazon CloudWatch Events) to send an event to Amazon Kinesis Data Streams when a new file is uploaded. Use an AWS Lambda function to consume the event from the stream and process the data. Store the resulting JSON file in Amazon Aurora DB cluster."
|
251 |
+
],
|
252 |
+
"correct": [
|
253 |
+
"C"
|
254 |
+
]
|
255 |
+
},
|
256 |
+
{
|
257 |
+
"question": "A law firm needs to share information with the public The information includes hundreds of files that must be publicly readable Modifications or deletions of the files by anyone before a designated future date are prohibited. Which solution will meet these requirements in the MOST secure way?",
|
258 |
+
"options": [
|
259 |
+
"Upload all files to an Amazon S3 bucket that is configured for static website hosting. Grant read- only 1AM permissions to any AWS principals that access the S3 bucket until the designated date.",
|
260 |
+
"Create a new Amazon S3 bucket with S3 Versioning enabled Use S3 Object Lock with a retention period in accordance with the designated date Configure the S3 bucket for static website hosting. Set an S3 bucket policy to allow read-only access to the objrcts.",
|
261 |
+
"Create a new Amazon S3 bucket with S3 Versioning enabled Configure an event trigger to run an AWS Lambda function in case of object modification or deletion. Configure the Lambda function to replace the objects with the original versions from a private S3 bucket.",
|
262 |
+
"Upload all files to an Amazon S3 bucket that is configured for static website hosting. Select the folder that contains the files. Use S3 Object Lock with a retention period in accordance with the designated date. Grant read-only 1AM permissions to any AWS principals that access the S3 bucket."
|
263 |
+
],
|
264 |
+
"correct": [
|
265 |
+
"B"
|
266 |
+
]
|
267 |
+
},
|
268 |
+
{
|
269 |
+
"question": "A company stores call transcript files on a monthly basis. Users access the files randomly within 1 year of the call, but users access the files infrequently after 1 year. The company wants to optimize its solution by giving users the ability to query and retrieve files that are less than 1-year-old as quickly as possible. A delay in retrieving older files is acceptable. Which solution will meet these requirements MOST cost-effectively?",
|
270 |
+
"options": [
|
271 |
+
"Store individual files with tags in Amazon S3 Glacier Instant Retrieval. Query the tags to retrieve the files from S3 Glacier Instant Retrieval.",
|
272 |
+
"Store individual files in Amazon S3 Intelligent-Tiering. Use S3 Lifecycle policies to move the files to S3 Glacier Flexible Retrieval after 1 year. Query and retrieve the files that are in Amazon S3 by using Amazon Athena. Query and retrieve the files that are in S3 Glacier by using S3 Glacier Select.",
|
273 |
+
"Store individual files with tags in Amazon S3 Standard storage. Store search metadata for each archive in Amazon S3 Standard storage. Use S3 Lifecycle policies to move the files to S3 Glacier Instant Retrieval after 1 year. Query and retrieve the files by searching for metadata from Amazon S3 .",
|
274 |
+
"Store individual files in Amazon S3 Standard storage. Use S3 Lifecycle policies to move the files to S3 Glacier Deep Archive after 1 year. Store search metadata in Amazon RDS. Query the files from Amazon RDS. Retrieve the files from S3 Glacier Deep Archive."
|
275 |
+
],
|
276 |
+
"correct": [
|
277 |
+
"B"
|
278 |
+
]
|
279 |
+
},
|
280 |
+
{
|
281 |
+
"question": "A company has two VPCs named Management and Production. The Management VPC uses VPNs through a customer gateway to connect to a single device in the data center. The Production VPC uses a virtual private gateway AWS Direct Connect connections. The Management and Production VPCs both use a single VPC peering connection to allow communication between the What should a solutions architect do to mitigate any single point of failure in this architecture?",
|
282 |
+
"options": [
|
283 |
+
"Add a set of VPNs between the Management and Production VPCs.",
|
284 |
+
"Add a second virtual private gateway and attach it to the Management VPC.",
|
285 |
+
"Add a second set of VPNs to the Management VPC from a second customer gateway device.",
|
286 |
+
"Add a second VPC peering connection between the Management VPC and the Production VPC."
|
287 |
+
],
|
288 |
+
"correct": [
|
289 |
+
"C"
|
290 |
+
]
|
291 |
+
},
|
292 |
+
{
|
293 |
+
"question": "A company is designing a microservice-based architecture tor a new application on AWS. Each microservice will run on its own set of Amazon EC2 instances. Each microservice will need to interact with multiple AWS services such as Amazon S3 and Amazon Simple Queue Service (Amazon SQS). The company wants to manage permissions for each EC2 instance based on the principle of least privilege. Which solution will meet this requirement?",
|
294 |
+
"options": [
|
295 |
+
"Assign an 1AM user to each micro-service. Use access keys stored within the application code to authenticate AWS service requests.",
|
296 |
+
"Create a single 1AM role that has permission to access all AWS services. Associate the 1AM role with all EC2 instances that run the microservices",
|
297 |
+
"Use AWS Organizations to create a separate account for each microservice. Manage permissions at the account level.",
|
298 |
+
"Create individual 1AM roles based on the specific needs of each microservice. Associate the 1AM roles with the appropriate EC2 instances."
|
299 |
+
],
|
300 |
+
"correct": [
|
301 |
+
"D"
|
302 |
+
]
|
303 |
+
},
|
304 |
+
{
|
305 |
+
"question": "A company has created a multi-tier application for its ecommerce website. The website uses an Application Load Balancer that resides in the public subnets, a web tier in the public subnets, and a MySQL cluster hosted on Amazon EC2 instances in the private subnets. The MySQL database needs to retrieve product catalog and pricing information that is hosted on the internet by a third-party provider. A solutions architect must devise a strategy that maximizes security without increasing operational overhead. What should the solutions architect do to meet these requirements?",
|
306 |
+
"options": [
|
307 |
+
"Deploy a NAT instance in the VPC. Route all the internet-based traffic through the NAT instance.",
|
308 |
+
"Deploy a NAT gateway in the public subnets. Modify the private subnet route table to direct all internet- bound traffic to the NAT gateway.",
|
309 |
+
"Configure an internet gateway and attach it to the VPC. Modify the private subnet route table to direct internet-bound traffic to the internet gateway.",
|
310 |
+
"Configure a virtual private gateway and attach it to the VPC. Modify the private subnet route table to direct internet-bound traffic to the virtual private gateway."
|
311 |
+
],
|
312 |
+
"correct": [
|
313 |
+
"B"
|
314 |
+
]
|
315 |
+
},
|
316 |
+
{
|
317 |
+
"question": "A company has a large data workload that runs for 6 hours each day. The company cannot lose any data while the process is running. A solutions architect is designing an Amazon EMR cluster configuration to support this critical data workload. Which solution will meet these requirements MOST cost-effectively?",
|
318 |
+
"options": [
|
319 |
+
"Configure a long-running cluster that runs the primary node and core nodes on On-Demand Instances and the task nodes on Spot Instances.",
|
320 |
+
"Configure a transient cluster that runs the primary node and core nodes on On-Demand Instances and the task nodes on Spot Instances.",
|
321 |
+
"Configure a transient cluster that runs the primary node on an On-Demand Instance and the core nodes and task nodes on Spot Instances.",
|
322 |
+
"Configure a long-running cluster that runs the primary node on an On-Demand Instance, the core nodes on Spot Instances, and the task nodes on Spot Instances."
|
323 |
+
],
|
324 |
+
"correct": [
|
325 |
+
"B"
|
326 |
+
]
|
327 |
+
},
|
328 |
+
{
|
329 |
+
"question": "A company is developing an application that provides order shipping statistics for retrieval by a REST API. The company wants to extract the shipping statistics, organize the data into an easy-to-read HTML format, and send the report to several email addresses at the same time every morning. Which combination of steps should a solutions architect take to meet these requirements? (Choose two.)",
|
330 |
+
"options": [
|
331 |
+
"Configure the application to send the data to Amazon Kinesis Data Firehose.",
|
332 |
+
"Use Amazon Simple Email Service (Amazon SES) to format the data and to send the report by email.",
|
333 |
+
"Create an Amazon EventBridge (Amazon CloudWatch Events) scheduled event that invokes an AWS Glue job to query the application's API for the data.",
|
334 |
+
"Create an Amazon EventBridge (Amazon CloudWatch Events) scheduled event that invokes an AWS Lambda function to query the application's API for the data.",
|
335 |
+
"Store the application data in Amazon S3. Create an Amazon Simple Notification Service (Amazon SNS) topic as an S3 event destination to send the report by"
|
336 |
+
],
|
337 |
+
"correct": [
|
338 |
+
"B",
|
339 |
+
"D"
|
340 |
+
]
|
341 |
+
},
|
342 |
+
{
|
343 |
+
"question": "A company is preparing a new data platform that will ingest real-time streaming data from multiple sources. The company needs to transform the data before writing the data to Amazon S3. The company needs the ability to use SQL to query the transformed data. Which solutions will meet these requirements? (Choose two.)",
|
344 |
+
"options": [
|
345 |
+
"Use Amazon Kinesis Data Streams to stream the data. Use Amazon Kinesis Data Analytics to transform the data. Use Amazon Kinesis Data Firehose to write the data to Amazon S3. Use Amazon Athena to query the transformed data from Amazon S3.",
|
346 |
+
"Use Amazon Managed Streaming for Apache Kafka (Amazon MSK) to stream the data. Use AWS Glue to transform the data and to write the data to Amazon S3. Use Amazon Athena to query the transformed data from Amazon S3.",
|
347 |
+
"Use AWS Database Migration Service (AWS DMS) to ingest the data. Use Amazon EMR to transform the data and to write the data to Amazon S3. Use Amazon Athena to query the transformed data from Amazon S3.",
|
348 |
+
"Use Amazon Managed Streaming for Apache Kafka (Amazon MSK) to stream the data. Use Amazon Kinesis Data Analytics to transform the data and to write the data to Amazon S3. Use the Amazon RDS query editor to query the transformed data from Amazon S3.",
|
349 |
+
"Use Amazon Kinesis Data Streams to stream the data. Use AWS Glue to transform the data. Use Amazon Kinesis Data Firehose to write the data to Amazon S3. Use the Amazon RDS query editor to query the transformed data from Amazon S3."
|
350 |
+
],
|
351 |
+
"correct": [
|
352 |
+
"A",
|
353 |
+
"B"
|
354 |
+
]
|
355 |
+
},
|
356 |
+
{
|
357 |
+
"question": "A company recently launched a new application for its customers. The application runs on multiple Amazon EC2 instances across two Availability Zones. End users use TCP to communicate with the application. The application must be highly available and must automatically scale as the number of users increases. Which combination of steps will meet these requirements MOST cost-effectively? (Select TWO.)",
|
358 |
+
"options": [
|
359 |
+
"Add a Network Load Balancer in front of the EC2 instances.",
|
360 |
+
"Configure an Auto Scaling group for the EC2 instances.",
|
361 |
+
"Add an Application Load Balancer in front of the EC2 instances.",
|
362 |
+
"Manually add more EC2 instances for the application.",
|
363 |
+
"Add a Gateway Load Balancer in front of the EC2 instances."
|
364 |
+
],
|
365 |
+
"correct": [
|
366 |
+
"A",
|
367 |
+
"B"
|
368 |
+
]
|
369 |
+
},
|
370 |
+
{
|
371 |
+
"question": "A company needs a solution to prevent AWS CloudFormation stacks from deploying AWS Identity and Access Management (1AM) resources that include an inline policy or \"*\" in the statement The solution must also prohibit deployment ot Amazon EC2 instances with public IP addresses The company has AWS Control Tower enabled in its organization in AWS Organizations. Which solution will meet these requirements?",
|
372 |
+
"options": [
|
373 |
+
"Use AWS Control Tower proactive controls to block deployment of EC2 instances with public IP addresses and inline policies with elevated access or \"*\"",
|
374 |
+
"Use AWS Control Tower detective controls to block deployment of EC2 instances with public IP addresses and inline policies with elevated access or \"\"",
|
375 |
+
"Use AWS Config to create rules for EC2 and 1AM compliance Configure the rules to run an AWS Systems Manager Session Manager automation to delete a resource when it is not compliant",
|
376 |
+
"Use a service control policy (SCP) to block actions for the EC2 instances and 1AM resources if the actions lead to noncompliance"
|
377 |
+
],
|
378 |
+
"correct": [
|
379 |
+
"D"
|
380 |
+
]
|
381 |
+
},
|
382 |
+
{
|
383 |
+
"question": "A company has a multi-tier payment processing application that is based on virtual machines (VMs). The communication between the tiers occurs asynchronously through a third-party middleware solution that guarantees exactly-once delivery. The company needs a solution that requires the least amount of infrastructure management. The solution must guarantee exactly-once delivery for application messaging Which combination of actions will meet these requirements? (Select TWO.) 22 21",
|
384 |
+
"options": [
|
385 |
+
"Use AWS Lambda for the compute layers in the architecture.",
|
386 |
+
"Use Amazon EC2 instances for the compute layers in the architecture.",
|
387 |
+
"Use Amazon Simple Notification Service (Amazon SNS) as the messaging component between the compute layers.",
|
388 |
+
"Use Amazon Simple Queue Service (Amazon SQS) FIFO queues as the messaging component between the compute layers.",
|
389 |
+
"Use containers that are based on Amazon Elastic Kubemetes Service (Amazon EKS) for the compute layers in the architecture."
|
390 |
+
],
|
391 |
+
"correct": [
|
392 |
+
"A",
|
393 |
+
"D"
|
394 |
+
]
|
395 |
+
},
|
396 |
+
{
|
397 |
+
"question": "A company has an application that runs on Amazon EC2 instances in a private subnet The application needs to process sensitive information from an Amazon S3 bucket The application must not use the internet to connect to the S3 bucket. Which solution will meet these requirements?",
|
398 |
+
"options": [
|
399 |
+
"Configure an internet gateway. Update the S3 bucket policy to allow access from the internet gateway Update the application to use the new internet gateway",
|
400 |
+
"Configure a VPN connection. Update the S3 bucket policy to allow access from the VPN connection. Update the application to use the new VPN connection.",
|
401 |
+
"Configure a NAT gateway. Update the S3 bucket policy to allow access from the NAT gateway. Update the application to use the new NAT gateway.",
|
402 |
+
"Configure a VPC endpoint. Update the S3 bucket policy to allow access from the VPC endpoint.Update the application to use the new VPC endpoint."
|
403 |
+
],
|
404 |
+
"correct": [
|
405 |
+
"D"
|
406 |
+
]
|
407 |
+
},
|
408 |
+
{
|
409 |
+
"question": "A solutions architect is implementing a document review application using an Amazon S3 bucket for storage. The solution must prevent accidental deletion of the documents and ensure that all versions of the documents are available. Users must be able to download, modify, and upload documents. Which combination of actions should be taken to meet these requirements? (Choose two.)",
|
410 |
+
"options": [
|
411 |
+
"Enable a read-only bucket ACL.",
|
412 |
+
"Enable versioning on the bucket.",
|
413 |
+
"Attach an IAM policy to the bucket.",
|
414 |
+
"Enable MFA Delete on the bucket.",
|
415 |
+
"Encrypt the bucket using AWS KMS."
|
416 |
+
],
|
417 |
+
"correct": [
|
418 |
+
"B",
|
419 |
+
"D"
|
420 |
+
]
|
421 |
+
},
|
422 |
+
{
|
423 |
+
"question": "A company has applications that run on Amazon EC2 instances. The EC2 instances connect to Amazon RDS databases by using an 1AM role that has associated policies. The company wants to use AWS Systems Manager to patch the EC2 instances without disrupting the running applications. Which solution will meet these requirements?",
|
424 |
+
"options": [
|
425 |
+
"Create a new 1AM role. Attach the AmazonSSMManagedlnstanceCore policy to the new 1AM role. Attach the new 1AM role to the EC2 instances and the existing 1AM role.",
|
426 |
+
"Create an 1AM user. Attach the AmazonSSMManagedlnstanceCore policy to the 1AM user. 24 23 Configure Systems Manager to use the 1AM user to manage the EC2 instances.",
|
427 |
+
"Enable Default Host Configuration Management in Systems Manager to manage the EC2 instances.",
|
428 |
+
"Remove the existing policies from the existing 1AM role. Add the AmazonSSMManagedlnstanceCore policy to the existing 1AM role."
|
429 |
+
],
|
430 |
+
"correct": [
|
431 |
+
"C"
|
432 |
+
]
|
433 |
+
}
|
434 |
+
]
|
requirements.txt
CHANGED
@@ -1,3 +1,4 @@
|
|
1 |
Flask
|
2 |
flask-socketio
|
|
|
3 |
matplotlib
|
|
|
1 |
Flask
|
2 |
flask-socketio
|
3 |
+
eventlet
|
4 |
matplotlib
|
static/script.js
CHANGED
@@ -29,12 +29,21 @@ function selectExam() {
|
|
29 |
document.getElementById('question-start-display').textContent = `Starting from question ${startQuestion}.`;
|
30 |
}
|
31 |
|
|
|
32 |
function loadQuiz() {
|
33 |
const examName = document.getElementById('exam-selector').value;
|
34 |
-
const startQuestion = document.getElementById('start-question-number').value;
|
35 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
36 |
}
|
37 |
|
|
|
|
|
38 |
function updateSliderValue(value) {
|
39 |
document.getElementById('start-question').value = value;
|
40 |
document.getElementById('start-question-number').value = value;
|
@@ -63,16 +72,27 @@ function restartQuiz() {
|
|
63 |
|
64 |
socket.on('quiz_loaded', (data) => {
|
65 |
if (data.success) {
|
66 |
-
alert(`Quiz loaded with ${data.num_questions} questions
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
67 |
} else {
|
68 |
-
alert(
|
69 |
}
|
70 |
});
|
71 |
|
|
|
72 |
socket.on('new_question', (data) => {
|
73 |
document.getElementById('waiting-message').style.display = 'none';
|
74 |
-
document.getElementById('question-text').innerText = data.question
|
75 |
-
// Dynamically generate letters for options (up to 'h')
|
76 |
const letters = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'];
|
77 |
const options = data.options.map((opt, index) =>
|
78 |
`<input type="radio" id="${letters[index]}" name="answer" value="${opt}">
|
@@ -81,6 +101,9 @@ socket.on('new_question', (data) => {
|
|
81 |
document.getElementById('options').innerHTML = options;
|
82 |
});
|
83 |
|
|
|
|
|
|
|
84 |
socket.on('display_results', (data) => {
|
85 |
const img = `<img src="data:image/png;base64,${data.chart}" alt="Results Chart" />`;
|
86 |
const resultText = `<p>Correct Answer: ${data.results.correct_answer}</p>`;
|
|
|
29 |
document.getElementById('question-start-display').textContent = `Starting from question ${startQuestion}.`;
|
30 |
}
|
31 |
|
32 |
+
|
33 |
function loadQuiz() {
|
34 |
const examName = document.getElementById('exam-selector').value;
|
35 |
+
const startQuestion = parseInt(document.getElementById('start-question-number').value, 10);
|
36 |
+
|
37 |
+
if (!examName) {
|
38 |
+
alert("Please select an exam first.");
|
39 |
+
return;
|
40 |
+
}
|
41 |
+
|
42 |
+
socket.emit('load_quiz', { exam_name: examName, start_question: startQuestion });
|
43 |
}
|
44 |
|
45 |
+
|
46 |
+
|
47 |
function updateSliderValue(value) {
|
48 |
document.getElementById('start-question').value = value;
|
49 |
document.getElementById('start-question-number').value = value;
|
|
|
72 |
|
73 |
socket.on('quiz_loaded', (data) => {
|
74 |
if (data.success) {
|
75 |
+
alert(`Quiz loaded with ${data.num_questions} questions.`);
|
76 |
+
const startQuestionInput = document.getElementById('start-question');
|
77 |
+
const startQuestionNumber = document.getElementById('start-question-number');
|
78 |
+
startQuestionInput.max = data.num_questions;
|
79 |
+
startQuestionNumber.max = data.num_questions;
|
80 |
+
startQuestionInput.value = data.start_question;
|
81 |
+
startQuestionNumber.value = data.start_question;
|
82 |
+
document.getElementById('question-start-display').textContent = `Starting from question ${data.start_question}.`;
|
83 |
+
document.getElementById('start-question-label').style.display = 'block';
|
84 |
+
startQuestionInput.style.display = 'block';
|
85 |
+
startQuestionNumber.style.display = 'block';
|
86 |
+
document.getElementById('question-start-display').style.display = 'block';
|
87 |
} else {
|
88 |
+
alert("Failed to load quiz. Please try again.");
|
89 |
}
|
90 |
});
|
91 |
|
92 |
+
|
93 |
socket.on('new_question', (data) => {
|
94 |
document.getElementById('waiting-message').style.display = 'none';
|
95 |
+
document.getElementById('question-text').innerText = `Question ${data.index}: ${data.question}`;
|
|
|
96 |
const letters = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'];
|
97 |
const options = data.options.map((opt, index) =>
|
98 |
`<input type="radio" id="${letters[index]}" name="answer" value="${opt}">
|
|
|
101 |
document.getElementById('options').innerHTML = options;
|
102 |
});
|
103 |
|
104 |
+
|
105 |
+
|
106 |
+
|
107 |
socket.on('display_results', (data) => {
|
108 |
const img = `<img src="data:image/png;base64,${data.chart}" alt="Results Chart" />`;
|
109 |
const resultText = `<p>Correct Answer: ${data.results.correct_answer}</p>`;
|
templates/host.html
CHANGED
@@ -17,10 +17,10 @@
|
|
17 |
<option value="{{ exam }}">{{ exam }}</option>
|
18 |
{% endfor %}
|
19 |
</select>
|
20 |
-
<label for="start-question" class="mt-3">Select starting question:</label>
|
21 |
-
<input type="range" id="start-question" min="1" max="10" value="1" class="form-range mt-2 mb-2" oninput="updateSliderValue(this.value)">
|
22 |
-
<input type="number" id="start-question-number" min="1" max="10" value="1" class="form-control" oninput="updateSliderValue(this.value)">
|
23 |
-
<p id="question-start-display" class="mt-2">Starting from question 1.</p>
|
24 |
<button onclick="loadQuiz()" class="btn btn-info mt-3">Load Quiz</button><br><br>
|
25 |
<button onclick="startQuiz()" class="btn btn-success mt-3">Start Quiz</button><br><br>
|
26 |
<button onclick="restartQuiz()" class="btn btn-warning mt-3">Restart</button><br><br>
|
|
|
17 |
<option value="{{ exam }}">{{ exam }}</option>
|
18 |
{% endfor %}
|
19 |
</select>
|
20 |
+
<label for="start-question" id="start-question-label" class="mt-3" style="display: none;">Select starting question:</label>
|
21 |
+
<input type="range" id="start-question" min="1" max="10" value="1" class="form-range mt-2 mb-2" style="display: none;" oninput="updateSliderValue(this.value)">
|
22 |
+
<input type="number" id="start-question-number" min="1" max="10" value="1" class="form-control" style="display: none;" oninput="updateSliderValue(this.value)">
|
23 |
+
<p id="question-start-display" class="mt-2" style="display: none;">Starting from question 1.</p>
|
24 |
<button onclick="loadQuiz()" class="btn btn-info mt-3">Load Quiz</button><br><br>
|
25 |
<button onclick="startQuiz()" class="btn btn-success mt-3">Start Quiz</button><br><br>
|
26 |
<button onclick="restartQuiz()" class="btn btn-warning mt-3">Restart</button><br><br>
|