copyright | lastupdated | keywords | subcollection | content-type | completion-time | ||
---|---|---|---|---|---|---|---|
|
2022-05-12 |
code engine, tutorial, build, source, application, buildpack, access, build run, image, cloud foundry |
codeengine |
tutorial |
10m |
{{site.data.keyword.attribute-definition-list}}
{: #migrate-cf-ce-local} {: toc-content-type="tutorial"} {: toc-completion-time="10m"}
Let's deploy a simple hello world
app to see how {{site.data.keyword.codeengineshort}} works. Follow the steps to create a project, prepare your code, and deploy your app.
{: shortdesc}
Review Cloud Foundry and {{site.data.keyword.codeengineshort}} terms before starting this tutorial.
{: #cf-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}}.
{: #cf-prereqs}
Before you can get started with {{site.data.keyword.codeengineshort}}, you need to set up your account and install the CLI.
-
All {{site.data.keyword.codeengineshort}} users are required to have a Pay-as-you-Go account.
-
While you can use {{site.data.keyword.codeengineshort}} through the console, the examples in this documentation focus on the command line. Therefore, you must install the {{site.data.keyword.codeengineshort}} CLI.
ibmcloud plugin install code-engine
{: pre}
For more information, see setting up the {{site.data.keyword.codeengineshort}} CLI. For more information about the CLI, see {{site.data.keyword.codeengineshort}} CLI reference.
All {{site.data.keyword.codeengineshort}} users are required to have a Pay-as-you-Go account. Tutorials might incur costs. Use the Cost Estimator to generate a cost estimate based on your projected usage. For more information, see {{site.data.keyword.codeengineshort}} pricing. {: note}
{: #local-log-cloud} {: step}
Follow these steps to log in to your {{site.data.keyword.cloud_notm}} account and target a resource group.
-
Log in to the {{site.data.keyword.cloud_notm}} CLI.
ibmcloud login
{: pre}
-
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}
{: #local-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. You can then configure access to these projects, similar to configuring access to your Cloud Foundry orgs
. 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.
{: #local-create-dir} {: step}
-
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}
-
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);
{: pre}
This example uses Node.js. You can substitute code from any supported runtime. {: note}
{: #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'...
Creating build 'myapp-build-220000-210706331'...
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 and build run before the app is created and deployed.
- {{site.data.keyword.codeengineshort}} receives a request to create an application from source code (instead of pulling directly from an image).
- {{site.data.keyword.codeengineshort}} checks for an IAM service ID and APIkey that is associated with the selected project. This service ID must be authorized to read and write to {{site.data.keyword.registrylong}}. 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.
- 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}} instance in your account. Note that you can target only {{site.data.keyword.registrylong}} 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. - {{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.
- 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.
{: #local-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}}.
- Navigate to Registry{: external} in the {{site.data.keyword.cloud_notm}} console.
- Find the archive and the image that are associated with your application by searching for your application name.
- Select the archive and image and delete.
{: #migrate-cf-ce-next-local}
- Just starting your migration? Check out Getting started.
- Compare Cloud Foundry terminology with {{site.data.keyword.codeengineshort}}.
- Deploying your application code from a local source (current page)
- Does your application use service bindings? Check out Migrating your service bindings.
- Learn about scaling and traffic management.
- Find {{site.data.keyword.codeengineshort}} equivalents to Cloud Foundry commands.
- Still have questions? Try the Migrating Cloud Foundry applications to {{site.data.keyword.codeengineshort}} FAQ.
Other information
- Find out about {{site.data.keyword.codeengineshort}} pricing.
- Try other {{site.data.keyword.codeengineshort}} tutorials{: external}.
- Explore other {{site.data.keyword.codeengineshort}} topics.