1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-10 23:01:04 +01:00

Unprototype Almanac

Summary: Fixes T10449. Almanac doesn't do a whole lot for the average user, but is in good shape technically and works well, and exposing it in the cluster won't let installs destroy themselves now.

Test Plan: Re-read documentation; grepped for `TODO` (there are a couple, but reasonable to push off); browsed around all the UI things (new two-column looks great), called API methods.

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T10449

Differential Revision: https://secure.phabricator.com/D15400
This commit is contained in:
epriestley 2016-03-04 16:33:49 -08:00
parent 85bf04ea02
commit 809646c8d2
2 changed files with 13 additions and 14 deletions

View file

@ -35,10 +35,6 @@ final class PhabricatorAlmanacApplication extends PhabricatorApplication {
); );
} }
public function isPrototype() {
return true;
}
public function getRoutes() { public function getRoutes() {
return array( return array(
'/almanac/' => array( '/almanac/' => array(

View file

@ -6,21 +6,24 @@ Using Almanac to manage devices and services.
Overview Overview
======== ========
IMPORTANT: Almanac is a prototype application. See
@{article:User Guide: Prototype Applications}.
Almanac is a device and service inventory application. It allows you to create Almanac is a device and service inventory application. It allows you to create
lists of //devices// and //services// that humans and other applications can lists of //devices// and //services// that humans and other applications can
use to keep track of what is running where. use to keep track of what is running where.
Almanac is an infrastructure application that will normally be used by
administrators to configure advanced Phabricator features. In most cases,
normal users will very rarely interact with Almanac directly.
At a very high level, Almanac can be thought of as a bit like a DNS server. At a very high level, Almanac can be thought of as a bit like a DNS server.
Callers ask it for information about services, and it responds with details Callers ask it for information about services, and it responds with details
about which devices host those services. However, it can respond to a broader about which devices host those services. However, it can respond to a broader
range of queries and provide more detailed responses than DNS alone can. range of queries and provide more detailed responses than DNS alone can.
Today, the primary use cases for Almanac involve configuring Phabricator Today, the primary use cases for Almanac are internal to Phabricator:
itself: Almanac is used to configure Phabricator to operate in a cluster setup,
and to expose hardware to Drydock so it can run build and integration tasks. - Providing a list of build servers to Drydock so it can run build and
integration tasks.
- Configuring Phabricator to operate in a cluster setup.
Beyond internal uses, Almanac is a general-purpose service and device inventory Beyond internal uses, Almanac is a general-purpose service and device inventory
application and can be used to configure and manage other types of service and application and can be used to configure and manage other types of service and
@ -37,13 +40,13 @@ introduction to Almanac concepts and a better idea of how the pieces fit
together. together.
In this scenario, we want to use Drydock to run some sort of build process. To In this scenario, we want to use Drydock to run some sort of build process. To
do this, Drydock needs hardware to run on. We're going to use Almanac to tell do this, Drydock needs hardware to run on. We're going to use Almanac to give
Drydock about the hardware it should use. Drydock a list of hosts it should use.
In this scenario, Almanac will work a bit like a DNS server. When we're done, In this scenario, Almanac will work a bit like a DNS server. When we're done,
Drydock will be able to query Almanac for information about a service (like Drydock will be able to query Almanac for information about a service (like
`build.mycompany.com`) and get back information about which hosts are part of `build.mycompany.com`) and get back information about which hosts are part of
that service and where it should connect to. that service and which addresses/ports it should connect to.
Before getting started, we need to create a **network**. For simplicity, let's Before getting started, we need to create a **network**. For simplicity, let's
suppose everything will be connected through the public internet. If you suppose everything will be connected through the public internet. If you
@ -52,7 +55,7 @@ haven't already, you'd create a "Public Internet" network first.
Once we have a network, we create the actual physical or virtual hosts by Once we have a network, we create the actual physical or virtual hosts by
launching instances in EC2, or racking and powering on some servers, or already launching instances in EC2, or racking and powering on some servers, or already
having some hardware on hand we want to use. We set the hosts up normally and having some hardware on hand we want to use. We set the hosts up normally and
connect them to the internet or network. connect them to the internet (or another network).
After the hosts exist, we add them to Almanac as **devices**, like After the hosts exist, we add them to Almanac as **devices**, like
`build001.mycompany.com`, `build002.mycompany.com`, and so on. In Almanac, `build001.mycompany.com`, `build002.mycompany.com`, and so on. In Almanac,