Lädt...


🔧 Pratical Differences between GCP Cloud Functions and AWS Lambda Functions


Nachrichtenbereich: 🔧 Programmierung
🔗 Quelle: dev.to

It's been a few months since I migrated from a GCP (Google Cloud Platform) environment to an AWS (Amazon Web Services) environment. At first, I thought I would find it strange and have difficulty adapting because I've heard reports from professionals going the opposite way complaining, but to my surprise, that didn't happen.

During this transition, I decided to write and share in a didactic way the subtle differences I encountered. Instead of presenting a direct confrontation, I opted for a comparison guide to help other professionals who may be considering a similar transition.

In general, there are many similarities. Both services are serverless, falling into the category known as FaaS (Function as a Service), which reduces the need to manage and maintain servers. Additionally, they provide automatic scaling based on the number of requests received. Another characteristic is that both are services that fit within an event-driven architecture, well known to those who work with messaging.

Some practical points that are relevant to know:

01. Infrastructure:

Both platforms, AWS and GCP, adopt a model of dividing infrastructure into regions and zones. However, there are some differences in how these structures are implemented on each platform.

In AWS, the data center structure consists of AZs (Availability Zones), which represent an isolated physical data center within a region. For example, the "us-east-1" region, east coast of the United States, encompasses several AZs, identified by letters like "us-east-1a," "us-east-1b," and so on. Thus, a region in AWS is an area that covers multiple AZs.

On the other hand, in GCP, the region "us-west1" represents the west coast of the United States and contains multiple zones, such as "us-west1-a," "us-west1-b," and "us-west1-c," also identified by letters. Each region corresponds to a specific geographical area where resources can be deployed.

In summary: Zones = Availability Zones = AZ

02. Different names, similar services

Even though we're mainly talking about serverless functions in day-to-day development, we need to know much more about the framework involved in development, integration, deployment, and monitoring of our projects. Below, I present a mapping for the most well-known terms.

Type AWS GCP
Serverless Functions Lambda Function Cloud Functions
API endpoints API Gateway Cloud Endpoints
Content Delivery Network (CDN) Cloudfront Cloud CDN
Kubernetes (K8s) Service EKS GKE
Messaging Queue Service SQS and SNS Cloud Pub/Sub
Operation, Log and Monitoring CloudWatch Cloud Logging and Cloud Monitoring

Google offers a more comprehensive list that includes other services and is available in this comparison.

03. Costs

The pricing structure is nearly identical between AWS and GCP. The main factors that impact cost in both services are the number of requests and the execution time. It's important to note that other fees may be charged for parallel services, such as data transfer or storage costs, but these depend on the project context.

An important detail that can cause differences between the values is how computing time is calculated in each provider. In AWS, runtime is billed in increments of 1 millisecond. This means that each additional millisecond is charged separately.

In Google Cloud Functions, runtime is rounded up for each 100-millisecond interval after the first 100 milliseconds. This means that if function execution lasts less than 100 milliseconds, you will not be charged for that time. However, if it lasts more than 100 milliseconds, you will be charged for the total time rounded up to the next 100-millisecond increment. For example, a function executed for 260 ms would be billed as 300 ms.

Another similar factor with different criteria is the free tier offered by both providers. For example, AWS Lambda offers 1 million free requests per month and 400,000 GB-seconds of compute time, while Google Cloud Functions offers 2 million requests, 400,000 GB-seconds of provisioned memory, and 200,000 GHz-seconds of CPU time.

How to make processing calculations:

500,000 invocations / 40 ms duration / 128 MB

  • 40 ms = 0.04 sec
  • 128 MB = 0.125 GB

Usage Time: 500,000 invocations/month * 0.04 sec/invocation = 20,000 sec/month

Provisioned Memory: 20,000 sec/month * 0.125 GB = 2.5 GB-sec/month

3,000,000 invocations / 230 ms duration / 1024 MB

  • 230 ms = 0.23 sec
  • 1024 MB = 1 GB

Usage Time: 3,000,000 invocations/month * 0.23 sec/invocation = 690,000 sec/month

Provisioned Memory: 690,000 sec/month * 1 GB = 690 GB-sec/month

Online Calculators

P.S.: I don't trust Google's calculator very much 🤷

04. Supported Languages:

Both services were accurate in including a good variety of supported languages. While Google's Cloud Functions support Node.js, Python, Go, and Java, Ruby, PHP, and .NET, AWS Lambda Functions have a slightly longer list, making it easier to use TypeScript (using Node environment) and including Rust and PowerShell.

Additionally, as I mainly work with Python, I noticed the commitment of providers to keep technologies up to date. In GCP, it's still possible to create a Lambda with Python 3.7, but in AWS, this is no longer allowed. It's worth mentioning that both in AWS and GCP, Python 3.8 will be discontinued later this year (2024). A sadness for companies adhering to the "If it's working, don't touch it" culture.

05. Execution Time:

Another important distinction is the execution time and customization capability. In Google's Cloud Functions (1st generation), the maximum duration time limit is 9 minutes (540 seconds), while in Cloud Functions (2nd generation), this time is 60 minutes (3,600 seconds) for HTTP functions and 9 minutes (540 seconds) for event-driven functions. In AWS Lambda Functions, the default timeout is 3 seconds but can be adjusted to a maximum of 15 minutes (900 seconds).

Execution time is an important aspect to consider, especially if the project makes use of synchronous external requests. If the average latency is high or unstable, this may result in the Lambda being terminated before it completes.

06. Integration with the Ecosystem:

Integration with the ecosystem was one of the factors that surprised me the most during the transition. AWS Lambda offers deep and flexible integration with the entire AWS ecosystem, which has been extremely helpful in the current architecture I work with. From seamless integrations with Amazon S3, Amazon DynamoDB, to Amazon API Gateway.

However, a downside is that this can lead to a high level of coupling. While both providers support HTTP integration, AWS requires the provisioning and configuration of a separate resource, the API Gateway, which is also charged separately. GCP has a much simpler HTTP integration.

07. Performance and Cold Start

I don't intend to delve too much into this aspect since neither of the providers publicly discloses their cold start metrics.

Searching around the internet, I noticed that natively Google's Cloud Functions start with a shorter time, but it's quite complicated to make a comparison for this difference. However, I observed that in AWS, an inactive Lambda in Python takes an average of 200ms to start. This is without considering the "provisioned concurrency" feature, which is a functionality that allows eliminating Cold Start in AWS.

08. Command Line Tools (CLI)

Command line tools play an important role in managing cloud platforms. Both providers, AWS and GCP, offer their own CLI tools to facilitate automation, deployment, and resource management in the cloud.

8.1 GCP

  • gcloud tool: With gcloud, users can create, modify, and manage resources such as virtual machine instances, databases, and serverless services.
  • gsutil tool: With gsutil, file transfer, access policy configuration, and various other operations in Cloud Storage buckets can be performed. Little used in the context of GCP Cloud Functions.
  • bq tool: bq is a command-line tool primarily for BigQuery, GCP's data analysis service. With bq, users can run SQL queries, load and export data, and manage datasets and tables. This tool is also rarely used in the context of GCP Cloud Functions.

8.2 AWS

  • AWS tool: AWS Command Line Interface is the primary tool for interacting with AWS services via the command line. With AWS CLI, users can manage EC2 instances, S3 buckets, Lambda functions, and a variety of other AWS services.
  • SAM tool: AWS SAM (Serverless Application Model) is an extension of AWS CLI that facilitates the creation, testing, and deployment of serverless applications on AWS. With AWS SAM, developers can define serverless resources using a simplified syntax and easily deploy them. AWS SAM overlays AWS CLI to provide us with some useful extra tools.

09. Conclusion:

As they say, the devil is in the details. Ultimately, AWS Lambda is more mature while Cloud Functions has a few fewer features, but it's still quite comparable to AWS. Choosing between one provider or another is not necessarily a matter of one being better than the other, but rather of understanding the nuances and adapting to the differences.

Additionally, I realized the importance of considering not only the technical aspects but also the associated costs, developer experience, and project context. This migration has given me a broader view of the cloud computing landscape and empowered me to make more informed decisions about the infrastructure of my future projects.

...

🔧 Pratical Differences between GCP Cloud Functions and AWS Lambda Functions


📈 122.92 Punkte
🔧 Programmierung

🔧 Diferenças práticas entre GCP Cloud Functions e AWS Lambda Functions


📈 59.17 Punkte
🔧 Programmierung

🔧 Cloud Showdown: AWS Vs. GCP – Unveiling Key Differences And Benefits


📈 43.28 Punkte
🔧 Programmierung

🔧 How to optimize your lambda functions with AWS Lambda power tuning


📈 42.67 Punkte
🔧 Programmierung

🔧 Turbocharge your Lambda Functions with AWS Lambda Powertools for Python


📈 42.67 Punkte
🔧 Programmierung

🔧 7 Differences Between Arrow Functions and Traditional Functions


📈 41.87 Punkte
🔧 Programmierung

🔧 Draft: What are the differences between arrow functions and traditional functions?


📈 41.87 Punkte
🔧 Programmierung

🔧 AWS ECS vs. AWS Lambda: Top 5 Main Differences


📈 40.78 Punkte
🔧 Programmierung

🔧 Spring Boot 3 application on AWS Lambda - Part 5 Introduction to AWS Lambda Web Adapter


📈 40.75 Punkte
🔧 Programmierung

🔧 Spring Boot 3 application on AWS Lambda - Part 6 Develop application with AWS Lambda Web Adapter


📈 40.75 Punkte
🔧 Programmierung

🔧 Enhancing AWS Lambda with AWS Lambda Powertools: A Complete Guide to CRUD Operations in DynamoDB


📈 40.75 Punkte
🔧 Programmierung

🔧 Day 22 of 100 Days of Cloud: Mastering AWS Lambda and Lambda Layers


📈 39.39 Punkte
🔧 Programmierung

🔧 Building an AI powered and Serverless meal planner with OpenAI, AWS Step functions, AWS Lambda and CDK


📈 39.38 Punkte
🔧 Programmierung

🔧 Applying event filters to AWS Lambda Functions with the AWS CDK


📈 36.05 Punkte
🔧 Programmierung

🔧 Deploying AWS Lambda Functions with API Gateway to DynamoDB using AWS SAM on LocalStack


📈 36.05 Punkte
🔧 Programmierung

🐧 Lambda.sh | Haskell-like lambda functions in bash


📈 35.8 Punkte
🐧 Linux Tipps

🔧 AWS Lambda support Node.js 18 now. Should we update the version of Node.js in the Lambda runtime?


📈 33.88 Punkte
🔧 Programmierung

🔧 Supercharge Your AWS Lambda Game With Lambda Powertools


📈 33.88 Punkte
🔧 Programmierung

🔧 Lambda Internals: Why AWS Lambda Will Not Help With Machine Learning


📈 33.88 Punkte
🔧 Programmierung

🔧 GCP Cloud Digital Leader certification versus the AWS Cloud Practitioner, and are they worth it?


📈 33.59 Punkte
🔧 Programmierung

📰 Bluemix OpenWhisk: IBM stellt Konkurrenten zu AWS Lambda und Google Cloud Functions vor


📈 33.02 Punkte
📰 IT Nachrichten

📰 Bluemix OpenWhisk: IBM stellt Konkurrenten zu AWS Lambda und Google Cloud Functions vor


📈 33.02 Punkte
📰 IT Nachrichten

🔧 Deploy nest app to AWS Lambda using cloud-formation stack and AWS CDK


📈 32.77 Punkte
🔧 Programmierung

🔧 GCP - Create api with Cloud Functions and API Gateway


📈 31.66 Punkte
🔧 Programmierung

🔧 Multi-Cloud Strategy: Pros and Cons of Using AWS, Azure, and GCP Together


📈 31.41 Punkte
🔧 Programmierung

🔧 Multi-Cloud Strategy: Pros and Cons of Using AWS, Azure, and GCP Together


📈 31.41 Punkte
🔧 Programmierung

🔧 Differences between Ethereum’s send/transfer/call functions


📈 31.4 Punkte
🔧 Programmierung

🔧 Learning AWS Day by Day - Day 53 - Differences between SQS, SNS and Amazon MQ


📈 31.15 Punkte
🔧 Programmierung

🔧 What are the differences between hosting websites through Git and AWS?


📈 31.15 Punkte
🔧 Programmierung

🔧 Spring Boot 3 application on AWS Lambda - Part 9 Develop application with Spring Cloud Function AWS


📈 31.1 Punkte
🔧 Programmierung

🔧 Cook a recipe with AWS: Simple and Easy Lambda Functions


📈 30.84 Punkte
🔧 Programmierung

matomo