I ran into a little issue today parsing a S3 SQS event that was sent to Lambda via a SQS trigger. I assumed the incoming event to Lambda was 100% of type dict. Given this, I assumed I could pull the bucket name and key using this syntax.
bucketname = event['Records']['body']['Records']['s3']['bucket']['name']
objectname = event['Records']['body']['Records']['s3']['object']['key']
As it turns out the incoming event is not 100% of type dict and I got the following error.
string indices must be integers
The Records after the body ([‘Records’][‘body’]) are of type str. Below is the updated code to pull the bucket name and key from the incoming event.
event_body_records_string = event['Records']['body']
event_body_records_dict = json.loads(event_body_records_string)
bucketname = event_body_records_dict['Records']['s3']['bucaket']['name']
objectname = event_body_records_dict['Records']['s3']['object']['key']
Now everything works out great!!!
Great link that explains how to grab InstanceId from a AWS CLI query when filtering by tag info!!! Huge time saver!!!
When using the “receive_message” Python Boto function to pull message(s) from a SQS queue, you will always get a response back when the command completes. However, how do you determine if the response you got back actually contains a valid message?
response = sqs.receive_message
if 'Messages' in response:
print("Message on the queue to process")
print("No messages on the queue to process")
Thats about it!!
Its time to study for AWS Certification #3. I took a little time off, but no more! This time I am going for the SysOps Administrator – Associate certificate. I guess its a little harder than the other 2 certifications I passed, but still within range!
Whats hard about some of these certifications is you don’t actually work with all covered material day-to-day. Spinning up EC2 instances and creating security groups it pretty standard, but when it comes to things like networking, those tasks are not typically done by me.
So my plan is going to be the following to pass the exam:
- Listen to a training course from acloud.guru on the way to and from work. (Long commute both ways)
- Practice heavily in AWS on all the relevant topics.
- Use the practice exam voucher I received from passing previous certifications to pay for an official AWS SysOps practice exam.
- Rely on personal experience.
Passed the AWS Certified Solutions Architect – Associate (Released February 2018) exam today!
These exams are both fun and a little stressful, but you do learn a lot while studying!!!
Will post the overall score results when I get them!
I’m getting ready to take the AWS Solutions Architect Associate 2018 test. Below are some final items I need to review before the exam.
- Spot vs Spot Block
- Application ELB vs Classic ELB
- Convertible vs. Standard Reserved Instances
- EBS Cost vs Performance
- EC2 reverse proxy (link) (link)
- Glacier Retrieval Options
- Beanstalk vs. NGINX
- Cross-region snapshots for databases
Passed the AWS Certified Developer – Associate exam! My broad study plan worked great!
Below are my results.
|Overall Score: 96%
|Topic Level Scoring:
1.0 AWS Fundamentals: 100%
2.0 Designing and Developing: 100%
3.0 Deployment and Security: 87%
4.0 Debugging: 100%
Next step is to attempt the AWS Certified Solutions Architect – Associate exam.