Skip to content

Latest commit

 

History

History
184 lines (125 loc) · 6.26 KB

function2_lab.md

File metadata and controls

184 lines (125 loc) · 6.26 KB

Go back to Overview Page

Application Development - Fn Functions lab

Run Serverless Functions using FnProject.io

In this lab you will explore serverless computing using functions with the Docker-based open source Fn project.

This page is an overview, pointing you to various individual steps, often pointing directly to the up-to-date function tutorials on fnproject.io.

Attention !! Always use the "back" button of your browser to go back to this overview, or you might end up on the generic Functions tutorial repository.

Section 1 - Setting up your Environment

You have several options to set up your Functions environment. Some key elements that will determine your choice are the type of OS you are running (Windows, Mac or Linux), your ability to install new software on your machine, and whether you already have Docker or VirtualBox available on your machine.

  1. Use a remote instance

    Pro : you only need a VNC or ssh client on your machine

    Cons : Temporary access only during the session, console emulator via browser not super responsive

    ==> Follow the link provided by your instructor to access the environment

  2. Install locally on your machine (advised for Mac and Linux OS)

    Pro: local install, best experience and reactivity

    Cons : Install of Docker required

    ==> Check out this page for installing Docker on Mac: https://docs.docker.com/docker-for-mac/install/

    ==> Installing Fn.

Section 2 - Verifying your Docker and Fn Installs

Before we get started with functions we're going to verify that Docker is installed and working. In a terminal, type the following command:

docker --version

If Docker is installed and running, you should see output something like:

Docker version 18.03.1-ce, build 9ee9f40

NOTE: Depending on how you've installed Docker you may need to prefix docker commands with sudo in which case you would have to type:

sudo docker --version

Now do the same for Functions :

fn version

You should see something like

Client version: 0.5.0
Server version:  ?

In case the Client version displayed is lower, you need to upgrade to the latest version:

curl -LSs https://raw.githubusercontent.com/fnproject/cli/master/install | sh

Now set the correct context for using a local functions server

fn ls context
fn use context default
fn update context registry fndemouser

Now make sure the Fn Server is also up to date with the latest version by performing following updates :

docker pull node:8-alpine
docker pull fnproject/go:latest
docker pull fnproject/go:dev
docker pull fnproject/fnserver:latest
docker pull fnproject/ui:latest

Now open a 2nd console window, and start the fn server with the following command:

fn start

In your first console window, re-validate the fn version:

fn version

You should now see something like

Client version: 0.5.0
Server version:  0.3.561

Now that you have taken care of the Server Side, you are ready to start working with actual functions!

Section 3 - Functions

With Docker and Fn successfully installed it's time to move on to functions. Functions as a Service (FaaS) platforms provide a way to deploy code to the cloud without having to worry about provisioning or managing any compute infrastructure. The goal of the open source Fn project is to provide a functions platform that you can run anywhere--on your laptop or in the cloud. And Fn will also be the basis of a fully serverless FaaS platform. With Fn you can develop locally and deploy to the cloud knowing your functions are running on exactly the same underlying platform.

Your First Function

Now that the Fn server and CLI are installed we can dig into the creation and running of functions. In this tutorial you'll create, run locally, and deploy a Go function. If you aren't a Go programmer don't panic! All the code is provided and is pretty easy to understand. The focus of this tutorial is on becoming familiar with the basics of Fn, not Go programming.

So let's create and deploy your first function.

Introducing the Java Function Developer Kit

Fn provides an FDK (Function Developer Kit) for each of the core supported programming languages. But the Java FDK is the most advanced with support for Maven builds, automatic function argument type conversions, and comprehenive support for function testing with JUnit.

The Introduction to Java Functions tutorial covers all these topics and more.

Troubleshooting

If you've been following the instructions in the tutorials carefully you shouldn't have run into any unexpected failures--hopefully!! But in real life when you're writing code things go wrong--builds fail, exceptions are thrown, etc. Fortunately the Troubleshooting tutorial introduces techniques you can use to track down the source of a failure.

Containers as Functions

One of the coolest features of Fn is that while it's easy to write functions in various programming languages, you can also deploy Docker images as functions. This opens up entire world's of opportunity as you can package existing code, utilities, or use a programming language not yet supported by Fn. Try the Containers as Functions tutorial to see how easy it is.

Function Applications

In some of the tutorials you've tried so far we've breezed over the concept of an 'application'. In Fn, functions must belong to an application. They function as a namespace, a place to set configuration common across functions, and can be used as a deployment unit. The Applications tutorial shows how you can use an application to organize and deploy functions.

More Fn Tutorials!

If you've completed these tutorial and want to try more you're in luck. There's an ever expanding collection of Fn tutorials you can try on your own time.

Check out these Fn Tutorials and just skip the ones you've already completed.