/EKSContainerLab

Build services using .NET Core and Amazon EKS

MIT LicenseMIT

.NET Framework Application Modernization using .NET Core, Docker Containers, and Amazon EKS

Application modernization presents designers with a spectrum of technology migration challenges including:

  • Do we retain the current monolithic application architecture?
  • Shall we refactor the application architecture using a Cloud Native model?
  • Given time and resource constraints, should we simply replatform the application using Virtual Machines?

Ultimately, a Container based solution can account for each of these modernization scenarios.

Legacy applications tend to exist in maintenance mode with few dedicated software development resources. Hence, retaining some or all of the existing solution architecture and rehosting via Virtual Machines may be the only viable first step.

If the "right answer" for your workload is a "lift and shift" approach, then perhaps the image2Docker utility would enable a migration path towards Containers and thus reduce a costly Virtual Machine dependency.

Herein, we pursure more of an application replatforming + refactoring approach with a typical enterprise-class .NET 4.x Framework based application. A key consideration is to determine what solution elements cannot easily be refactored. Common .NET Framework application dependencies such as the Windows Registery, third-party libraries, file system APIs, IIS integrations, and data-access technologies, are now considered anti-patterns relative to Cloud Native architectures.

This article illustrates application modernization with the following objectives:

  • Rebuild from .NET Framework 4.x to .NET Core 2.x
  • Replatform from Windows to Linux
  • Refactor from a desktop architecture to a Managed Kubernetes Service (Amazon EKS) container architecture

Topical Agenda by Modules

Workshop Clean-Up (Once Complete)

Be sure to delete all of the resources created during the workshop in order to ensure that billing for the resources does not continue for longer than you intend. We recommend that you utilize the AWS Console to explore the resources you've created and delete them when you're ready.

For the any cases where you provisioned resources using AWS CloudFormation, you can remove those resources by simply running the following commands for each stack:

AWS CLI

aws cloudformation delete-stack --stack-name STACK-NAME-HERE

To remove all of the created resources, you can visit the following AWS Consoles, which contain resources you've created during this workshop:

Begin the Workshop

Proceed to Module 1