Logo

dev-resources.site

for different kinds of informations.

When (Tech Service) Relationships Don’t Work Out

Published at
1/8/2025
Categories
cloudcomputing
heroku
aws
abdication
Author
johnjvester
Author
11 person written this
johnjvester
open
When (Tech Service) Relationships Don’t Work Out

article image

Think back to those days when you met the love of your life. The feeling was mutual. The world seemed like a better place, and you were on an exciting journey with your significant other. You were both “all-in” as you made plans for a life together.

Life was amazing … until it wasn’t.

When things don’t work out as planned, then you’ve got to do the hard work of unwinding the relationship. Communicating with each other, and with others. Sorting out shared purchases. Moving on. Bleh.

Believe it or not, our relationship with technology isn’t all that different.

Breaking up with a service

There was a time when you decided to adopt a service—maybe it was a SaaS, or a PaaS, or something more generic. Back in the day, did you make the decision while also considering the time when you would no longer plan to use the service anymore? Probably not. You were just thinking of all the wonderful possibilities for the future.

But what happens when going with that service is no longer in your best interest? Now, you’re in for a challenge, and it’s called service abdication. While services can be shut down with a reasonable amount of effort, getting the underlying data can be problematic. This often depends on the kind of service and the volume of data owned by that service provider.

Sometimes, the ideal unwinding looks like this: Stop paying for the service, but retain access to the data source for some period of time. Is this even a possibility? Yes, it is!

The power of VPC peering

Leading cloud providers have embraced the virtual private cloud (VPC) network as the de facto approach to establishing connectivity between resources. For example, an EC2 instance on AWS can access a data source using VPCs and VPC end-point services. Think of it as a point-to-point connection.

VPCs allow us to grant access to other resources in the same cloud provider, but we can also use them to grant access to external services. Consider a service that was recently abdicated but with the original data source left in place. Here’s how it might look:

Image 1

This concept is called VPC peering, and it allows for a private connection to be established from another network.

A Service Migration Example

Let’s consider a more concrete example. In your organization, a business decision was made to streamline how it operates in the cloud. While continuing to leverage some AWS services, your organization wanted to optimize how it builds, deploys, and manages its applications by terminating a third-party, cloud-based service running on AWS. They ran the numbers and concluded that internal software engineers could stand up and support a new auto-scaled service on Heroku for a fraction of the cost that they had been paying the third-party provider.

However, because of a long tenure with the service provider, migrating the data source is not an option anytime soon. You don’t want the service, and you can’t move the data, but you still want access to the data. Fortunately, the provider has agreed to a new contract to continue hosting the data and provide access—via VPC peering.

Here’s how the new arrangement would look:

Image 2

VPC Peering with Heroku

In order for your new service (a Heroku app) to access the original data source in AWS, you’ll first need to run your app within a Private Space. For more information, you can read about Secure cloud adoption and my discovery of Heroku Private Spaces.

Next, you’ll need to meet the following simple network requirements:

  • The VPC must use a compatible IPv4 CIDR block in its network configuration.

  • The VPC must use an RFC1918 CIDR block (10.0.0.0/8, 172.16.0.0/12, or 192.168.0.0/16).

  • The VPC’s CIDR block must not overlap with the CIDR ranges for your Private Space. The default ranges are 10.0.0.0/16, 10.1.0.0/16, and 172.17.0.0/16

With your Private Space up and running, you’ll need to retrieve its peering information:

$ heroku spaces:peering:info our-new-app
=== our-new-app Peering Info
AWS Account ID:    647xxxxxx317
AWS Region:        us-east-1
AWS VPC ID:        vpc-e285ab73
AWS VPC CIDR:      10.0.0.0/16
Space CIDRs:       10.0.128.0/20, 10.0.144.0/20, 10.0.0.0/20, 10.0.16.0/20
Unavailable CIDRs: 10.1.0.0/16
Enter fullscreen mode Exit fullscreen mode

Copy down the AWS Account ID (647xxxxxx317) and AWS VPC ID (vpc-e285ab73). You’ll need to give that information to the third-party provider who controls the AWS data source. From there, they can use either the AWS Console or CLI to create a peering connection. Their operation would look something like this:

$ aws ec2 create-vpc-peering-connection \ 
  --vpc-id vpc-e527bb17 \
  --peer-vpc-id vpc-e285ab73 \
  --peer-owner-id 647xxxxxx317
{
    "VpcPeeringConnection": {
        "Status": {
            "Message": "Initiating Request to 647xxxxxx317",
            "Code": "initiating-request"
        },
        "Tags": [],
        "RequesterVpcInfo": {
            "OwnerId": "714xxxxxx214",
            "VpcId": "vpc-e527bb17",
            "CidrBlock": "10.100.0.0/16"
        },
        "VpcPeeringConnectionId": "pcx-123abc456",
        "ExpirationTime": "2025-04-23T22:05:27.000Z",
        "AccepterVpcInfo": {
            "OwnerId": "647xxxxxx317",
            "VpcId": "vpc-e285ab73"
        }
    }
}
Enter fullscreen mode Exit fullscreen mode

This creates a request to peer. Once the provider has done this, you can view the pending request on the Heroku side:

$ heroku spaces:peerings our-new-app
Enter fullscreen mode Exit fullscreen mode

In the screenshot below, we can see the pending-acceptance status for the peering connection.

Image 3

From here, you can accept the peering connection request:

$ heroku spaces:peerings:accept pcx-123abc456 --space our-new-app
Accepting and configuring peering connection pcx-123abc456
Enter fullscreen mode Exit fullscreen mode

We check the request status a second time:

$ heroku spaces:peerings our-new-app
Enter fullscreen mode Exit fullscreen mode

We see that the peer connection is active.

Image 4

At this point, the app running in our Heroku Private Space will be able to access the AWS data source without any issues.

Conclusion

An unfortunate truth in life is that relationships can be unsuccessful just as often as they can be long-lasting. This applies to people, and it applies to technology.

When it comes to technology decisions, sometimes changing situations and needs drive us to move in different directions. Sometimes things just don’t work out. And in these situations, the biggest challenge is often unwinding an existing implementation—without losing access to persistent data.

Fortunately, Heroku provides a solution for slowly migrating away from existing cloud-based solutions while retaining access to externally hosted data. Its easy integration for VPC peering with AWS lets you access resources that still need to live in the legacy implementation, even if the rest of you has moved on.

Taking this approach will allow your new service to thrive without an interruption in service to the consumer.

Have a really great day!

cloudcomputing Article's
30 articles in total
Favicon
Best Tips to Prepare for the AWS Certification Exam in 2025
Favicon
AWS Certification Syllabus [Updated 2025]
Favicon
How to start Microsoft’s RDP client on Windows
Favicon
Step 1: GET-> SET-> AWS!
Favicon
Something You Didn't Know About AWS Availability Zones
Favicon
Query Data with DynamoDB
Favicon
Top 10 Reasons to Learn AWS in 2025
Favicon
Mastering Kubernetes Storage: A Deep Dive into Persistent Volumes and Claims
Favicon
From Regions to Edge Locations: A CiLoTs Guide to Cloud Infrastructure
Favicon
Cost Optimization Strategies for AWS: Leveraging Spot Instances, Savings Plans, and Cost Explorer
Favicon
How to Design a Secure and Scalable Multi-Region Architecture on AWS
Favicon
Legacy to Lightning: Tackling Cloud Challenges in Banking
Favicon
Master Azure Development: Linking Cloud Shell with VS Code on Windows Made Easy
Favicon
Por onde começar os estudos da AWS - Parte 1
Favicon
Introduction to AWS services & It's carrier opportunities
Favicon
open source multi tenant cloud database
Favicon
AWS Serverless: How to Create and Use a Lambda Layer via the AWS SAM - Part 2
Favicon
From Overspending to Savings: 5 Ways to Tame Your AWS Bill
Favicon
Understand Kubernetes Troubleshooting Cheat Sheet Now
Favicon
Want to learn a top skill in 2025? Then check out Cloud Computing.
Favicon
What Kind of Solution Would Santa Claus Use for Proper Gift Distribution?
Favicon
Demistfying AWS VPC Lattice
Favicon
Day 1: Setting up the AWS Weather Dashboard Application
Favicon
Understanding Node Problem Detector in Kubernetes: Beyond Default Node Conditions
Favicon
What is Cloud Native?
Favicon
The Role of Azure AI in Business: Transforming Enterprises with Intelligent Solutions in 2025
Favicon
10 Essential Tools Every Azure Administrator Should Know in 2025
Favicon
When (Tech Service) Relationships Don’t Work Out
Favicon
Building for the Future: How Scalable Web Architecture Can Help Your Business Grow Without Limits
Favicon
AWS Identity Access and Management

Featured ones: