We're Rewriting Sdkbin

10 Aug 2023

We're Rewriting Sdkbin

In light of the recent drama with the Moq project’s decision to try to solicit donations through the use of SponsorLink, I’ve decided to share some updates on Sdkbin - our NuGet marketplace for .NET developers that we launched in October, 2020.

The last update I shared on Sdkbin was February 2021 - Sdkbin has continued to be a major driver of revenue growth for us with our Phobos product and handles about 33% of our total revenue.

However, as I shared on Twitter yesterday - we are embarking on a project to rewrite Sdkbin in order to fulfill our mission of becoming the marketplace for OSS developers to build businesses around their technology.

Read More

DRY Gone Bad: Bespoke Company Frameworks

08 Mar 2023

DRY Gone Bad: Bespoke Company Frameworks

There are some software development best practices out there that are universally and unambiguously true outside of any specific business context - “use source control” is a great example. These are rare.

The lion’s share of software industry “best practices” - SOLID principles, “Clean Code,” DRY, and so on -...

Read More

Why Self-Fulfilling Prophecies Come True

23 Dec 2022

Why Self-Fulfilling Prophecies Come True

In the aftermath of the 2022 midterm elections in the United States many conservative leaders, disappointed with the election results, blamed their poor showing on mail-in voting laws in key states:

“We will never win elections in states like Pennsylvania, Nevada, or Michigan so long as there’s mass mail-in...

Read More

Beware the Long 'YAGNI'

06 Dec 2022

Beware the Long 'YAGNI'

One of my favorite regularly occurring Twitter arguments is over what should be a simple and uncontroversial question: have you ever had to migrate to a different database in a production application before?

I wrote about our adventures migrating databases for MarkedUp analytics here thus I answer this question accordingly. But the group of developers who fascinate me are the ones who answer along the lines of “no and YAGNI - You Ain’t Gonna Need It.”

The reason for the “controversy” around this question is the “YAGNI” - the attitude that you should never need to migrate databases unless you’re incompetent, I guess.

Read More

Reflections on a Decade of Self-Employment

17 Aug 2022

Reflections on a Decade of Self-Employment

Ten years ago on August 10th, 2012 I wrote “Today I am Leaving Microsoft and Starting my Own Company” and cap-stoned my final day of working for someone else. Since then, I founded two companies:

I’ve learned a lot over ten years and I’m learning more every year, but I thought I’d take this milestone as an opportunity to reflect on the journey so far.

Read More

Professional Open Source: Extend-Only Design

27 Dec 2021

Professional Open Source: Extend-Only Design

This post marks the third one I’ve written this year about versioning problems in open source software development, although they apply to anyone who develops shared software components:

In this post I’m...

Read More

An Overview of Distributed Tracing with OpenTelemetry in .NET 6

21 Dec 2021

An Overview of Distributed Tracing with OpenTelemetry in .NET 6

I’ve given multiple talks and written posts about distributed tracing, a still relatively novel concept in the field of application performance monitoring (APM,) and how distributed tracing gives us observability into the dynamic run-time behavior of networked applications. I’ve also previously written about OpenTelemetry, “OTel” for short, an emerging industry-wide standard that combines distributed tracing with traditional metrics-based application performance monitoring into a single consumable standard that all APM vendors will eventually support.

In this blog post we’ll explore OpenTelemetry tracing in .NET 6.

OpenTelemetry logo

Read More

The Future of the .NET Foundation and .NET OSS

12 Oct 2021

The Future of the .NET Foundation and .NET OSS

.NET Foundation Logo

The last time I wrote about the .NET Foundation was in the context of the “Project Maturity Ladder” proposal in late 2019 - a well-intentioned, but ultimately not really appropriate measure aimed at trying to increase the adoption of best practices among member projects.

The .NET Foundation has its heart in the right place - widening the range of “acceptable” OSS beyond what is produced in Redmond. I want that too. Everyone does, most of all the developers who aren’t able to use that OSS today because of the historical conservatism of the .NET ecosystem as a whole when it comes to OSS.

The current proposal puts the .NET Foundation as a centralized certification authority for the entire .NET ecosystem. That’s heavy-handed and will ultimately undermine the .NET ecosystem’s ability to become “bigger than Microsoft.”

The key takeaways from that saga, which is still recent in the minds of many maintainers who are participating in this week’s public outrage against the Foundation:

  • The .NET Foundation did not build any agreement with member projects before introducing the maturity ladder proposal, so it came as a surprise to its member projects;
  • The .NET Foundation appeared to be pursuing some different priorities than those of the member projects itself, the former pursuing continuity of business and professionalism of the projects whereas the projects themselves are much more focused on supporting themselves and reducing costs; and
  • In general, the .NET Foundation’s top-down approach to trying to manage the ecosystem wasn’t really aligned with maintainer’s expectations (set by the Foundation itself years earlier) of a bottom-up, collaborative federation of projects. Too much Cathedral, not enough Bazaar.

I issued a warning at the time that going down this road of treating member projects like they’ve automatically agreed to whatever the Foundation leadership decides to do by the virtue of joining it will lead to misalignment between the two groups of stakeholders. In other words, agreements have to be constantly renewed among the members - otherwise there will be less cooperation, less trust, and a lot more public push-back.

Two years later and it’s clear that the .NET Foundation did not learn these lessons.

I’m going to address this in three parts:

  1. Summary of the current kerfuffle;
  2. Paths forward for the .NET Foundation and its projects; and
  3. Aspirations for the .NET OSS movement.

Read More

On Generational Thinking

16 Aug 2021

On Generational Thinking

Three weeks to the day my wife and I welcomed our daughter to the world and ascended to parenthood.

When I first laid eyes on her, instantly recognizing my own features in her minutes-old face, I had one feeling course through my veins: a deep, uplifting, and eternal sense of responsibility. A lifelong commitment made automatically without the utterance of a word.

And it was then I understood what so many other parents, in their own way, had tried to communicate to me about parenthood: it’s a higher calling and you’ll understand what that means once you’re in it. In my unspoken promise to her I realized purpose.

I didn’t worry much about the unknowns while she was in the womb since there’s little, if anything, I could do about those. Instead I turned my attention to things I could control: preparing our home, our routines, our finances, and so on. But one nagging thought that straddled the can / can’t control divide tugged at my conscience: “what sort of world will your daughter inherit and how will you prepare her for it?”

Read More

.NET Open Source: What Happens When the Free Lunch Ends?

03 Jun 2021

.NET Open Source: What Happens When the Free Lunch Ends?

It’s a Thursday, which means: .NET open source drama.

Read More