Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Our continued commitment to Steeltoe and the broader .NET community #1244

Open
TimHess opened this issue Jan 10, 2024 · 3 comments
Open

Our continued commitment to Steeltoe and the broader .NET community #1244

TimHess opened this issue Jan 10, 2024 · 3 comments

Comments

@TimHess
Copy link
Member

TimHess commented Jan 10, 2024

Quick History

Steeltoe was originally started by Pivotal 8+ years ago to cloud native and observability outcomes available in the Spring ecosystem to enterprise customers with .NET applications. The name SteelToe is a derivative of IronBoot, originating from the convention of using the “Iron” prefix for external offerings brought into the .NET ecosystem (i.e. IronRuby, IronPython, IronFoundry, etc…). The adoption of Steeltoe along with the availability of Windows server VMs on Pivotal Cloud Foundry (now named Tanzu Application Service) enabled the platform to provide a valuable and collaborative platform for both .NET and Spring applications. With the accelerated adoption shown in downloads of Steeltoe Nuget packages, we were excited to donate the project to the .NET foundation in 2017. Later, we built and donated the .NET version of OpenCensus, preceding the evolution into OpenTelemetry.

The Announcement of .NET Aspire

The launch of .NET Aspire, along with Microsoft.Extensions.ServiceDiscovery mark Microsoft’s genuine entry into the domain Steeltoe has occupied all this time. We are excited to contribute our own expertise to the Aspire project and continue moving towards even stronger and more approachable solutions to cloud native constructs in Microsoft namespaces. Steeltoe is not going away. We are going to rearrange where some of the functionality in Steeltoe resides (in collaboration with the Aspire project leaders) and continue to provide and innovate with Spring and Tanzu integration opportunities. The following section lays out our initial plan but we also need to hear from you! Please let us know your thoughts on the details of these projects and how you see them in relation to Aspire. Having more feedback from our Steeltoe community will help us ensure that the right options are chosen.

What is coming in Steeltoe 4.0

Our release plans for Steeltoe 4.0 and beyond have been available in our OSS repository for visibility and feedback. With the announcement of .NET Aspire and our conversations so far in collaboration with their project team, we will be continuing to deliver the following in Steeltoe 4.0:

  • Public API Surface Area Review
  • Enhanced compatibility with runtime configuration via IOptions usage
  • .NET 8 support
  • Configuration
    • [possibly research-only] Support for application configuration service on Tanzu
  • Connectors
  • Management
    • Actuators available on an alternate port
  • Service Discovery
    • Align abstractions and core functionality with Aspire/Microsoft.Extensions.ServiceDiscovery
    • Blue/Green deployments through endpoints
      • Use endpoint to set registered instances to online/offline
  • Refactoring, bugfixes and usability improvements across all components

In addition to the removal of Hystrix and the Credhub Client (prior to the announcement of .NET Aspire), we are planning to remove the following projects from Steeltoe 4.0 and future releases:

  • Common.Expression
  • Common.Hosting
  • Common.Kubernetes
  • Common.Net
  • Common.RetryPolly
  • Configuration.Kubernetes
  • Discovery.Kubernetes
  • Integration and related packages
  • Management.Kubernetes
  • Management.Tracing
  • Management.Wavefront
  • Messaging and related packages
  • Stream and related packages

Please let us know your thoughts on these planned project removals from Steeltoe OSS. We are eager to hear from you on the matter and any other feedback you may have.

Conclusion

We are excited about the future of the Steeltoe project. We expect accelerated popularity within the .NET developer community as we align closer to .NET Aspire. The Steeltoe project remains with the .NET Foundation and will continue to provide value to our extended community.

@thompson-tomo
Copy link
Contributor

thompson-tomo commented Jan 15, 2024

I think it is a good move to align with Aspire and allow that to lead to a reduction in overlap between the 2 solutions and have them becoming complimentary.

One thing I think would be worthwhile is to move the service discovery to implement Microsoft.Extensions.ServiceDiscovery.Abstractions which also appears to be falling under the Aspire team. With this approach we could use eureka as a service provider for Aspire. This would be a similar approach as has been done for config. #1254

@em-jones
Copy link

I just wanted to applaud the decision to align with Aspire.
There seems to be a lot of mixed experiences and opinions about 3rd-party OSS and .NET blurring lines between each other(e.g. - the ongoing Eventing discussion vs the polly partnership).

Are there any resources that we can reference that would help interested parties see how that partnership is playing out?
Blog articles, forums, podcasts, or presentations?

@TimHess
Copy link
Member Author

TimHess commented Jan 3, 2025

I just wanted to applaud the decision to align with Aspire. There seems to be a lot of mixed experiences and opinions about 3rd-party OSS and .NET blurring lines between each other(e.g. - the ongoing Eventing discussion vs the polly partnership).

Are there any resources that we can reference that would help interested parties see how that partnership is playing out? Blog articles, forums, podcasts, or presentations?

Hi @em-jones,

Agreed on mixed experiences, some of that is present here as well.

Unfortunately, the Steeltoe team's participation with Aspire in 2024 was affected by the Broadcom acquisition of VMware from the perspective of acquisition-related distractions and corporate legal red tape... I expect we'll be able to dig in properly this year.

In the meantime, we've been pretty focused on our v4 release (which was already a major overhaul without factoring in Aspire). We were able to make some contributions to the ConfigurationSchemaGenerator and use it in Steeltoe as well. We've also been doing some work preparing for obvious incompatibilities with Service Discovery, but I'm sure there's more to do there as well.

So not much in terms of shareable content yet, but we'll try to be loud about that when it does exist!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants