Skip to content

Latest commit

 

History

History
239 lines (163 loc) · 12.7 KB

migrate-cf-ce-tutorial.md

File metadata and controls

239 lines (163 loc) · 12.7 KB
copyright lastupdated keywords subcollection content-type completion-time
years
2022, 2023
2023-06-13
code engine, tutorial, build, source, application, buildpack, access, build run, image, cloud foundry
codeengine
tutorial
30m

{{site.data.keyword.attribute-definition-list}}

Deploying Cloud Foundry applications in {{site.data.keyword.codeengineshort}}: Getting started

{: #migrate-cf-ce-tutorial} {: toc-content-type="tutorial"} {: toc-completion-time="30m"}

Welcome Cloud Foundry users to {{site.data.keyword.codeenginefull}}. {: shortdesc}

{{site.data.keyword.codeengineshort}} is a fully managed, serverless platform that runs your containerized workloads. {{site.data.keyword.codeengineshort}} even builds container images for you from your source code. The {{site.data.keyword.codeengineshort}} experience is designed so that you can focus on writing code and not on the infrastructure that is needed to host it.

{{site.data.keyword.codeengineshort}} was designed with the following key goals in mind.

  • Focus on your code. {{site.data.keyword.codeengineshort}} provides a simplified developer experience. No need to learn about or manage the underlying infrastructure.
  • Support the modern runtime characteristics, such as autoscaling, scaling to zero when idle, and seamless integration with managed services and security.
  • Support all your Cloud-native based applications, whether they are 12-factor apps, event-driven functions, or run-to-completion batch-jobs. If it can be containerized, {{site.data.keyword.codeengineshort}} can run it.
  • Pay for only the resources that you actually use.

If you are coming from a Cloud Foundry background, many of these features sound familiar. However, {{site.data.keyword.codeengineshort}} also includes some new capabilities that allow you to go beyond even what Cloud Foundry offers, including applications that can scale to zero and incur no charges. So, after you're past the syntactical difference of the user experience, you and your applications will feel right at home in {{site.data.keyword.codeengineshort}}.

{{site.data.keyword.ibmcf_full}} is deprecated and no longer supported as of 1 June 2023. For more information, see the deprecation details. {: important}

Let's deploy a simple hello world app to see how {{site.data.keyword.codeengineshort}} works. Follow the steps to create a project, build your code, and deploy your app.

Review Cloud Foundry and {{site.data.keyword.codeengineshort}} terms before starting this tutorial.

Objectives

{: #cftut-objectives}

  • Learn the similarities between {{site.data.keyword.codeengineshort}} and Cloud Foundry.
  • Learn the general process of deploying apps in {{site.data.keyword.codeengineshort}}.
  • Deploy an application from code on your local system with {{site.data.keyword.codeengineshort}}.

Prerequisites

{: #cftut-prereqs}

Before you can get started with {{site.data.keyword.codeengineshort}}, you need to set up your account and install the CLI.

Log in to {{site.data.keyword.cloud_notm}}

{: #cftut-log-cloud} {: step}

Follow these steps to log in to your {{site.data.keyword.cloud_notm}} account and target a resource group.

  1. Log in to the {{site.data.keyword.cloud_notm}} CLI.

    ibmcloud login

    {: pre}

  2. Target a resource group by running the following command. To get a list of your resource groups, run ibmcloud resource groups.

    ibmcloud target -g <resource_group>

    {: pre}

    Example output

    Targeted resource group default

    {: screen}

Creating a project

{: #cftut-create-project} {: step}

A {{site.data.keyword.codeengineshort}} "project" is similar to a Cloud Foundry "space" in that it groups related workloads into a logical collection that is meaningful to the developer. You can group workloads into different projects based on whatever criteria that makes sense to you, for example, company organization structure, dependencies between the workloads, or development versus test versus production environments. Keep in mind that workloads within a single project share a private network and are isolated within the security boundary of the project. All workloads within a project can talk to each other freely without concern of being seen by workloads outside of the cluster. If workloads in different projects want to communicate with each other, then the communication must either use the internet or an internal IBM private network. For more information, see Options for visibility for a {{site.data.keyword.codeengineshort}} application.

Create a project in {{site.data.keyword.codeengineshort}} called sample.

ibmcloud ce project create --name sample

{: pre}

Example output

Creating project 'sample'...
ID for project 'sample' is 'abcdabcd-abcd-abcd-abcd-abcd12e3456f7'.
Waiting for project 'sample' to be active...
Now selecting project 'sample'.
OK

{: screen}

Notice that your project is also selected for context, so all subsequent application-related commands are within the scope of this new sample project.

Creating a directory and source code

{: #cftut-create-dir} {: step}

  1. Create a directory on your local workstation that is named myapp and navigate into it. In this directory, save all the files that are required to build the image and to run your app.

    mkdir myapp && cd myapp

    {: pre}

  2. Create a file called server.js and copy the following source code into it.

    const http = require('http');
    
    
    http.createServer(function (request, response) {
      response.writeHead(200, {'Content-Type': 'text/plain'});
      response.end( "Hello world\n" );
    }).listen(8080);

    {: codeblock}

    This example uses Node.js. You can substitute code from any supported runtime. {: note}

Deploying your application

{: #cftut-build2-application} {: step}

Push your code to {{site.data.keyword.codeengineshort}} by using the application create command. You must provide a name for your application and the location of the source code. The following example creates an application called myapp that uses the buildpack strategy and provides the location for the source code in the current directory (.).

ibmcloud ce app create --name myapp --build-source . --strategy buildpacks

{: pre}

Example output

Creating application 'myapp'...
Packaging files to upload from source path '.'...
Submitting build run 'myapp-run-220999-210706331'...
Creating image 'private.us.icr.io/ce--6ef04-khxrbwa0lci/app-myapp:220418-0207-askql'...
Waiting for build run to complete...
Build run status: 'Running'
Build run completed successfully.
Run 'ibmcloud ce buildrun get -n myapp-run-220000-210706331' to check the build run status.
Waiting for application 'myapp' to become ready.
Configuration 'myapp' is waiting for a Revision to become ready.
Ingress has not yet been reconciled.
Waiting for load balancer to be ready.
Run 'ibmcloud ce application get -n myapp' to check the application status.
OK

https://myapp.abcdbwa0lci.us-south.codeengine.appdomain.cloud

{: screen}

And that's it. You now have an internet-facing application. The code in the application itself is the same as what is used for a Cloud Foundry application, it's just the {{site.data.keyword.codeengineshort}} commands that are slightly different.

Let's take a deeper look at the previous app create command. Notice that the output of the app create command provides information about the progression of the build run before the app is created and deployed.

  1. {{site.data.keyword.codeengineshort}} receives a request to create an application from source code (instead of pulling directly from an image).
  2. {{site.data.keyword.codeengineshort}} checks for an IAM service ID and API key that is associated with the selected project. This service ID must be authorized to read and write to {{site.data.keyword.registrylong_notm}}. If no service ID exists, {{site.data.keyword.codeengineshort}} creates one for you. Note that this service ID is used for subsequent {{site.data.keyword.codeengineshort}} build requests that are run from the same project.
  3. This example builds code from a local source (--build-source .). The source code is packed into an archive file and uploaded to a managed namespace within the {{site.data.keyword.registrylong_notm}} instance in your account. Note that you can target only {{site.data.keyword.registrylong_notm}} for your local builds. For more information about IBM Container Registry, including information about quota limits and access, see Getting started with IBM Cloud Container Registry.
  4. {{site.data.keyword.codeengineshort}} builds your source code into an image. The source image is created in the same namespace as your source archive file.
  5. After the build completes, your application is deployed. You can access your application from the provided URL.

With {{site.data.keyword.codeengineshort}}, you automatically get many of the same features as Cloud Foundry, such as autoscaling and blue-green roll-out of updates, but you'll also enjoy the benefits of newer features such as scaling down-to-zero, ensuring that you are not charged if your application is not active.

Want to learn more about your options for building your source code? See the application create and the job create commands.

Want to learn more about applications and jobs? See Working with apps in {{site.data.keyword.codeengineshort}} and Working with jobs and jobruns.

Clean up

{: #cftut-clean-up}

After you finish this tutorial, you can clean up the resources that you created with the following commands.

Delete your application

ibmcloud ce app delete --name myapp

{: pre}

When you delete your app, the associated build files are also deleted.

Lastly, delete the images that the build created from {{site.data.keyword.registrylong_notm}}.

  1. Navigate to Registry{: external} in the {{site.data.keyword.cloud_notm}} console.
  2. Find the archive and the image that are associated with your application by searching for your application name.
  3. Select the archive and image and delete.

Next steps

{: #cftut-migrate-next}

  1. Just starting your migration? Check out Getting started.
  2. Compare Cloud Foundry terminology with {{site.data.keyword.codeengineshort}}.
  3. Deploying Cloud Foundry applications in {{site.data.keyword.codeengineshort}}: Getting started (current page)
  4. Does your application use service bindings? Check out Migrating your service bindings.
  5. Learn about scaling and traffic management.
  6. Find {{site.data.keyword.codeengineshort}} equivalents to Cloud Foundry commands.
  7. Add a custom domain mapping from the console.
  8. Still have questions? Try the Migrating Cloud Foundry applications to {{site.data.keyword.codeengineshort}} FAQ.

Other information