Getting your Trinity Audio player ready...
|
Google Cloud Functions is a serverless execution environment for building and connecting cloud services. With Cloud Functions, you write simple, single-purpose functions that are attached to events emitted from your cloud infrastructure and services. Your function is triggered when an event being watched is fired. Your code executes in a fully managed environment. There is no need to provision any infrastructure or worry about managing any servers.
- Serverless execution environment for building and connecting cloud services
- Write simple, single-purpose functions that are attached to events emitted from your cloud services
- These functions execute code in response to events based on triggers
Key Terms used in Cloud Functions
Event
Events are the things that happen in the cloud environment. These can be:
- changes to data in a database
- files added to a storage system
- a new virtual machine instance being created
Trigger
Declaration of interest in an event. We bind a function to a trigger and when the trigger is set, the function is executed.
data:image/s3,"s3://crabby-images/97f7e/97f7e7bb6a7253db0ec607f1c6f43865f168eed9" alt=""
Triggers are associated with available resources such as Cloud storage, Cloud pub-sub, HTTP, Firebase Analytics, Firebase Authentication and Firebase real-time database.
Runtimes
Cloud Functions supports multiple language runtimes:
data:image/s3,"s3://crabby-images/ad15f/ad15fcc6dddbc5300bc9ddf5fa816928a5c27325" alt=""
Triggering Cloud Storage with Cloud Functions
The idea is when an object is put in Google Cloud Storage, the cloud function must be triggered and it will be logged likewise.
Step 1.) Create a Cloud Storage Bucket
Go to Navigation — Cloud Storage — Give a unique bucket name
data:image/s3,"s3://crabby-images/e8ccd/e8ccd3cf09c72cd585af7a7e27e55f6991c741ec" alt=""
Step 2.) Create a Cloud Function
Go to Navigation —> Cloud Functions —> Create Function
data:image/s3,"s3://crabby-images/3b04d/3b04d5fbaf4335681615a29b75efb4db70605ea4" alt=""
Step 3.) Selecting the Trigger and Event Type
After clicking Create Function, you must give a proper name of the Cloud Function and select the Trigger as Cloud Storage and Event type as Finalise/Create (this determines when an object is put into the bucket, it will trigger cloud function).
data:image/s3,"s3://crabby-images/68ae7/68ae7eb9b7e3bb11bf405809325b83eee1db3d7d" alt=""
Step 4.) Select the Google Cloud Storage bucket you want to trigger.
data:image/s3,"s3://crabby-images/e5bb7/e5bb79ee3488ac081f5c75a8a5a4cf62202c38e6" alt=""
Step 5.) Selecting the Runtime for running the Cloud Function
The Java programming language recently turned 25 years old, and it’s still one of the top-used languages powering today’s enterprise application customers. Google brought Java 11 to Google Cloud Functions in Q1 2020. That means you can now write Cloud Functions using your favourite JVM languages (Java, Kotlin, Groovy, Scala, etc) with our Functions Framework for Java, and also with Spring Cloud Functions and Micronaut!
With Cloud Functions for Java 11, now in beta, you can use Java to build business-critical applications and integration layers, and deploy the function in a fully managed environment, complete with access to resources in a private VPC network. Java functions will scale automatically based on your load. You can write HTTP functions to respond to HTTP events, and background functions to process events sourced from the various cloud and GCP services, such as Pub/Sub, Cloud Storage, Firestore, and more.
So, you have to select Java 11 in the Runtime drop-down.
data:image/s3,"s3://crabby-images/a40ab/a40aba3da19a9143b4fd8039a158c80a1c3c10c1" alt=""
pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>cloudfunctions</groupId>
<artifactId>gcs-function</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.target>11</maven.compiler.target>
<maven.compiler.source>11</maven.compiler.source>
</properties>
<dependencies>
<dependency>
<groupId>com.google.cloud.functions</groupId>
<artifactId>functions-framework-api</artifactId>
<version>1.0.1</version>
<type>jar</type>
</dependency>
</dependencies>
<!-- Required for Java 11 functions in the inline editor -->
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<excludes>
<exclude>.google/</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
</project>
src/main/java/com/example/example.java
package com.example;
import com.example.Example.GCSEvent;
import com.google.cloud.functions.BackgroundFunction;
import com.google.cloud.functions.Context;
import java.util.logging.Logger;
public class Example implements BackgroundFunction<GCSEvent> {
private static final Logger logger = Logger.getLogger(Example.class.getName());
@Override
public void accept(GCSEvent event, Context context) {
logger.info("Processing file: " + event.name);
throw new UnsupportedOperationException("Not supported yet.");
}
public static class GCSEvent {
String bucket;
String name;
String metageneration;
}
}
Step 6.) Click the Create button for creating Cloud Function
data:image/s3,"s3://crabby-images/9bc35/9bc35ce6ae21f299cfe0152357c8c101d5efd911" alt=""
Step 7.) Check and confirm that the Cloud Function is successfully created.
data:image/s3,"s3://crabby-images/6cb3b/6cb3befaf185aec05275d01509d50496902b7905" alt=""
Step. 8) Check the View logs under Actions —> 3-horizontal-dots
When the function is created, you can view the logs to see that the function has been created.
data:image/s3,"s3://crabby-images/41bed/41bed599ed5d747f01189470fe81d76766b5a25f" alt=""
Step 9.) Upload a file in the GCS bucket to trigger Cloud Functions
data:image/s3,"s3://crabby-images/5c511/5c511ed52ac16d25a772e27a93b66d656c0f2bb5" alt=""
Step 10.) Check the logs after uploading the file in the GCS bucket
data:image/s3,"s3://crabby-images/32608/3260897a095917d2b93610472f1a7430a28f585b" alt=""
Conclusion
Cloud Functions are a great fit for serverless application backends for integrating with third-party services and APIs, or for mobile or IoT backends. You can also use functions for real-time data processing systems, like processing files as they are uploaded to Cloud Storage, or handling real-time streams of events from Pub/Sub. Last but not least, functions can serve intelligent applications like virtual assistants and chatbots, or video, image and sentiment analysis.
If this article provided you with value, please support my work — only if you can afford it. You can also connect with me on X. Thank you!
Comments are closed.