Kubernetes Dashboard Design Sprint (Łódź, Poland, 23 Mar 2016)

    Sketch the directions of the development of the UI to achieve:

    • scalability for the variety of types of K8s objects we want to handle (currently: replication controllers & pods; desired: replica sets, daemon sets, container, nodes, volumes, secrets, deployments etc.)
    • scalability for the number of such objects (currently: cards are suitable for <20 objects; desired: show >100 pods in a nice way)
    • good UX for various use cases (monitor, debug, deploy, explore)
    • more aware about namespaces
    • agree on the meeting’s goals
    • split into 3 groups - propose a general UX vision - discuss them together, unify
    • split again - sketch the system in more detail - discuss, unify
    • split once more - sketch a chosen page, in yet more detail - discuss
    • decide when and how to publish the results
    • constant, basic-purpose navigation menu on the left, containing:

      • under them, sub-items describing types of objects
      • possibly, other special buttons, e.g. “resource explorer”
      • possibly, minimizable
    • context-dependent action bar on the top (below the main “K8s” bar)

      • buttons for basic actions, e.g. “create”, “edit”, “delete”
      • single namespace / all namespaces / multi-choice / filter
      • shall it be visible also on the object details page?

    Cards

    • will be generally replaced by table rows
    • possibly thicker to contain few more data items and/or some graphs
    • much more clear sorting; sort triggered by clicking on column name
    • easier pagination
    • does no more list all objects (or RCs) in the cluster
    • instead, it shows:
      • important messages (errors/warnings/suggestions)
      • a few selected objects (last visited/most visited/most important)

    Details page of an object

    • general requirements:

      • has possibly (but reasonably) unique design across various object types
      • allows convenient navigation to all directly related objects; by this we mean e.g. that a pod shows links to all volumes it uses, and conversely, a volume shows links to all pods using it
      • contains a number of sections (described below); some of them may be moved to other tabs if everything does not fit in one page (e.g. we will need several tabs for RCs, but not for secrets)
    • section (main tab): a brief description of the object status

      • for a more complex one, this contains most important properties, while all properties are gathered in another tab of the page
    • section (main tab): visual summaries for all directly related objects (aggregated by type)

      • example: for a RC, these could be activity graphs of all involved pods, volumes, services etc.
      • grouped by type
      • each type is headed by a user-friendly description of type, and of the relation to the current object (e.g. ‘volumes mounted to this pod’, ‘pods mounting this volume’, etc.)
      • limited to e.g. 10 top items, to make them all fit in one page (this has the form of a table, so clicking column names allows adjusting the meaning of “top”)
      • if there are more related objects of some type, we provide a link to the list of all of them (see below)
    • other sections (main or additional tab): history, logs, (more?)

    • can be:
      • global (with namespace restriction applied), reachable by left menu panel
      • scoped (all objects of type X related to object O), reachable from O details page
    • similar visual design to the object details page
    • upper section: general metrics of involved objects
    • lower section: list of all involved objects, tabularized

    Supplementary ideas, questions etc.

    • resource explorer

      • goal: give a larger-scale insight into cluster structure (beyond “directly related” links)
      • shall easily support filtering
      • two considered views:
        • “filebrowser view”: very compact but difficult to model all relations in a cluster (a volume may have many pods mounting it as “parents”; network communication between pods is not at all a “parent-child-sibling” relation)
        • “graph visualization”
    • error messaging policy On the details page of a RC, do we want to show that 3 out of 100 its volumes are broken? Is this important enough? Generally, what is sufficiently important? How do we decide on this?