-
Notifications
You must be signed in to change notification settings - Fork 173
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
Let's get our definitions straight :-) #174
Comments
I just hate "special words". If we can avoid making up our own words, would be easier to explain. I know there isn't a "standard", but clearly other's have looked at "tiny edge" before and come up with some words to describe. |
Who besides P1 has used tiny edge? |
For context, over in #172 I've been using:
So, saying something like this makes sense:
That can all be changed to use whatever we decide here though, for sure, cuz I love clarity in terms. |
I like how agent describes the way we install & always-on the Zarf k3s cluster. Might make a decent substitute for "appliance", as in: Appliance Mode --> Agent Mode maybe? |
It feels really awkward to me to try and have a term like the Zarf Agent describe the post-native-apply-"HA Utility Cluster" situation though. I get hella cognitive discord from trying to map something like the following onto machines & processes in my mind:
|
Fascinating conversation. I agree that appliance mode could be confusing and think trying to find words that explicitly descript the action or service provided is key. Designer brain - would a miro board where we can all brain dump ideas async help? And then we can find a time to converge? I would be happy to document the options already listed out here |
It feels like we're missing the name for a cluster that pulls something from the central utility cluster. In my head this is how I was thinking of things: Appliance Mode - Any cluster/application that is deployed by zarf that does not depend on an external "datasource" for git repos or registries. This would necessitate that those artifacts are co-deployed as part of the application installation. This could be done via the k3d boostrapping done currently, or by k8s-native-applying a git repo and registry as part of the installation process onto an existing cluster. I always pictured this as a single use cluster, i.e. no other applications would be run co-located, but that doesn't necessarily need to be true. Hub and Spoke - I don't necessarily love these names, but the Hub would be an appliance mode deployment of a git repo and/or registry that's used to centrally host artifacts. The Spoke is deployed via Zarf on an existing or bootstrapped cluster, but all artifacts are pulled from the Hub rather than being co-located on the cluster. Zarf would then be used a second time to "fill"/"seed"/"populate"/etc the artifacts for a particular spoke deployment. Ideally Zarf could use the same bundle to deploy via appliance mode or fill the hub and deploy on the spoke. Other names: upstream and downstream, mothership and satellite There are deployment paradigms where an end user doesn't want a Hub and Spoke, e.g. if they want to pull from upstream in connected environments. We would/could/should argue that we don't advocate for having a spoke/downstream/satellite by itself for production, but nothing would prevent this and provide a clear language for what this architecture looks like. It also doesn't prevent us from having a hub be a non-zarf cluster and just use existing managed services, that Zarf would still be responsible for filling/seeding with required artifacts for the spoke. |
In an attempt to make the various/expected usage scenarios more explicit & scope the conversation here, I've roughed out a diagram that:
The intention is to make clear that (based upon the chosen scenario) differently-named actors can be performing similar roles... which seems relevant for how & where we use specific terms to label certain actions / actors. Perhaps this helps us come up with "good names" for any of the nouns on the graph that I have intentionally filled called by functional-but-not-currently-used-placeholder names (anything inside "{{ blah blah }}" brackets)..? Any of those boxes look funny? Are there any "big ones" missing? Anyone feel like taking a wag at translating those "{{ --- }}" terms into something real(-ish)? |
Except for the datacenter feeder vs bootstrap I am hoping to be the same if possible, or at least from a users perspective. Ideally a user could easily decide to later scale the gitops service to HA vs completely change everything to go HA. If they are K3s or some larger distro that should be easy so long as we configure manifests to support that out of the box. Biggest issues I see are better persistent storage and the gitea db using SQLite. |
@jeff-mccoy @Racer159 @YrrepNoj @Madeline-UX I'd like to close this if it no longer needs discussion, or get this closed soon. Let's get this done next week. |
I think it's mostly already covered by our extensive docs work, no issue closing. |
Closing per @jeff-mccoy |
As the project has matured a lot of words and definitions have surfaced that need to be sorted out so the CLI and docs and clearly communicate to users what exactly is happening and how to use Zarf.
Background:
zarf init
command today. This is where it gets interesting--the native apply work will allow for "HA Utility Clusters" so it might not be an actual Appliance Mode deployment for the Utility Cluster, but some HA system (pick your K8s distro).Other Notes:
Maybe??:
When this is complete, revisit the language in #186
The text was updated successfully, but these errors were encountered: