SlideShare a Scribd company logo
1 of 57
BUILDING A SMART
SECURITY CAMERA WITH
A PI ZERO, NODE.JS &
THE CLOUD
MARK WEST
@markawest
Kraków, 17-19 May 2017
BUILDING A SMART
SECURITY CAMERA
WITH PI ZERO, JAVA
AND AWS
MARK WEST
Prague, 19-20 October 2017
Who Am I?
• IT Consultant at Bouvet.
• Hacker and Maker.
• Java, JavaScript, AI, Cloud & IoT.
• Active member of javaBin - the
Norwegian JUG.
@markawest
Talk Outline
Motivation
and
Requirements
Building a
Motion
Activated
Camera
Adding Smart
Image
Analysis with
AWS
Evaluation
and Tips
Node.js vs
Java Lambda
Functions
@markawest
Motivation and Requirements
Input from Stakeholder
Motivation
and
Requirements
Building a
Motion
Activated
Camera
Adding Smart
Image Analysis
with AWS
Evaluation and
Tips
Node.js vs Java
@markawest
Initial Motivation
@markawest
Project Requirements
Functional
• Monitor activity in the
garden.
• Send warning when activity
detected.
• Live video stream.
Non-functional
• In place as soon as possible.
• Low cost.
• Portable.
@markawest
Functional Design
1. Activity
in garden
2. Camera
detects
movement
3. Camera sends
alert email with
snapshot
@markawest
Building a Motion Activated
Camera
Motivation
and
Requirements
Building a
Motion
Activated
Camera
Adding Smart
Image Analysis
with AWS
Evaluation and
Tips
Node.js vs Java
Lambda
Functions
@markawest
Pi Zero W Essentials Kit: €30
Camera Module: €28
Camera Adapter: €6
ZeroView: €9
Total Cost: €73
Hardware Shopping List
@markawest
Assembled Camera
Rear View Front View
@markawest
Implementing the Functional Design
1. Activity
in garden
2. Camera
detects
movement
3. Camera sends
alert email with
snapshot
@markawest
Motion
(https://motion-project.github.io)
• Open source motion detection software.
• Excellent performance on the Raspberry Pi Zero.
• Built-in Web Server for streaming video.
• Detected activity or ‘motion’ triggers events.
• Works out of the box. No need for additional programming.
@markawest
Motion
Streaming
Demo
@markawest
How the Motion Software works
1 2 3 4
@markawest
1 2 3
How the Motion Software works
1 2 3 4
1 2 3
@markawest
1 2 3
How the Motion Software works
1 2 3 4
1 2 3
@markawest
1 2 3
Alarm Snapshots from Web Camera
@markawest
Project Requirements : Evaluation
Functional
• Monitor activity in the
garden.
• Send warning when activity
detected.
• Live video stream.
Non-functional
• In place as soon as possible.
• Low cost.
• Portable.
@markawest
False Alarms from Web Camera
cat
cloud
@markawest
The Motion Software
focuses on the amount of
changed pixels, and not the
cause of the changed
pixels!
@markawest
Adding Smart Image Analysis
with AWS
Motivation
and
Requirements
Building a
Motion
Activated
Camera
Adding Smart
Image Analysis
with AWS
Evaluation and
Tips
Node.js vs Java
Lambda
Functions
@markawest
Improving Alarm Accuracy with
Smart Image Analysis
person
@markawest
cat
Project Requirements Reloaded
Functional
• Monitor activity in our
garden.
• Send warning when activity
detected.
• Live video stream.
Non-functional
• In place as soon as possible.
• Low cost.
• Portable.
@markawest
Project Requirements Reloaded
Functional
• Monitor activity in our
garden.
• Send warning when human
activity detected.
• Live video stream.
Non-functional
• In place as soon as possible.
• Low cost.
• Portable.
@markawest
AWS Rekognition
• Part of Amazon Web Services suite of Cloud based services.
• Image Analysis as a Service, offering a range of API’s.
• Built upon Deep Neural Networks.
• Officially launched in November 2016.
• Alternatives: Google Vision, MicroSoft Computer Vision, Clarafai.
@markawest
AWS Rekognition Demo
@markawest
Adding AWS to the Web Camera
Amazon Web Services (AWS)
Send warning
email (if snapshot
contains a person)
Snapshot analysed
via AWS
Rekognition
@markawest
Camera pushes
snapshot to AWS
Email alert sent
(with snapshot)
AWS IAM
AWS
Rekognition
AWS Simple
Email Service
AWS S3
(storage)
Amazon Web Service Flow
Overview
AWS Step Function
(workflow)
Upload
Trigger
1
2
4
5
6
calls
3
uses
uses
@markawest
AWS IAM
AWS
Rekognition
AWS Simple
Email Service
AWS S3
(storage)
AWS Lambda Functions
Code Building Blocks (aka Microservices)
AWS Step Function
(workflow)
Upload
Trigger calls
uses
uses
@markawest
AWS Lambda Functions
• Code units based on Java, C#, Python or Node.js
• Serverless, no infrastructure to manage.
• High availability out of the box.
• Pay as you go model based on total invocations and duration -
with a generous free tier.
• Native AWS SDK gives easy access to other AWS services.
@markawest
AWS Lambda Demo
@markawest
AWS IAM
AWS S3
(storage)
AWS Step Functions
Orchestration of Lambda Functions
AWS Step Function
(workflow)
Upload
Trigger calls
AWS
Rekognition
AWS Simple
Email Service
uses
uses
@markawest
AWS Step Functions
• Coordinate and orchestrate Lambda Functions into Workflows or
State Machines.
• Launched in December 2016.
• Defined via JSON files, displayed as visual workflows.
• Provide the same benefits as AWS Lambda (Highly Available,
Serverless, Scalable, “Pay as you go” pricing model).
@markawest
Step Function for Image Processing
Error
Handler
(sends
Error
Email via
AWS
SES)
Sends snapshot to AWS Rekognition
Evaluate AWS Rekognition response
Send Alert Email?
Send Alert Email
via AWS SES
Archive image in AWS S3
1
2
3
4
5
6 1
2
3
4
5
6
@markawest
Smart Camera
(plus AWS Step Function)
Demo
@markawest
Evaluation and Lessons
Learned
Motivation
and
Requirements
Building a
Motion
Activated
Camera
Adding Smart
Image Analysis
with AWS
Evaluation and
Tips
Node.js vs Java
Lambda
Functions
@markawest
Project Requirements : Evaluation
Functional
• Monitor activity in the
garden.
• Send warning when human
activity detected.
• Live video stream.
Non-functional
• In place as soon as possible.
• Low cost.
• Portable.
@markawest
“Fun project, but has it
caught any real criminals?”
@markawest
@markawest
AWS Monthly Cost : August 2017
@markawest
Rekognition:
EUR 2.89
SES: EUR 0.01S3: EUR 0.30
Step
Functions:
EUR 0.99
Tax: EUR 0.96
(Based on 8093 images processed)
Lambda: EUR 0.00
Activity Timeline
Which Image Should Motion Upload?
@markawest
Activity
Event
Start
1 Activity
Event
Stop
2 3 4 5
Activity Timeline
@markawest
Activity
Event
Start
1 Activity
Event
Stop
2 3 4 5
First
Picture
Which Image Should Motion Upload?
Activity Timeline
@markawest
Activity
Event
Start
1 Activity
Event
Stop
2 3 4 5
Most
Pixels
Changed
Which Image Should Motion Upload?
Activity Timeline
@markawest
Activity
Event
Start
1 Activity
Event
Stop
2 3 4 5
Most
Central
Activity
Which Image Should Motion Upload?
Activity Timeline
@markawest
Activity
Event
Start
1 Activity
Event
Stop
2 3 4 5
Upload all snapshots
Which Image Should Motion Upload?
Choosing an Image Upload Strategy
Upload One Snapshot to
Rekognition when
activity detected
•Lower cost, due to less
calls to the AWS stack.
•Potentially lower hit
rate.
Upload Many Snapshots
to Rekognition when
activity detected
•Higher cost due to
increased calls to AWS.
•Potentially higher hit
rate.
@markawest
Node.js vs Java
Motivation
and
Requirements
Building a
Motion
Activated
Camera
Adding Smart
Image Analysis
with AWS
Evaluation and
Tips
Node.js vs Java
Lambda
Functions
@markawest
Java 8 vs. Node.js 6.10
1. Artefact Sizes
2. Memory Requirements
3. Performance and Cost
@markawest
AWS Lambda Functions
@markawest
Lambda Function Purpose AWS Service Calls
rekognition-image-
assessment
Uses AWS Rekognition to generate a
list of labels describing each
uploaded picture.
AWS Rekognition
rekognition-evaluate-labels
Evaluates labels to find out if an
alarm email should be sent.
-
ses-send-notification
Sends an alarm email via AWS SES
when the smart security camera
detects a person.
AWS SES
s3-archive-image
Moves the processed image to the
correct archive location in S3.
AWS S3
Artefact Sizes
3 Reasons for the difference:
1. Java is generally more
verbose.
2. Unused JAR’s in Java
Deployments.
3. AWS SDK is natively
available to Node.js
Lambda Functions.
@markawest
Lambda Function Java Node
rekognition-image-
assessment
7.9
MB
813
bytes
rekognition-evaluate-
labels
7.6
MB
677
bytes
ses-send-notification
8.7
MB
4.8
MB
s3-archive-image
7.6
MB
943
bytes
Memory Requirements
Memory
Allocated
AWS Free
Seconds Per
Month
AWS Price
Per Second
128 MB 3 200 000 $0.00000208
192 MB 2 133 333 $0.00000313
256 MB 1 600 000 $0.00000417
1536 MB 266 667 $0.00002501
@markawest
• My Node.js 6.10 Lambda
Functions were happy with
128 MB memory.
• My Java 8 Lambda
Functions required 256 MB
to avoid OutOfMemory
Errors.
Testing Cost & Performance : Method
• Simulate 1500 alerts (not false alarms).
• Triggered in batches of 30, with a 60 second pause.
• Memory set to 256 MB for both Node.js and Java.
• Prior to testing, Lambda Functions “rested” for 90 minutes.
• Ran tests 5 times to ensure consistency of results.
@markawest
Test Results
@markawest
Lambda Function
Average
Duration Java
Average
Duration Node.js
rekognition-image-assessment 2250 ms 1720 ms
rekognition-evaluate-labels 6.57 ms 1.61 ms
ses-send-notification 3040 ms 996 ms
s3-archive-image 1050 ms 364 ms
Why was Java slower on AWS Lambda?
• Cold Starts (5-10 times longer on Java).
• Lack of JVM tuning options on AWS.
• Different underlying implementations.
• Use Case for Project Jigsaw?
@markawest
Does Java belong on AWS Lambda?
• Of course it does!
• Evaluate your use case and potential costs first.
• Try different memory settings to reduce costs.
• Remember the Free Tier!
@markawest
Would you like to know more?
markwest1972/smart-
security-camera
@markawest
slideshare.net/markawest
Slides Code
FOR
LISTENING!
@markawest
Kraków, 17-19 May 2017

More Related Content

What's hot

Getting Started with Serverless Architectures
Getting Started with Serverless ArchitecturesGetting Started with Serverless Architectures
Getting Started with Serverless ArchitecturesAmazon Web Services
 
AWS re:Invent 2016: Internet of Things (IoT) Edge and Device Services (IOT202)
AWS re:Invent 2016: Internet of Things (IoT) Edge and Device Services (IOT202)AWS re:Invent 2016: Internet of Things (IoT) Edge and Device Services (IOT202)
AWS re:Invent 2016: Internet of Things (IoT) Edge and Device Services (IOT202)Amazon Web Services
 
Serverless Computing: build and run applications without thinking about servers
Serverless Computing: build and run applications without thinking about serversServerless Computing: build and run applications without thinking about servers
Serverless Computing: build and run applications without thinking about serversAmazon Web Services
 
Working with microservices and Amazon ECS at Airtime
Working with microservices and Amazon ECS at AirtimeWorking with microservices and Amazon ECS at Airtime
Working with microservices and Amazon ECS at AirtimeAmazon Web Services
 
Getting Started with AWS Lambda and the Serverless Cloud
Getting Started with AWS Lambda and the Serverless CloudGetting Started with AWS Lambda and the Serverless Cloud
Getting Started with AWS Lambda and the Serverless CloudAmazon Web Services
 
(GAM401) Build a Serverless Mobile Game w/ Cognito, Lambda & DynamoDB
(GAM401) Build a Serverless Mobile Game w/ Cognito, Lambda & DynamoDB(GAM401) Build a Serverless Mobile Game w/ Cognito, Lambda & DynamoDB
(GAM401) Build a Serverless Mobile Game w/ Cognito, Lambda & DynamoDBAmazon Web Services
 
AWS 2016 re:Invent Launch Summary
AWS 2016 re:Invent Launch SummaryAWS 2016 re:Invent Launch Summary
AWS 2016 re:Invent Launch SummaryAmazon Web Services
 
10 Tips For Serverless Backends With NodeJS and AWS Lambda
10 Tips For Serverless Backends With NodeJS and AWS Lambda10 Tips For Serverless Backends With NodeJS and AWS Lambda
10 Tips For Serverless Backends With NodeJS and AWS LambdaJim Lynch
 
ARC201 Microservices Architecture @ AWS re:Invent 2015
ARC201 Microservices Architecture @ AWS re:Invent 2015ARC201 Microservices Architecture @ AWS re:Invent 2015
ARC201 Microservices Architecture @ AWS re:Invent 2015Mitoc Group
 
Serverless archtiectures
Serverless archtiecturesServerless archtiectures
Serverless archtiecturesIegor Fadieiev
 
AWS re:Invent 2016: 1-Click Enterprise Innovation with the AWS IoT Button (IO...
AWS re:Invent 2016: 1-Click Enterprise Innovation with the AWS IoT Button (IO...AWS re:Invent 2016: 1-Click Enterprise Innovation with the AWS IoT Button (IO...
AWS re:Invent 2016: 1-Click Enterprise Innovation with the AWS IoT Button (IO...Amazon Web Services
 
AWS Step Functions - Dev lounge Express Edition.pdf
AWS Step Functions - Dev lounge Express Edition.pdfAWS Step Functions - Dev lounge Express Edition.pdf
AWS Step Functions - Dev lounge Express Edition.pdfAmazon Web Services
 
A Brief Look at Serverless Architecture
A Brief Look at Serverless ArchitectureA Brief Look at Serverless Architecture
A Brief Look at Serverless ArchitectureAmazon Web Services
 
AWS Innovate: Building an Internet Connected Camera with AWS IoT- Tim Cruse
AWS Innovate: Building an Internet Connected Camera with AWS IoT- Tim CruseAWS Innovate: Building an Internet Connected Camera with AWS IoT- Tim Cruse
AWS Innovate: Building an Internet Connected Camera with AWS IoT- Tim CruseAmazon Web Services Korea
 
AWS re:Invent 2016: All Your Chats are Belong to Bots: Building a Serverless ...
AWS re:Invent 2016: All Your Chats are Belong to Bots: Building a Serverless ...AWS re:Invent 2016: All Your Chats are Belong to Bots: Building a Serverless ...
AWS re:Invent 2016: All Your Chats are Belong to Bots: Building a Serverless ...Amazon Web Services
 
How to Connect Your Own Creations with AWS IoT - DevDay Los Angeles 2017
How to Connect Your Own Creations with AWS IoT - DevDay Los Angeles 2017How to Connect Your Own Creations with AWS IoT - DevDay Los Angeles 2017
How to Connect Your Own Creations with AWS IoT - DevDay Los Angeles 2017Amazon Web Services
 
Deep Dive: Developing, Deploying & Operating Mobile Apps with AWS
Deep Dive: Developing, Deploying & Operating Mobile Apps with AWS Deep Dive: Developing, Deploying & Operating Mobile Apps with AWS
Deep Dive: Developing, Deploying & Operating Mobile Apps with AWS Amazon Web Services
 
AWS Lambda: Event-driven Code in the Cloud
AWS Lambda: Event-driven Code in the CloudAWS Lambda: Event-driven Code in the Cloud
AWS Lambda: Event-driven Code in the CloudAmazon Web Services
 

What's hot (20)

Getting Started with Serverless Architectures
Getting Started with Serverless ArchitecturesGetting Started with Serverless Architectures
Getting Started with Serverless Architectures
 
AWS re:Invent 2016: Internet of Things (IoT) Edge and Device Services (IOT202)
AWS re:Invent 2016: Internet of Things (IoT) Edge and Device Services (IOT202)AWS re:Invent 2016: Internet of Things (IoT) Edge and Device Services (IOT202)
AWS re:Invent 2016: Internet of Things (IoT) Edge and Device Services (IOT202)
 
Serverless Computing: build and run applications without thinking about servers
Serverless Computing: build and run applications without thinking about serversServerless Computing: build and run applications without thinking about servers
Serverless Computing: build and run applications without thinking about servers
 
Working with microservices and Amazon ECS at Airtime
Working with microservices and Amazon ECS at AirtimeWorking with microservices and Amazon ECS at Airtime
Working with microservices and Amazon ECS at Airtime
 
Getting Started with AWS Lambda and the Serverless Cloud
Getting Started with AWS Lambda and the Serverless CloudGetting Started with AWS Lambda and the Serverless Cloud
Getting Started with AWS Lambda and the Serverless Cloud
 
(GAM401) Build a Serverless Mobile Game w/ Cognito, Lambda & DynamoDB
(GAM401) Build a Serverless Mobile Game w/ Cognito, Lambda & DynamoDB(GAM401) Build a Serverless Mobile Game w/ Cognito, Lambda & DynamoDB
(GAM401) Build a Serverless Mobile Game w/ Cognito, Lambda & DynamoDB
 
AWS 2016 re:Invent Launch Summary
AWS 2016 re:Invent Launch SummaryAWS 2016 re:Invent Launch Summary
AWS 2016 re:Invent Launch Summary
 
10 Tips For Serverless Backends With NodeJS and AWS Lambda
10 Tips For Serverless Backends With NodeJS and AWS Lambda10 Tips For Serverless Backends With NodeJS and AWS Lambda
10 Tips For Serverless Backends With NodeJS and AWS Lambda
 
ARC201 Microservices Architecture @ AWS re:Invent 2015
ARC201 Microservices Architecture @ AWS re:Invent 2015ARC201 Microservices Architecture @ AWS re:Invent 2015
ARC201 Microservices Architecture @ AWS re:Invent 2015
 
Serverless archtiectures
Serverless archtiecturesServerless archtiectures
Serverless archtiectures
 
AWS re:Invent 2016: 1-Click Enterprise Innovation with the AWS IoT Button (IO...
AWS re:Invent 2016: 1-Click Enterprise Innovation with the AWS IoT Button (IO...AWS re:Invent 2016: 1-Click Enterprise Innovation with the AWS IoT Button (IO...
AWS re:Invent 2016: 1-Click Enterprise Innovation with the AWS IoT Button (IO...
 
Introduction to Microservices
Introduction to MicroservicesIntroduction to Microservices
Introduction to Microservices
 
AWS Step Functions - Dev lounge Express Edition.pdf
AWS Step Functions - Dev lounge Express Edition.pdfAWS Step Functions - Dev lounge Express Edition.pdf
AWS Step Functions - Dev lounge Express Edition.pdf
 
Serverless Culture
Serverless CultureServerless Culture
Serverless Culture
 
A Brief Look at Serverless Architecture
A Brief Look at Serverless ArchitectureA Brief Look at Serverless Architecture
A Brief Look at Serverless Architecture
 
AWS Innovate: Building an Internet Connected Camera with AWS IoT- Tim Cruse
AWS Innovate: Building an Internet Connected Camera with AWS IoT- Tim CruseAWS Innovate: Building an Internet Connected Camera with AWS IoT- Tim Cruse
AWS Innovate: Building an Internet Connected Camera with AWS IoT- Tim Cruse
 
AWS re:Invent 2016: All Your Chats are Belong to Bots: Building a Serverless ...
AWS re:Invent 2016: All Your Chats are Belong to Bots: Building a Serverless ...AWS re:Invent 2016: All Your Chats are Belong to Bots: Building a Serverless ...
AWS re:Invent 2016: All Your Chats are Belong to Bots: Building a Serverless ...
 
How to Connect Your Own Creations with AWS IoT - DevDay Los Angeles 2017
How to Connect Your Own Creations with AWS IoT - DevDay Los Angeles 2017How to Connect Your Own Creations with AWS IoT - DevDay Los Angeles 2017
How to Connect Your Own Creations with AWS IoT - DevDay Los Angeles 2017
 
Deep Dive: Developing, Deploying & Operating Mobile Apps with AWS
Deep Dive: Developing, Deploying & Operating Mobile Apps with AWS Deep Dive: Developing, Deploying & Operating Mobile Apps with AWS
Deep Dive: Developing, Deploying & Operating Mobile Apps with AWS
 
AWS Lambda: Event-driven Code in the Cloud
AWS Lambda: Event-driven Code in the CloudAWS Lambda: Event-driven Code in the Cloud
AWS Lambda: Event-driven Code in the Cloud
 

Similar to GeeCON Prague : Building a Smart Security Camera with Raspberry Pi Zero, Java and AWS

DevExperience 2018 : Building a Smart Security Camera with Raspberry Pi Zero,...
DevExperience 2018 : Building a Smart Security Camera with Raspberry Pi Zero,...DevExperience 2018 : Building a Smart Security Camera with Raspberry Pi Zero,...
DevExperience 2018 : Building a Smart Security Camera with Raspberry Pi Zero,...Mark West
 
IoT Meetup Oslo - AI on Edge Devices
IoT Meetup Oslo - AI on Edge DevicesIoT Meetup Oslo - AI on Edge Devices
IoT Meetup Oslo - AI on Edge DevicesMark West
 
IoT Tech Day Smart Camera slides. Utrecht, April 2017.
IoT Tech Day Smart Camera slides.  Utrecht, April 2017.IoT Tech Day Smart Camera slides.  Utrecht, April 2017.
IoT Tech Day Smart Camera slides. Utrecht, April 2017.Mark West
 
Rails in the Cloud
Rails in the CloudRails in the Cloud
Rails in the Cloudiwarshak
 
Getting Started with AWS Lambda and the Serverless Cloud
Getting Started with AWS Lambda and the Serverless CloudGetting Started with AWS Lambda and the Serverless Cloud
Getting Started with AWS Lambda and the Serverless CloudAmazon Web Services
 
AWS September Webinar Series - Build Cross-Platform Mobile Apps with AWS and...
AWS September Webinar Series -  Build Cross-Platform Mobile Apps with AWS and...AWS September Webinar Series -  Build Cross-Platform Mobile Apps with AWS and...
AWS September Webinar Series - Build Cross-Platform Mobile Apps with AWS and...Amazon Web Services
 
Getting Started with Serverless Apps
Getting Started with Serverless AppsGetting Started with Serverless Apps
Getting Started with Serverless AppsAmazon Web Services
 
Getting Started with Serverless Architectures
Getting Started with Serverless ArchitecturesGetting Started with Serverless Architectures
Getting Started with Serverless ArchitecturesAmazon Web Services
 
Media Processing Workflows using AWS Step Functions and Machine Learning on A...
Media Processing Workflows using AWS Step Functions and Machine Learning on A...Media Processing Workflows using AWS Step Functions and Machine Learning on A...
Media Processing Workflows using AWS Step Functions and Machine Learning on A...Cloudinary
 
WKS407 Wild Rydes Takes Off – The Dawn of a New Unicorn
WKS407 Wild Rydes Takes Off – The Dawn of a New UnicornWKS407 Wild Rydes Takes Off – The Dawn of a New Unicorn
WKS407 Wild Rydes Takes Off – The Dawn of a New UnicornAmazon Web Services
 
Develop a Messaging App on AWS in One Day
Develop a Messaging App on AWS in One DayDevelop a Messaging App on AWS in One Day
Develop a Messaging App on AWS in One DayAmazon Web Services
 
Building Scalable Windows and .NET Apps on AWS (TLS302) | AWS re:Invent 2013
Building Scalable Windows and .NET Apps on AWS (TLS302) | AWS re:Invent 2013Building Scalable Windows and .NET Apps on AWS (TLS302) | AWS re:Invent 2013
Building Scalable Windows and .NET Apps on AWS (TLS302) | AWS re:Invent 2013Amazon Web Services
 
Surviving Serverless Testing: The ultimate Guide
Surviving Serverless Testing: The ultimate GuideSurviving Serverless Testing: The ultimate Guide
Surviving Serverless Testing: The ultimate GuideOPEN KNOWLEDGE GmbH
 
AWS March 2016 Webinar Series Getting Started with Serverless Architectures
AWS March 2016 Webinar Series   Getting Started with Serverless ArchitecturesAWS March 2016 Webinar Series   Getting Started with Serverless Architectures
AWS March 2016 Webinar Series Getting Started with Serverless ArchitecturesAmazon Web Services
 
CMP211_Getting Started with Serverless Architectures
CMP211_Getting Started with Serverless ArchitecturesCMP211_Getting Started with Serverless Architectures
CMP211_Getting Started with Serverless ArchitecturesAmazon Web Services
 
Iot meets Serverless
Iot meets ServerlessIot meets Serverless
Iot meets ServerlessNarendran R
 
AWS re:Invent 2020 Serverless Recap
AWS re:Invent 2020 Serverless RecapAWS re:Invent 2020 Serverless Recap
AWS re:Invent 2020 Serverless RecapDaniel Zivkovic
 
AWS Lambda - Event Driven Event-driven Code in the Cloud
AWS Lambda - Event Driven Event-driven Code in the CloudAWS Lambda - Event Driven Event-driven Code in the Cloud
AWS Lambda - Event Driven Event-driven Code in the CloudAmazon Web Services
 
Serverless Architectural Patterns & Best Practices
Serverless Architectural Patterns & Best PracticesServerless Architectural Patterns & Best Practices
Serverless Architectural Patterns & Best PracticesDaniel Zivkovic
 

Similar to GeeCON Prague : Building a Smart Security Camera with Raspberry Pi Zero, Java and AWS (20)

DevExperience 2018 : Building a Smart Security Camera with Raspberry Pi Zero,...
DevExperience 2018 : Building a Smart Security Camera with Raspberry Pi Zero,...DevExperience 2018 : Building a Smart Security Camera with Raspberry Pi Zero,...
DevExperience 2018 : Building a Smart Security Camera with Raspberry Pi Zero,...
 
IoT Meetup Oslo - AI on Edge Devices
IoT Meetup Oslo - AI on Edge DevicesIoT Meetup Oslo - AI on Edge Devices
IoT Meetup Oslo - AI on Edge Devices
 
IoT Tech Day Smart Camera slides. Utrecht, April 2017.
IoT Tech Day Smart Camera slides.  Utrecht, April 2017.IoT Tech Day Smart Camera slides.  Utrecht, April 2017.
IoT Tech Day Smart Camera slides. Utrecht, April 2017.
 
Rails in the Cloud
Rails in the CloudRails in the Cloud
Rails in the Cloud
 
Getting Started with AWS Lambda and the Serverless Cloud
Getting Started with AWS Lambda and the Serverless CloudGetting Started with AWS Lambda and the Serverless Cloud
Getting Started with AWS Lambda and the Serverless Cloud
 
AWS September Webinar Series - Build Cross-Platform Mobile Apps with AWS and...
AWS September Webinar Series -  Build Cross-Platform Mobile Apps with AWS and...AWS September Webinar Series -  Build Cross-Platform Mobile Apps with AWS and...
AWS September Webinar Series - Build Cross-Platform Mobile Apps with AWS and...
 
Getting Started with Serverless Apps
Getting Started with Serverless AppsGetting Started with Serverless Apps
Getting Started with Serverless Apps
 
Getting Started with Serverless Architectures
Getting Started with Serverless ArchitecturesGetting Started with Serverless Architectures
Getting Started with Serverless Architectures
 
Media Processing Workflows using AWS Step Functions and Machine Learning on A...
Media Processing Workflows using AWS Step Functions and Machine Learning on A...Media Processing Workflows using AWS Step Functions and Machine Learning on A...
Media Processing Workflows using AWS Step Functions and Machine Learning on A...
 
WKS407 Wild Rydes Takes Off – The Dawn of a New Unicorn
WKS407 Wild Rydes Takes Off – The Dawn of a New UnicornWKS407 Wild Rydes Takes Off – The Dawn of a New Unicorn
WKS407 Wild Rydes Takes Off – The Dawn of a New Unicorn
 
Develop a Messaging App on AWS in One Day
Develop a Messaging App on AWS in One DayDevelop a Messaging App on AWS in One Day
Develop a Messaging App on AWS in One Day
 
Building Scalable Windows and .NET Apps on AWS (TLS302) | AWS re:Invent 2013
Building Scalable Windows and .NET Apps on AWS (TLS302) | AWS re:Invent 2013Building Scalable Windows and .NET Apps on AWS (TLS302) | AWS re:Invent 2013
Building Scalable Windows and .NET Apps on AWS (TLS302) | AWS re:Invent 2013
 
Surviving Serverless Testing: The ultimate Guide
Surviving Serverless Testing: The ultimate GuideSurviving Serverless Testing: The ultimate Guide
Surviving Serverless Testing: The ultimate Guide
 
AWS March 2016 Webinar Series Getting Started with Serverless Architectures
AWS March 2016 Webinar Series   Getting Started with Serverless ArchitecturesAWS March 2016 Webinar Series   Getting Started with Serverless Architectures
AWS March 2016 Webinar Series Getting Started with Serverless Architectures
 
CMP211_Getting Started with Serverless Architectures
CMP211_Getting Started with Serverless ArchitecturesCMP211_Getting Started with Serverless Architectures
CMP211_Getting Started with Serverless Architectures
 
Iot meets Serverless
Iot meets ServerlessIot meets Serverless
Iot meets Serverless
 
AWS re:Invent 2020 Serverless Recap
AWS re:Invent 2020 Serverless RecapAWS re:Invent 2020 Serverless Recap
AWS re:Invent 2020 Serverless Recap
 
AWS Startup Insights Singapore
AWS Startup Insights SingaporeAWS Startup Insights Singapore
AWS Startup Insights Singapore
 
AWS Lambda - Event Driven Event-driven Code in the Cloud
AWS Lambda - Event Driven Event-driven Code in the CloudAWS Lambda - Event Driven Event-driven Code in the Cloud
AWS Lambda - Event Driven Event-driven Code in the Cloud
 
Serverless Architectural Patterns & Best Practices
Serverless Architectural Patterns & Best PracticesServerless Architectural Patterns & Best Practices
Serverless Architectural Patterns & Best Practices
 

More from Mark West

A Practical-ish Introduction to Data Science
A Practical-ish Introduction to Data ScienceA Practical-ish Introduction to Data Science
A Practical-ish Introduction to Data ScienceMark West
 
Explaining the new Java release and licensing models
Explaining the new Java release and licensing modelsExplaining the new Java release and licensing models
Explaining the new Java release and licensing modelsMark West
 
GeeCon Prague 2018 - A Practical-ish Introduction to Data Science
GeeCon Prague 2018 - A Practical-ish Introduction to Data ScienceGeeCon Prague 2018 - A Practical-ish Introduction to Data Science
GeeCon Prague 2018 - A Practical-ish Introduction to Data ScienceMark West
 
JavaZone 2018 - A Practical(ish) Introduction to Data Science
JavaZone 2018 - A Practical(ish) Introduction to Data ScienceJavaZone 2018 - A Practical(ish) Introduction to Data Science
JavaZone 2018 - A Practical(ish) Introduction to Data ScienceMark West
 
NDC Oslo : A Practical Introduction to Data Science
NDC Oslo : A Practical Introduction to Data ScienceNDC Oslo : A Practical Introduction to Data Science
NDC Oslo : A Practical Introduction to Data ScienceMark West
 
JavaZone 2016 : MQTT and CoAP for the Java Developer
JavaZone 2016 : MQTT and CoAP for the Java DeveloperJavaZone 2016 : MQTT and CoAP for the Java Developer
JavaZone 2016 : MQTT and CoAP for the Java DeveloperMark West
 
JavaZone 2015 : NodeBots - JavaScript Powered Robots with Johnny-Five
JavaZone 2015 : NodeBots - JavaScript Powered Robots with Johnny-FiveJavaZone 2015 : NodeBots - JavaScript Powered Robots with Johnny-Five
JavaZone 2015 : NodeBots - JavaScript Powered Robots with Johnny-FiveMark West
 
Coding Mojo : Node.js Meetup
Coding Mojo : Node.js MeetupCoding Mojo : Node.js Meetup
Coding Mojo : Node.js MeetupMark West
 
IoT Tech Day Coding Mojo slides. Utrecht, April 2016
IoT Tech Day Coding Mojo slides.  Utrecht, April 2016IoT Tech Day Coding Mojo slides.  Utrecht, April 2016
IoT Tech Day Coding Mojo slides. Utrecht, April 2016Mark West
 
JavaOne 2015 : How I Rediscovered My Coding Mojo by Building an IoT/Robotics ...
JavaOne 2015 : How I Rediscovered My Coding Mojo by Building an IoT/Robotics ...JavaOne 2015 : How I Rediscovered My Coding Mojo by Building an IoT/Robotics ...
JavaOne 2015 : How I Rediscovered My Coding Mojo by Building an IoT/Robotics ...Mark West
 

More from Mark West (10)

A Practical-ish Introduction to Data Science
A Practical-ish Introduction to Data ScienceA Practical-ish Introduction to Data Science
A Practical-ish Introduction to Data Science
 
Explaining the new Java release and licensing models
Explaining the new Java release and licensing modelsExplaining the new Java release and licensing models
Explaining the new Java release and licensing models
 
GeeCon Prague 2018 - A Practical-ish Introduction to Data Science
GeeCon Prague 2018 - A Practical-ish Introduction to Data ScienceGeeCon Prague 2018 - A Practical-ish Introduction to Data Science
GeeCon Prague 2018 - A Practical-ish Introduction to Data Science
 
JavaZone 2018 - A Practical(ish) Introduction to Data Science
JavaZone 2018 - A Practical(ish) Introduction to Data ScienceJavaZone 2018 - A Practical(ish) Introduction to Data Science
JavaZone 2018 - A Practical(ish) Introduction to Data Science
 
NDC Oslo : A Practical Introduction to Data Science
NDC Oslo : A Practical Introduction to Data ScienceNDC Oslo : A Practical Introduction to Data Science
NDC Oslo : A Practical Introduction to Data Science
 
JavaZone 2016 : MQTT and CoAP for the Java Developer
JavaZone 2016 : MQTT and CoAP for the Java DeveloperJavaZone 2016 : MQTT and CoAP for the Java Developer
JavaZone 2016 : MQTT and CoAP for the Java Developer
 
JavaZone 2015 : NodeBots - JavaScript Powered Robots with Johnny-Five
JavaZone 2015 : NodeBots - JavaScript Powered Robots with Johnny-FiveJavaZone 2015 : NodeBots - JavaScript Powered Robots with Johnny-Five
JavaZone 2015 : NodeBots - JavaScript Powered Robots with Johnny-Five
 
Coding Mojo : Node.js Meetup
Coding Mojo : Node.js MeetupCoding Mojo : Node.js Meetup
Coding Mojo : Node.js Meetup
 
IoT Tech Day Coding Mojo slides. Utrecht, April 2016
IoT Tech Day Coding Mojo slides.  Utrecht, April 2016IoT Tech Day Coding Mojo slides.  Utrecht, April 2016
IoT Tech Day Coding Mojo slides. Utrecht, April 2016
 
JavaOne 2015 : How I Rediscovered My Coding Mojo by Building an IoT/Robotics ...
JavaOne 2015 : How I Rediscovered My Coding Mojo by Building an IoT/Robotics ...JavaOne 2015 : How I Rediscovered My Coding Mojo by Building an IoT/Robotics ...
JavaOne 2015 : How I Rediscovered My Coding Mojo by Building an IoT/Robotics ...
 

Recently uploaded

EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWEREMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWERMadyBayot
 
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024Victor Rentea
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProduct Anonymous
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FMESafe Software
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoffsammart93
 
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024Victor Rentea
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodJuan lago vázquez
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businesspanagenda
 
DBX First Quarter 2024 Investor Presentation
DBX First Quarter 2024 Investor PresentationDBX First Quarter 2024 Investor Presentation
DBX First Quarter 2024 Investor PresentationDropbox
 
FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024The Digital Insurer
 
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...Angeliki Cooney
 
Elevate Developer Efficiency & build GenAI Application with Amazon Q​
Elevate Developer Efficiency & build GenAI Application with Amazon Q​Elevate Developer Efficiency & build GenAI Application with Amazon Q​
Elevate Developer Efficiency & build GenAI Application with Amazon Q​Bhuvaneswari Subramani
 
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...apidays
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FMESafe Software
 
WSO2's API Vision: Unifying Control, Empowering Developers
WSO2's API Vision: Unifying Control, Empowering DevelopersWSO2's API Vision: Unifying Control, Empowering Developers
WSO2's API Vision: Unifying Control, Empowering DevelopersWSO2
 
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc
 
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...apidays
 
ICT role in 21st century education and its challenges
ICT role in 21st century education and its challengesICT role in 21st century education and its challenges
ICT role in 21st century education and its challengesrafiqahmad00786416
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfsudhanshuwaghmare1
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Jeffrey Haguewood
 

Recently uploaded (20)

EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWEREMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
 
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
 
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
Modular Monolith - a Practical Alternative to Microservices @ Devoxx UK 2024
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
 
DBX First Quarter 2024 Investor Presentation
DBX First Quarter 2024 Investor PresentationDBX First Quarter 2024 Investor Presentation
DBX First Quarter 2024 Investor Presentation
 
FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024
 
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
 
Elevate Developer Efficiency & build GenAI Application with Amazon Q​
Elevate Developer Efficiency & build GenAI Application with Amazon Q​Elevate Developer Efficiency & build GenAI Application with Amazon Q​
Elevate Developer Efficiency & build GenAI Application with Amazon Q​
 
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
 
WSO2's API Vision: Unifying Control, Empowering Developers
WSO2's API Vision: Unifying Control, Empowering DevelopersWSO2's API Vision: Unifying Control, Empowering Developers
WSO2's API Vision: Unifying Control, Empowering Developers
 
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
 
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
 
ICT role in 21st century education and its challenges
ICT role in 21st century education and its challengesICT role in 21st century education and its challenges
ICT role in 21st century education and its challenges
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdf
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
 

GeeCON Prague : Building a Smart Security Camera with Raspberry Pi Zero, Java and AWS

  • 1. BUILDING A SMART SECURITY CAMERA WITH A PI ZERO, NODE.JS & THE CLOUD MARK WEST @markawest Kraków, 17-19 May 2017 BUILDING A SMART SECURITY CAMERA WITH PI ZERO, JAVA AND AWS MARK WEST Prague, 19-20 October 2017
  • 2. Who Am I? • IT Consultant at Bouvet. • Hacker and Maker. • Java, JavaScript, AI, Cloud & IoT. • Active member of javaBin - the Norwegian JUG. @markawest
  • 3. Talk Outline Motivation and Requirements Building a Motion Activated Camera Adding Smart Image Analysis with AWS Evaluation and Tips Node.js vs Java Lambda Functions @markawest
  • 4. Motivation and Requirements Input from Stakeholder Motivation and Requirements Building a Motion Activated Camera Adding Smart Image Analysis with AWS Evaluation and Tips Node.js vs Java @markawest
  • 6. Project Requirements Functional • Monitor activity in the garden. • Send warning when activity detected. • Live video stream. Non-functional • In place as soon as possible. • Low cost. • Portable. @markawest
  • 7. Functional Design 1. Activity in garden 2. Camera detects movement 3. Camera sends alert email with snapshot @markawest
  • 8. Building a Motion Activated Camera Motivation and Requirements Building a Motion Activated Camera Adding Smart Image Analysis with AWS Evaluation and Tips Node.js vs Java Lambda Functions @markawest
  • 9. Pi Zero W Essentials Kit: €30 Camera Module: €28 Camera Adapter: €6 ZeroView: €9 Total Cost: €73 Hardware Shopping List @markawest
  • 10. Assembled Camera Rear View Front View @markawest
  • 11. Implementing the Functional Design 1. Activity in garden 2. Camera detects movement 3. Camera sends alert email with snapshot @markawest
  • 12. Motion (https://motion-project.github.io) • Open source motion detection software. • Excellent performance on the Raspberry Pi Zero. • Built-in Web Server for streaming video. • Detected activity or ‘motion’ triggers events. • Works out of the box. No need for additional programming. @markawest
  • 14. How the Motion Software works 1 2 3 4 @markawest 1 2 3
  • 15. How the Motion Software works 1 2 3 4 1 2 3 @markawest 1 2 3
  • 16. How the Motion Software works 1 2 3 4 1 2 3 @markawest 1 2 3
  • 17. Alarm Snapshots from Web Camera @markawest
  • 18. Project Requirements : Evaluation Functional • Monitor activity in the garden. • Send warning when activity detected. • Live video stream. Non-functional • In place as soon as possible. • Low cost. • Portable. @markawest
  • 19. False Alarms from Web Camera cat cloud @markawest
  • 20. The Motion Software focuses on the amount of changed pixels, and not the cause of the changed pixels! @markawest
  • 21. Adding Smart Image Analysis with AWS Motivation and Requirements Building a Motion Activated Camera Adding Smart Image Analysis with AWS Evaluation and Tips Node.js vs Java Lambda Functions @markawest
  • 22. Improving Alarm Accuracy with Smart Image Analysis person @markawest cat
  • 23. Project Requirements Reloaded Functional • Monitor activity in our garden. • Send warning when activity detected. • Live video stream. Non-functional • In place as soon as possible. • Low cost. • Portable. @markawest
  • 24. Project Requirements Reloaded Functional • Monitor activity in our garden. • Send warning when human activity detected. • Live video stream. Non-functional • In place as soon as possible. • Low cost. • Portable. @markawest
  • 25. AWS Rekognition • Part of Amazon Web Services suite of Cloud based services. • Image Analysis as a Service, offering a range of API’s. • Built upon Deep Neural Networks. • Officially launched in November 2016. • Alternatives: Google Vision, MicroSoft Computer Vision, Clarafai. @markawest
  • 27. Adding AWS to the Web Camera Amazon Web Services (AWS) Send warning email (if snapshot contains a person) Snapshot analysed via AWS Rekognition @markawest Camera pushes snapshot to AWS Email alert sent (with snapshot)
  • 28. AWS IAM AWS Rekognition AWS Simple Email Service AWS S3 (storage) Amazon Web Service Flow Overview AWS Step Function (workflow) Upload Trigger 1 2 4 5 6 calls 3 uses uses @markawest
  • 29. AWS IAM AWS Rekognition AWS Simple Email Service AWS S3 (storage) AWS Lambda Functions Code Building Blocks (aka Microservices) AWS Step Function (workflow) Upload Trigger calls uses uses @markawest
  • 30. AWS Lambda Functions • Code units based on Java, C#, Python or Node.js • Serverless, no infrastructure to manage. • High availability out of the box. • Pay as you go model based on total invocations and duration - with a generous free tier. • Native AWS SDK gives easy access to other AWS services. @markawest
  • 32. AWS IAM AWS S3 (storage) AWS Step Functions Orchestration of Lambda Functions AWS Step Function (workflow) Upload Trigger calls AWS Rekognition AWS Simple Email Service uses uses @markawest
  • 33. AWS Step Functions • Coordinate and orchestrate Lambda Functions into Workflows or State Machines. • Launched in December 2016. • Defined via JSON files, displayed as visual workflows. • Provide the same benefits as AWS Lambda (Highly Available, Serverless, Scalable, “Pay as you go” pricing model). @markawest
  • 34. Step Function for Image Processing Error Handler (sends Error Email via AWS SES) Sends snapshot to AWS Rekognition Evaluate AWS Rekognition response Send Alert Email? Send Alert Email via AWS SES Archive image in AWS S3 1 2 3 4 5 6 1 2 3 4 5 6 @markawest
  • 35. Smart Camera (plus AWS Step Function) Demo @markawest
  • 36. Evaluation and Lessons Learned Motivation and Requirements Building a Motion Activated Camera Adding Smart Image Analysis with AWS Evaluation and Tips Node.js vs Java Lambda Functions @markawest
  • 37. Project Requirements : Evaluation Functional • Monitor activity in the garden. • Send warning when human activity detected. • Live video stream. Non-functional • In place as soon as possible. • Low cost. • Portable. @markawest
  • 38. “Fun project, but has it caught any real criminals?” @markawest
  • 40. AWS Monthly Cost : August 2017 @markawest Rekognition: EUR 2.89 SES: EUR 0.01S3: EUR 0.30 Step Functions: EUR 0.99 Tax: EUR 0.96 (Based on 8093 images processed) Lambda: EUR 0.00
  • 41. Activity Timeline Which Image Should Motion Upload? @markawest Activity Event Start 1 Activity Event Stop 2 3 4 5
  • 42. Activity Timeline @markawest Activity Event Start 1 Activity Event Stop 2 3 4 5 First Picture Which Image Should Motion Upload?
  • 43. Activity Timeline @markawest Activity Event Start 1 Activity Event Stop 2 3 4 5 Most Pixels Changed Which Image Should Motion Upload?
  • 44. Activity Timeline @markawest Activity Event Start 1 Activity Event Stop 2 3 4 5 Most Central Activity Which Image Should Motion Upload?
  • 45. Activity Timeline @markawest Activity Event Start 1 Activity Event Stop 2 3 4 5 Upload all snapshots Which Image Should Motion Upload?
  • 46. Choosing an Image Upload Strategy Upload One Snapshot to Rekognition when activity detected •Lower cost, due to less calls to the AWS stack. •Potentially lower hit rate. Upload Many Snapshots to Rekognition when activity detected •Higher cost due to increased calls to AWS. •Potentially higher hit rate. @markawest
  • 47. Node.js vs Java Motivation and Requirements Building a Motion Activated Camera Adding Smart Image Analysis with AWS Evaluation and Tips Node.js vs Java Lambda Functions @markawest
  • 48. Java 8 vs. Node.js 6.10 1. Artefact Sizes 2. Memory Requirements 3. Performance and Cost @markawest
  • 49. AWS Lambda Functions @markawest Lambda Function Purpose AWS Service Calls rekognition-image- assessment Uses AWS Rekognition to generate a list of labels describing each uploaded picture. AWS Rekognition rekognition-evaluate-labels Evaluates labels to find out if an alarm email should be sent. - ses-send-notification Sends an alarm email via AWS SES when the smart security camera detects a person. AWS SES s3-archive-image Moves the processed image to the correct archive location in S3. AWS S3
  • 50. Artefact Sizes 3 Reasons for the difference: 1. Java is generally more verbose. 2. Unused JAR’s in Java Deployments. 3. AWS SDK is natively available to Node.js Lambda Functions. @markawest Lambda Function Java Node rekognition-image- assessment 7.9 MB 813 bytes rekognition-evaluate- labels 7.6 MB 677 bytes ses-send-notification 8.7 MB 4.8 MB s3-archive-image 7.6 MB 943 bytes
  • 51. Memory Requirements Memory Allocated AWS Free Seconds Per Month AWS Price Per Second 128 MB 3 200 000 $0.00000208 192 MB 2 133 333 $0.00000313 256 MB 1 600 000 $0.00000417 1536 MB 266 667 $0.00002501 @markawest • My Node.js 6.10 Lambda Functions were happy with 128 MB memory. • My Java 8 Lambda Functions required 256 MB to avoid OutOfMemory Errors.
  • 52. Testing Cost & Performance : Method • Simulate 1500 alerts (not false alarms). • Triggered in batches of 30, with a 60 second pause. • Memory set to 256 MB for both Node.js and Java. • Prior to testing, Lambda Functions “rested” for 90 minutes. • Ran tests 5 times to ensure consistency of results. @markawest
  • 53. Test Results @markawest Lambda Function Average Duration Java Average Duration Node.js rekognition-image-assessment 2250 ms 1720 ms rekognition-evaluate-labels 6.57 ms 1.61 ms ses-send-notification 3040 ms 996 ms s3-archive-image 1050 ms 364 ms
  • 54. Why was Java slower on AWS Lambda? • Cold Starts (5-10 times longer on Java). • Lack of JVM tuning options on AWS. • Different underlying implementations. • Use Case for Project Jigsaw? @markawest
  • 55. Does Java belong on AWS Lambda? • Of course it does! • Evaluate your use case and potential costs first. • Try different memory settings to reduce costs. • Remember the Free Tier! @markawest
  • 56. Would you like to know more? markwest1972/smart- security-camera @markawest slideshare.net/markawest Slides Code

Editor's Notes

  1. But before I go any further I’d like to tell you a couple of things about me. In my day job I am a manager in Bouvet’s Oslo offices, where I work with a range of technologies based upon Java and JavaScript. My current focus is upon AI, Cloud and the Internet of Things. When I’m not at work I can often be found working on a range of hobby projects – often using the Raspberry Pi and Arduino platforms. In addition I am also involved in the organisation of the JavaZone conference, where I primarily work with the program committee. I’m on twitter under the handle @markawest, so feel free to contact me if there is anything you’d like to talk about!
  2. Ok, so lets look at the outline of todays talk. We’ll start in a second with a run through of the motivation for building this camera, along with the requirements. These should always be clear and defined for any project, whether it is a multi million kroner project for NAV, or a hobby project undertaken by an englishman living in Oslo. Then we’ll look at the first version of the camera, evaluate how it worked and discuss it’s weaknesses. The second version of the camera is where we introduce Amazon Web Services to the mix and will take up the majority of the presentation time. Finally I’ll evaluate the project and talk about what I learned.
  3. Ok, so lets get started by looking at why I did this project!
  4. The motivation for creating my camera was simple enough. A large amount of break-ins had recently taken plan in the area where I live. The thieves targeted houses with secluded gardens, as the chance of being spotted by passers by was lower. My garden is not visible from the road, making it a prime target for the thieves.
  5. When undertaking any project you need to identify the stakeholders, or those who will be affected by the project outcome. These stakeholders will have their expectations of the project, and your requirements should always take the stakeholders expectations into account. For this project my wife was my primary stakeholder, so the requirements reflected her wishes. (Go through requirements)
  6. Once I’d gathered the requirements I realized that I needed to implement the above, in a cost effective and speedy manner.
  7. Ok, so lets get started by looking at why I did this project!
  8. We’ll begin by looking at the hardware I used for creating the Camera and how much this costs. The Pi Zero is a cut down version of the Raspberry Pi. They cost about 50kr, but you’ll also need to buy an SD card, power supply and HDMI and USB adapters. Therefore I recommend a starter kit such as the one sold by the Pi Hut. This costs 300 kr, and gives you all you need to get started with the Pi Zero. In addition to the Pi Zero board I needed a camera. I choose the Raspberry Pi Camera module, at around 250 kr. To fit this to the Pi Zero I also had to buy a Pi Zero Camera adapter, which cost an additional 50 kr. The camera I chose was the Pi NoIR, which work better in low conditions. To truly provide night vision it requires an IR light source, which I didn’t buy for this project. Finally I needed a mount for the Camera. I choose the ZeroView at 80 kr. The total cost for all equipment (if bought new) would be therefore approximately 680kr. If this seems a lot of money, remember that you can easily reuse the components for other projects at a later point!
  9. Here you can see the fully assembled camera, from the front and the back. The white cable is a USB Wi Fi adapter and the black cable is for power.
  10. Once I’d gathered the requirements I realized that I needed to implement the above, in a cost effective and speedy manner.
  11. After some consideration, I decided to use the Linux Motion software. Motion is open source, and is purpose built for motion detection. It has excellent performance on the Raspberry Pi Zero, plus a built in web server for streaming video. Detected activity triggers an “event” in Motion, which can be used to send email alerts. Motion works out of the box and is highly configurable. With no need for additional programming it would take no time at all to get up and running.
  12. So how does Motion work? Well it basically monitors the video stream from the camera. Each frame is compared to the previous, in order to find out how many pixels (if any) differ. If the total number of changed pixels is greater than a given threshold, a motion alarm is then triggered.
  13. So how does Motion work? Well it basically monitors the video stream from the camera. Each frame is compared to the previous, in order to find out how many pixels (if any) differ. If the total number of changed pixels is greater than a given threshold, a motion alarm is then triggered.
  14. So how does Motion work? Well it basically monitors the video stream from the camera. Each frame is compared to the previous, in order to find out how many pixels (if any) differ. If the total number of changed pixels is greater than a given threshold, a motion alarm is then triggered.
  15. I was initially very happy with the first version of the Pi Zero Camera. The camera monitored my garden for the whole of July, whilst I was in England with my family. The results from the camera were quite boring, and mostly showed the neighbor's watering our flowers, plus me testing out the camera before we left.
  16. Ok, lets revisit my project requirements. My camera: Would monitor activity in the garden. It would be able to send an email when acitivity was detected. It included a live video stream. It was quick to build and program. It had a one of cost of 680kr. And it was portable. All this led to a happy stakeholder! But was the project completely successful?
  17. False alerts : why problematic? Loads of emails, that’s why!
  18. Ok, let us try a quick demo of the Pi Camera Version 1.
  19. Ok, so lets get started by looking at why I did this project!
  20. You’ll remember these project requirements from earlier on in this presentation. Lets just revisit them all! They are all still just as relevant. But by adding one word to one of the functional requirements we can address the issue of false positives. Any guesses?
  21. Yep. The missing word is “Human”! We only want to send warnings when human activity is detected.
  22. Why cloud based?
  23. Perhaps the best way of understanding what Amazon Rekognition is, is to run a quick demo. DetectLabels use Burglar picture from NTNU folder on my Desktop.
  24. My next challenge was to find out how I would trigger the image processing from my Pi Zero Camera. After some thought I decided to move the whole image processing and email handling to The Cloud, and specifically Amazon Web Services. My planned solution basically looked as follows: The PiZero Camera monitors the garden. On detecting movement, a snapshot is taken and pushed to Amazon Web Services. Amazon web services handles the image analysis and the eventual sending of an alert emails. This solution had some benefits: 1. The Pi Zero could now focus on running the motion software. 2. The Camera and Image Processing would be seperated, making it easy to replace either at a later date. I also tweaked the Motion configuration file to provide multiple snapshots for each detected activity. More pictures would increase the chance of Motion correctly detecting movement.
  25. Ok, so how did the AWS processing work? Here’s a simplified run through. Firstly an image is pushed from the PiZero Camera to Amazon’s s3 storage. A small unit of code or Lambda Function is triggered by the upload. It in turn triggers a Step Function. The Step Function orchestrates further Lambda Functions into a workshop. The first Lambda Function makes a call to Rekognition to evaluate the picture. The second Lambda Function uses the Simple Email Service to send the alert email. Finally, all components in the workflow use Identity Access management to make sure that they have access to the components they need to use. For example, the Lambda Function that sends an email needs access to both the Simple Email Service and to s3 in order to attach the image file to the email
  26. On upload to s3, a Lambda Function is triggered, which in turn triggers a step function, which contains more Lambda Functions. Lets look at AWS Lambda Functions and their role in our solution.
  27. A Lambda Function is essentially a unit of code. As today it is possible to implement Lambda Function using Java, C#, Python and Node.js. Lamba Functions are serverless. This doesn’t mean that they run without servers, but that the business or person running the code doesn’t have to worry about provisioning or managing the servers. In other word, Amazon has responsibility for making sure that the servers are up and running. Lambda Functions are also stateless. By not storing state they are more easily scaled up and down. This scalability is an important part of the Cloud paradigm, as it allows one to scale Lambda Functions rapidly up and down according to demand. The AWS Lambda platform is engineered to be highly available, making it suitable for running applications that need to be up all of the time. AWS Lambda utilises a Pay as you go model. This means that you pay only for the processing time you use. This means that an application with low traffic will be relatively cheap compared to one with lots of traffic. ASW Lambda also has a free tier for those who want to get started with AWS. This provides free usage up to a given threshold. AWS Lambda also has the SDK natively available, making it simple to call other AWS services and resources.
  28. { "s3Bucket": "smart-security-camera-upload", "sendAlert": false, "rekognitionLabels": {}, "s3ArchivedKey": null, "stepFunctionID": "60331694-7476-43c8-b866-8f0ca3d9db2e", "s3key": "archive/falsepositives/gardenCam1/20170904/131601-6069-01.jpg” }
  29. On upload to s3, a Lambda Function is triggered, which in turn triggers a step function, which contains more Lambda Functions. Lets look at AWS Lambda Functions and their role in our solution.
  30. Here is the actual Step Function for my Camera, rendered by the AWS Step Function interface. It’s not necessarily easy to see the flow here, so let me try to shed some light on how this works. The first step submits the snapshot to AWS Rekognition. The second step then evaluates the response from AWS Rekognition. It looks for labels such as “Person” and ”Human” and sets a flag to indicate whether a person has been found. The third step uses this flag to decide whether or not to send an email. Unlike all the other steps this is not calling a Lambda Function. The fourth step sends the alert email if. This will be skipped if the alert flag is set to false. The fifth step archives the snapshot – either in an alert folder or a false positive folder. The final step is an all purpose error handler. Any errors during processing will result in an email being sent to me.
  31. Ok, let us try a quick demo of the Pi Camera Version 2. Show happy case and unhappy case. Show Step Function flow If camera NOT working, try upload from PC : cd '/Users/mark.west/Documents/GitHub Repositories/smart-security-camera/s3-upload/' s3-upload mark.west$ node s3-upload-image-file.js smart-security-camera-upload /Users/mark.west/Desktop/ntnu/burglar.png
  32. Ok, so lets get started by looking at why I did this project!
  33. Ok, lets revisit my project requirements. My camera: Would monitor activity in the garden. It would be able to send an email when human activity was detected. It included a live video stream. It was quick to build and program. It had a one of cost of 680kr. And a yearly cost of 600kr after the first year. And it was portable. All this led to a happy stakeholder! But was the project completely successful?
  34. Ok, let us try a quick demo of the Pi Camera Version 1.
  35. The first figure is based on usage in March, where approximately 3750 images where processed – approximately 125 a day. During this period I received less than 100 real alarms. The second figure is based on the same usage amounts once the free tier is expired. The extra costs will mostly arise from costs of Step Functions and Rekognition, which as new services come at a premium rate. Other than that, additional costs will be incurred by S3 usage.
  36. VAT is 23-25% from what I can see. Some services have a level of free usage for the first year. For example Rekognition allows 5000 pictures a month. S3 also has a certain amount of free usage for the first year. I’m still in my first year, but from december my monthly price will rise by 5-10 dollars a month, including tax. Note that I don’t pay anything for Lambda Function usage – we’ll come to that some.
  37. Ok, so lets get started by looking at why I did this project!
  38. Remind people that we are comparing apples and oranges here, and that both Java and Node.js have places in a modern solution architecture
  39. Reason 2: The AWS Toolkit for Eclipse When creating the Java version of my Smart Security Camera project I used the AWS Toolkit for Eclipse, which provides support for creating, packaging and uploading AWS Lambda Functions. Functions are packaged into ZIP files which also include a set of dependancy JAR files (including the AWS SDK).   Unfortunately the AWS Toolkit isn't selective about which JAR's it adds. A quick analysis of a deployed ZIP file revealed that it included a set of AWS Client JAR's that were not required for that specific Lambda Function to run.  Amending the Maven POM file to remove these unneeded JAR's helped reduce the size of the Java Functions by up to 2MB. Reason 3: Writing Node.js Code Directly in the Browser If your Node.js based AWS Lambda Function doesn't require any 3rd party libraries, you can choose to write your code directly in the browser and avoid the packaging and upload steps. If you do this, the AWS SDK is implicitly available (no need to upload it). In the above table, the four "smallest" functions were all written in this way, which explains their small size. The "largest" Node based AWS Lambda Function was packaged as a ZIP file due to it's dependancy on the Nodemailer library.
  40. Node.js – more free seconds and cheaper price per second. This made me wonder how the costs would differ. Note that my monthly lambda costs are well below the threshold for charging – my total duration per month is normally 10 000 – 15 000 seconds with 40 000 -50 000 executions. Well below the free thresholds.
  41. Remind people that we are comparing apples and oranges here, and that both Java and Node.js have places in a modern solution architecture. Tested 10 times, results remarkably similar from time to time. Have summarized the results and created an average.
  42. Lambda provides the Amazon Linux build of openjdk 1.8.
  43. Thanks very much for attending my talk! You can find more information about this project at the Bouvet blog. And you’ll find all the code on my GitHub. If anyone wants to have a chat I’ll be on the Bouvet stand for the rest of the day and will be joining some of you for food this evening!