Skip to content

A walk through of creating and deploying a simple gcp could function

License

Notifications You must be signed in to change notification settings

amaziahub/gcp-py-cloud-function

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gcp-py-cloud-function

This project demonstrates how to create, deploy, and test a simple Google Cloud Function using Python. The function responds to HTTP requests and returns a JSON message.

Terraform GCP Python Google Cloud Functions CI

Prerequisites

  1. A Google Cloud account with billing enabled.
  2. Python 3.10 or later installed locally.
  3. gcloud CLI installed and initialized:

Setup Instructions

Step 1: Clone This Repository

git clone git@github.com:amaziahub/gcp-py-cloud-function.git
cd gcp-py-cloud-function

Step 2: Create a Google Cloud Project


Deploying the Function

Step 3: Initialize gcloud CLI

  1. Set your project ID:

    gcloud config set project YOUR_PROJECT_ID
  2. Enable necessary APIs:

    gcloud services enable cloudfunctions.googleapis.com
    gcloud services enable cloudbuild.googleapis.com

Step 4: Deploy the Cloud Function using gcloud

Run the following command to deploy the function:

gcloud functions deploy helloWorld \
    --runtime python310 \
    --trigger-http \
    --allow-unauthenticated \
    --entry-point hello_world

Deploying with Terraform

If you prefer to manage your Google Cloud Function deployment using Terraform, follow these steps:

Step 1: Install Terraform

Ensure that Terraform is installed on your machine. If not, follow the Terraform installation guide.

Step 2: Configure Your Google Cloud Project in Terraform

In the main.tf file, update the project and region with your own values. You can also modify the function runtime, name, and other settings as required.

Step 3: Deploy with Terraform

  1. Initialize Terraform:
make init
  1. Apply the configuration to deploy the function:
make apply

Testing the Function

Step 5: Get the Function URL

Retrieve the function URL:

gcloud functions describe helloWorld --format='value(httpsTrigger.url)'

Step 6: Test the Function

Use curl to test the function:

curl -X POST \
    -H "Content-Type: application/json" \
    -d '{"name": "Amazia"}' \
    FUNCTION_URL

Replace FUNCTION_URL with the URL retrieved in the previous step.


Logs and Debugging

View Logs

gcloud functions logs read helloWorld

Cleanup

Delete the Function

To avoid incurring costs, delete the deployed function:

with gcloud

gcloud functions delete helloWorld

with terraform

make destroy

Happy Coding! 🚀


How to Use It

---

### How to Use It
Replace `your-username/your-repo-name` with your GitHub repository’s actual details. This README provides all the necessary steps to recreate, deploy, and test your Cloud Function, along with a structured overview of the project. Let me know if you need further customization!