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

[Sandbox] Runme Notebooks for DevOps #127

Closed
2 tasks done
admc opened this issue Sep 17, 2024 · 8 comments
Closed
2 tasks done

[Sandbox] Runme Notebooks for DevOps #127

admc opened this issue Sep 17, 2024 · 8 comments
Assignees
Labels

Comments

@admc
Copy link

admc commented Sep 17, 2024

Application contact emails

[email protected]

Project Summary

Runme is a toolchain that turns Markdown into interactive, cloud-native, runnable Notebook experiences for DevOps.

Project Description

Runme: DevOps Notebooks Built with Markdown

Runme consolidates operational documentation and executable commands/code into interactive Notebooks or TUIs, seamlessly integrating with cloud-native infrastructure. The toolchain empowers engineering teams to build and maintain reliable, shareable documentation that can be tested in CI/CD.

Key Features:

  • Cloud Integration: Supports AWS, GCP, and GitHub Actions for managing deployments and automating cloud workflows directly from within Notebooks.
  • GitOps-Ready: Runme stores operational steps in Git-managed Markdown files, ensuring that runbooks, playbooks, and scripts are synchronized with infrastructure-as-code (IaC), tests, and GitOps processes, encouraging reviews/knowledge-sharing and keeping documentation up to date.
  • DevOps Tooling: Integrates with Kubernetes, Terraform, Helm, Docker, Dagger, and Argo CD for seamless orchestration and automation of infrastructure.
  • Environment Validation: Runme enables users to define and validate .ENV dependencies, ensuring all required resources and configurations are present before execution. Combined with devContainers, this delivers the most innovative and effective approach to repeatable, reliable documentation experiences.

Use Cases:

  1. Runbooks and Playbooks: Document and execute operational processes like deployments, infrastructure management, or incident response directly from Notebooks, ensuring consistency and repeatability.
  2. Automation: Automate workflows with tools like Terraform, Helm, Dagger, and Argo CD. Runme allows users to interact with these automated workflows one task (or category) at a time, without requiring the workflow to be a pipeline (although it can be run there as well).
  3. Interactive Control Panels: Build real-time dashboards for monitoring and tuning systems, enabling interactive control over infrastructure.

Runme’s kernel, exposed over gRPC, converts between Markdown and Notebook formats (as required by the client) and maintains the .ENV state across Notebook sessions, transforming Markdown into an interactive and reliable docs experience. Delivered as a VS Code platform compatible extension, Runme makes it easy to distribute Notebooks across environments like Codespaces, Gitpod, and VSCodium.

For more, visit the Runme Documentation.

Org repo URL (provide if all repos under the org are in scope of the application)

N/A

Project repo URL in scope of application

https://github.com/stateful/runme

Additional repos in scope of the application

https://github.com/stateful/vscode-runme
https://github.com/stateful/runme.dev
https://github.com/stateful/docs.runme.dev
https://github.com/stateful/runme-action

Website URL

https://runme.dev

Roadmap

https://github.com/stateful/runme/issues

Roadmap context

Roadmap is currently managed by prioritizing work in Github issues, but soon we'll be doing this using a project kanban.

The roadmap content is prioritized as follows:

  • Build, test, deploy process
  • Bugs blocking adoption from community
  • Feature requests from community
  • Cloud-native tools integrations and support
  • Cloud-provider integrations and support
  • Expansion of VS Code platform compatibility

Contributing Guide

https://github.com/stateful/runme/blob/main/CONTRIBUTING.md

Code of Conduct (CoC)

https://github.com/stateful/runme/blob/main/CODE_OF_CONDUCT.md

Adopters

No response

Contributing or Sponsoring Org

https://stateful.com

Maintainers file

https://github.com/stateful/runme/blob/main/MAINTAINERS.md

IP Policy

  • If the project is accepted, I agree the project will follow the CNCF IP Policy

Trademark and accounts

  • If the project is accepted, I agree to donate all project trademarks and accounts to the CNCF

Why CNCF?

Starting in my time at Buoyant I would attend Kubecon events, which have great energy. We've started exploring DevOpsDays, whose audience feels like the right place to build our community. Given the use-cases we see, it's clear that the intersection of devContainers, cloud-native, security/authorization and reproducible/reliable process for complex workflows is our bread and butter. We also see a lot of potential for partnering in the CNCF project landscape and adding value by lowering project barriers to entry, while collecting feedback to guide Runme to add the most tangible value.

Benefit to the Landscape

There is a huge opportunity for CNCF projects to embrace Runme as a more human friendly interface. Not just utilizing Runme for a nicer interface for their tool, but also to make the experience when using their tool more deeply integrated and intuitive. I continue to find it interesting that there are so many tools to support production cloud-native operations, but very little to support training, streamlining, educating and documenting the interfaces people need to really use them. Maybe it's time to open a new category?

Cloud Native 'Fit'

The simplest answer is that the tool is fairly agnostic and flexible about the specifics of the workflows being defined. But the reason that we moved from basic development flows to DevOps is because of how common it is for operators to build custom bash scripts to manage their day-to-day. We see a hole in the tooling landscape when it comes to reliable repeatable process that need to also exist outside of pipelines.

Here are some other components that make us a good fit for the CNCF landscape:

  • We are building on Markdown that can be checked into Git as the basic philosophy
  • Community building is a primary focus of the project and we work hard to operate in the open
  • The primary components of these Notebooks are bash or code that either calls a project's CLI, or talks directly to APIs, many of these use cases interface with cloud-native tools or cloud providers already
  • Out of the box we are a better way to share DevOps process that interacts with kubectl, terraform, helm, argo CD than what currently exists
  • We have already built cloud provider integrations to enhance the operational experience for Notebooks using them
  • Our Notebook data can be accessed over gRPC and consumed using Otel, making us a good fit for existing observability tooling
  • We are also working to provide an even more cloud-native onboarding experience through revamping our CLI to allow Runme projects to be initialized and configured with an init that generates a YAML
  • The Runme kernel is built with GoLang making it easy to be packaged, distributed and understood by our DevOps audience
  • We are already members of the Linux foundation

Cloud Native 'Integration'

We feel that interactive Notebooks complement basically any CNCF project that has a CLI or cloud dashboard that the user needs to understand and configure. Both from an educational/onboarding and day-to-day operational perspective. A great example is the overhead in knowing and running the numerous 'kubectl' commands with all their flags and arguments. Codifying these workflows as a Notebook makes it easy to follow along while passing data down the line and make sure that you not only get them right but also that the output is formatted in a way that is fit for human consumption.

Cloud Native Overlap

It is still way too hard to codify operational knowledge, which leads to a relatively high bar and constant learning of the different available tools and interfaces. This makes it really hard to stay competent when it comes to the cloud-native toolchain. We think we can lower the bar for the whole ecosystem, enabling more people to both get involved, contribute and also more effectively do their jobs.

Similar projects

N/A

Landscape

No

Business Product or Service to Project separation

Runme is the open source project, Stateful is the commercial company/product, the only place there is overlap is that the Runme VS Code extension and CLI have an integration with the hosted product allowing users to authorize using the VS Code account manager and push their data (notebook results) to our cloud. There is absolutely no requirement, obligation or OSS feature withholding involved.

Project presentations

No response

Project champions

No response

Additional information

No response

@edrob999
Copy link

TAG Contributor Strategy has reviewed this project and found the following:

  • Contributor Guide: is Complete, with a good section on how to find something to get started on
  • Governance: project does not yet have a written Governance file (NOT a blocking issue for sandbox acceptance)
  • Roadmap: with milestones/task breakdown/who-tasks-are-assigned-to/schedule is not yet formerly documented (NOT a blocking issue for sandbox acceptance)
  • Maintainers: Project has 6 maintainers, including one super maintainer

This review is for the TOC’s information only. Sandbox projects are not required to have full governance or contributor documentation.

@mrbobbytables
Copy link
Member

/vote

Copy link

git-vote bot commented Jan 14, 2025

Vote created

@mrbobbytables has called for a vote on [Sandbox] Runme Notebooks for DevOps (#127).

The members of the following teams have binding votes:

Team
@cncf/cncf-toc

Non-binding votes are also appreciated as a sign of support!

How to vote

You can cast your vote by reacting to this comment. The following reactions are supported:

In favor Against Abstain
👍 👎 👀

Please note that voting for multiple options is not allowed and those votes won't be counted.

The vote will be open for 2months 30days 2h 52m 48s. It will pass if at least 66% of the users with binding votes vote In favor 👍. Once it's closed, results will be published here as a new comment.

@mrbobbytables
Copy link
Member

@dzolotusky to follow up

@angellk angellk moved this from 🏗 Upcoming to 🤔 In voting in Sandbox Application Board Jan 15, 2025
@mrbobbytables
Copy link
Member

/check-vote

Copy link

git-vote bot commented Jan 15, 2025

Vote status

So far 63.64% of the users with binding vote are in favor and 0.00% are against (passing threshold: 66%).

Summary

In favor Against Abstain Not voted
7 0 0 4

Binding votes (7)

User Vote Timestamp
TheFoxAtWork In favor 2025-01-14 16:52:08.0 +00:00:00
kgamanji In favor 2025-01-15 8:16:27.0 +00:00:00
dims In favor 2025-01-14 21:29:54.0 +00:00:00
linsun In favor 2025-01-15 3:26:32.0 +00:00:00
angellk In favor 2025-01-14 22:15:17.0 +00:00:00
nikhita In favor 2025-01-15 2:23:24.0 +00:00:00
rochaporto In favor 2025-01-14 21:46:05.0 +00:00:00
@mauilion Pending
@dzolotusky Pending
@kevin-wangzefeng Pending
@cathyhongzhang Pending

Non-binding votes (7)

User Vote Timestamp
admc In favor 2025-01-14 16:56:32.0 +00:00:00
duvanmonsa In favor 2025-01-14 16:57:09.0 +00:00:00
peraltafederico In favor 2025-01-14 16:57:13.0 +00:00:00
sourishkrout In favor 2025-01-14 17:02:30.0 +00:00:00
fperaltamb In favor 2025-01-14 18:42:14.0 +00:00:00
pastuxso In favor 2025-01-14 21:15:16.0 +00:00:00
nderjung In favor 2025-01-15 10:54:28.0 +00:00:00

Copy link

git-vote bot commented Jan 16, 2025

Vote closed

The vote passed! 🎉

90.91% of the users with binding vote were in favor and 0.00% were against (passing threshold: 66%).

Summary

In favor Against Abstain Not voted
10 0 0 1

Binding votes (10)

User Vote Timestamp
@mauilion In favor 2025-01-15 16:52:41.0 +00:00:00
@nikhita In favor 2025-01-15 2:23:24.0 +00:00:00
@dzolotusky In favor 2025-01-15 16:33:40.0 +00:00:00
@linsun In favor 2025-01-15 3:26:32.0 +00:00:00
@rochaporto In favor 2025-01-14 21:46:05.0 +00:00:00
@dims In favor 2025-01-14 21:29:54.0 +00:00:00
@angellk In favor 2025-01-14 22:15:17.0 +00:00:00
@kgamanji In favor 2025-01-15 8:16:27.0 +00:00:00
@kevin-wangzefeng In favor 2025-01-16 1:39:58.0 +00:00:00
@TheFoxAtWork In favor 2025-01-14 16:52:08.0 +00:00:00

Non-binding votes (7)

User Vote Timestamp
@admc In favor 2025-01-14 16:56:32.0 +00:00:00
@duvanmonsa In favor 2025-01-14 16:57:09.0 +00:00:00
@peraltafederico In favor 2025-01-14 16:57:13.0 +00:00:00
@sourishkrout In favor 2025-01-14 17:02:30.0 +00:00:00
@fperaltamb In favor 2025-01-14 18:42:14.0 +00:00:00
@pastuxso In favor 2025-01-14 21:15:16.0 +00:00:00
@nderjung In favor 2025-01-15 10:54:28.0 +00:00:00

@mrbobbytables
Copy link
Member

Congrats!
With the vote completed, I've created #334 for following up on sandbox onboarding. I'll go ahead and close this out and further follow up can occur there :)

@github-project-automation github-project-automation bot moved this from 🤔 In voting to ✅ Done in Sandbox Application Board Jan 21, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
Status: Done
Development

No branches or pull requests

6 participants