-
Notifications
You must be signed in to change notification settings - Fork 11
Running services locally
-
Be sure you've setup elixir, erlang and docker prior to following this guide illustrating how to run application code. Setup link
-
A reminder that an architecture diagram is available here
-
When running multiple UrbanOS dependency containers, it's sometimes helpful to give the system docker service additional memory. My machine defaulted to 2GB, and upping to 6GB resulted in significantly less issues. 4GB is probably also reasonable. Raising memory available to docker with Docker Desktop
From the root of the repository, run:
-
mix deps.get
to install elixir dependencies for all of the applications in the umbrella.
From the apps/e2e
directory, run:
-
docker compose -f test/docker-compose.yml up -d
to startup all docker containers required by the UrbanOS Suite. (Kafka, Postgres, Elasticsearch, etc)-
Add the
-d
flag to run in detached mode, with the compose process running in the background -
Reminder: If you'd like to run a single microservice instead of multiple, refer to that microservice README.md in
smarcitiesdata/apps/{microservice or library}/README.md
. You'll need significantly less containers running to test only one microservice.
-
-
With the docker containers now running, start the elixir apps by following the startup commands listed in each app's readme. Remember to skip any steps in application readmes that mention starting Docker, because we did that in the previous step for all apps.
- The core 4 services at time of writing are:
Reaper
,Alchemist
,Valkyrie
andForklift
. These are the recommended core services to startup individually. - As mentioned, the readme files for those services will be more accurate then
this guide, but at time of writing, the command to start all four is the same:
MIX_ENV=integration iex -S mix
. I run that in 4 terminal windows, in each of directories of the 4 apps.
- The core 4 services at time of writing are:
-
To setup datasets and ingestions for UrbanOS to fetch and store data, you'll need to also startup
Andi
. You'll need an Auth0 tenant configured for UrbanOS in order to runAndi
. (Setting up an UrbanOS Auth0 Tenant)
Now that UrbanOS core services are running, we'll use Andi to configure an organzation, dataset, and ingestion. By the end of this section, data from a remote source will be stored on a database in your system, processed by UrbanOS.
We'll ingest this piece of json data as an example, but feel free to configure an ingest for your own remote source.
Note: Chromium browsers work significantly better with Andi than webkit at time of writing.
-
From the
smartcitiesdata/apps/andi/assets
directory, runnpm install
.- Node should have been installed as part of the setup
-
Afterwards, Andi can be started with the startup command listed in the readme, that should look something like this:
AUTH0_CLIENT_SECRET="<auth_client_secret>" MIX_ENV=integration iex -S mix start
- auth_client_secret is the Client Secret in the Settings of the corresponding tenant configuration for the Andi application in Auth0.
-
Open a browser and visit Andi by going to https://127.0.0.1.nip.io:4443/datasets. Choose login in the top corner, and create a user with the Auth0 dialog that pops up. Each time Andi is started, it's recommended that you logout and login again at application launch.
-
you'll notice the datasets, ingestions, and organizations index pages are empty.
-
Before you can create a dataset you need to create an organization. You see your organization in the list at
/organizations
once saved. -
With an organization, you're now able to create a dataset! Section 1 of the form will define it's metadata, and Section 2 will define the dataset schema. The dataset schema will align with the schema of the data you're fetching from a remote source, unless you opt to configure additional transformations.
- Help configuring attributes of a dataset in the Andi guide
- You should now see your dataset in the list!
-
The last Andi resource required to start to ingest data, is an "Ingestion". At time of writing, section 3 (transformations) of the create ingestion form is not yet complete. Fill out sections 1 2 and 4 to create an ingestion. Guide on creating ingestions The simplest ingestion for getting started would be one with a single HTTP extract step, set as some static json. Example URL
- Section 4 configures the ingestion cadence. UrbanOS supports ingestion cadences around a maximum of every 2 seconds at time of writing, but something like 30 seconds might be best for testing purposes to avoid filling your local database.
-
https://crontab.guru/ is good for debugging cadence declarations.
-
*/30 * * * * *
represents every 30 seconds
-
Your configured data should now be flowing through the system, and being stored in an internal database. In the next section, we'll show how to access this ingested data from a front end website.
todo