zeus

module
v1.0.0-beta.rc1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 15, 2023 License: Apache-2.0

README

Documentation

https://docs.zeus.fyi

zK8s == Kubernetes + Zeus

Here we overview the core concepts needed to understand how you can build, deploy, configure K8s apps using Zeus, with a full walkthrough example of how we created an Ethereum beacon.

https://medium.com/@zeusfyi/zeus-k8s-infra-as-code-concepts-47e690c6e3c5

Hosted Docusaurus in 5 Minutes and Under $10/month

Developing Kubernetes applications is often complex and time-consuming, with a steep learning curve. However, the advent of zK8s is changing the game, allowing developers to build Kubernetes apps with pure Go code that’s functional, testable, and effortlessly turned into deployable infrastructure.

type WorkloadDefinition struct {
   WorkloadName string                    `json:"workloadName"`
   ReplicaCount int                       `json:"replicaCount"`
   Containers   zk8s_templates.Containers `json:"containers"`
   FilePath     filepaths.Path            `json:"-"`
}

type Containers map[string]Container

type Container struct {
   IsInitContainer bool        `json:"isInitContainer"`
   ImagePullPolicy string      `json:"imagePullPolicy,omitempty"`
   DockerImage     DockerImage `json:"dockerImage"`
}

type DockerImage struct {
   ImageName            string               `json:"imageName"`
   Cmd                  string               `json:"cmd"`
   Args                 string               `json:"args"`
   ResourceRequirements ResourceRequirements `json:"resourceRequirements,omitempty"`
   EnvVars              []EnvVar             `json:"envVars,omitempty"`
   Ports                []Port               `json:"ports,omitempty"`
   VolumeMounts         []VolumeMount        `json:"volumeMounts,omitempty"`
}
How we built a Docusaurus deployment from this.
wd := zeus_cluster_config_drivers.WorkloadDefinition{
    WorkloadName: "docusaurus-template",
    ReplicaCount: 1,
    Containers: zk8s_templates.Containers{
     docusaurusTemplate: zk8s_templates.Container{
      ImagePullPolicy: "Always",
      DockerImage: zk8s_templates.DockerImage{
         ImageName: "docker.io/zeusfyi/docusaurus-template:latest",
         ResourceRequirements: zk8s_templates.ResourceRequirements{
            CPU:    "100m",
            Memory: "500Mi",
         },
         Ports: []zk8s_templates.Port{
           {
             Name:               "http",
             Number:             "3000",
             Protocol:           "TCP",
             IngressEnabledPort: true,
             ProbeSettings: zk8s_templates.ProbeSettings{
                UseForLivenessProbe:  true,
                UseForReadinessProbe: true,
                UseTcpSocket:         true,
          },
         },
        },
      },
    },
  }
}
Tutorial & zK8s Overview

https://medium.zeus.fyi/hosted-docusaurus-in-5-minutes-and-under-10-month-af999d7ef90a

Authenticated API in 5 Minutes

Step by step tutorial using our UI

https://medium.com/@zeusfyi/zeus-ui-no-code-kubernetes-authenticated-api-tutorial-c468d5ef0446

zK8s Apps & Clients

zK8s is an expressive language for cloud infrastructure, used for building, assembling, and keeping them running over their entire lifecycle. Enabling cost efficient, effortless large scale infra automation, coordination, customization, and control.

cluster_config_drivers
system_config_drivers
workload_config_drivers

Workflow & Proxy Programmable Automation (Rolling releases coming through end of year)

artemis_workflows
iris_programmable_proxy

QuickNode MarketPlace users can find Load Balancing documentation in the iris programmable proxy directory

  • Adaptive Load Balancer Documentation
API Endpoints

Documentation and code examples are found here API_README.md

How to use the test suite to setup your own api calls README.md

The test directory contains useful mocks and tools for interacting with the API. It also contains a useful config-sample.yaml, convert this to config.yaml and set your bearer token here, which then allows you to use the demo code to create your first api request in seconds

Overview

  1. Automates translation of kubernetes yaml configurations into representative SQL models
  2. Users upload these infrastructure configurations via API where they are stored in the DB
  3. Users can then query the contents of these infrastructure components, deploy, mutate or destroy them on demand
Currently Supported Workload Types
  1. Deployments
  2. StatefulSets
  3. Services
  4. ConfigMaps
  5. Ingresses
  6. ServiceMonitors
  7. Secrets
  • Node Tainting Automation & Infra Provisioning (Servers & SSDs) Deployable & Scalable on Demand.
Pods Controller
  1. GetPods
  2. GetPodLogs
  3. PortforwardReqToPods
  4. DeletePods

Not every possible field type is supported, but the most common ones are, and even a decent amount of the uncommon ones. If you find a field you need isn't supported please send us an email at support@zeus.fyi

Hades Library

Hades is used to interact with Kubernetes workloads via API, and can apply saved Zeus workloads & cookbooks onto your own in house infrastructure.

Hera Client

This client uses the OpenAI API to generate code with AI. This service is available at OpenAI cost, so just pay for the token cost, otherwise it is free to use.

Cookbooks

Contains common web2 & web3 recipes for deploying applications, and managing infrastructure using zK8s or vanilla Kubernetes.

Zeus UI Highlights

Screenshot 2023-04-11 at 1 58 00 PM

Screenshot 2023-04-11 at 1 57 46 PM

Screenshot 2023-04-07 at 6 46 08 PM

Screenshot 2023-04-05 at 2 11 33 PM

Recent Articles

Introducing Serverless EVMs

Foundry’s Anvil as an EVM Simulation Environment on Demand.

Democratizing access to simulation technology at scale by lowering the cost of simulation to near zero. For safer smart contracts, less exploits, more robust engineering by using isolated ephemeral environments per each test. Screenshot 2023-11-02 at 11 52 38AM

https://medium.zeus.fyi/introducing-serverless-evms-0035549a5e7f

Secret Sauce: Running Ethereum Validators at Scale for Pennies

Why run them any other way after you’ve read this?

Screenshot 2023-11-03 at 2 06 34PM

https://medium.com/zeusfyi/secret-sauce-running-ethereum-validators-at-scale-for-pennies-24ac8dad4efd

Automating Validator Status Management in Ethereum in SQL

Using SQL Triggers and Relational States Compliant with Enforcing Consensus Spec

Screenshot 2023-11-02 at 11 51 00AM

https://medium.zeus.fyi/automating-validator-status-management-in-ethereum-in-sql-part-1-464e40e32b0b

Adaptive RPC Load Balancer Benchmarks

Over several weeks on a production load monitoring Uniswap prices

When should you consider using the Adaptive RPC Load Balancer?​

TLDR:

  • You need to scale your application to handle more requests than a single endpoint can handle
  • You need to reduce the error rate of your application
  • Especially if you are still paying for the request even if it fails
  • You need to improve the reliability of your application
  • You want to run multi-step procedures in a single request

weekly

https://medium.zeus.fyi/adaptive-rpc-load-balancer-benchmarks-c7aa3aa0d42a

High Performance Disks: NVMe in the Cloud

How to use NVMe disks the right way before you spend $$$$

https://medium.zeus.fyi/high-performance-disks-nvme-in-the-cloud-abb2bfc11fd9

Show Me the Stats

Optimal adaptive load balancing in stochastic environments. Recommended reading for scientists, engineers, data driven individuals

Screenshot 2023-09-14 at 11 12 23 PM

https://medium.com/zeusfyi/show-me-the-stats-6740f8d6d0b7

Adaptive RPC Load Balancer on QuickNode Marketplace

Accurate, Reliable, Performant Node Traffic at Web3 Scale

Screenshot 2023-09-14 at 11 11 30 PM

https://medium.com/zeusfyi/adaptive-rpc-load-balancer-on-quicknode-marketplace-e68bb7c9d8ac

Screenshot 2023-09-14 at 11 13 55 PM

Beta Testing Sign Up (free to use): https://marketplace.quicknode.com/add-on/zeusfyi-4

Directories

Path Synopsis
sui
examples
pkg
artemis/web3/vc
package vc contains an implementation of the W3 Verifiable Credentials data model.
package vc contains an implementation of the W3 Verifiable Credentials data model.
zeus

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL