README ¶
App-AutoScaler
The App-AutoScaler
provides the capability to adjust the computation resources for Cloud Foundry applications through
- Dynamic scaling based on application performance metrics
- Scheduled scaling based on time
The App-AutoScaler
has the following components:
api
: provides public APIs to manage scaling policyservicebroker
: implements the Cloud Foundry service broker APImetricsgateway
: collects and filters loggregator events via loggregator v2 APImetricsserver
: transforms loggregator events to app-autoscaler performance metrics ( metricsgateway + metricsserver is a replacement of metricscollector)metricsforwarder
: receives and forwards custom metrics to loggregator via v2 ingress APIeventgenerator
: aggregates memory metrics, evaluates scaling rules and triggers events for dynamic scalingscheduler
: manages the schedules in scaling policy and trigger events for scheduled scalingscalingengine
: takes the scaling actions based on dynamic scaling rules or schedules
Development
System requirements
- Java 11 or above
- Docker
- Apache Maven 3
- Cloud Foundry cf command line 7 or 8
- Go 1.17 or above
Database requirement
The App-AutoScaler
supports Postgres and MySQL. It uses Postgres as the default backend
data store. These are run up locally with docker images so ensure that docker is working on
your system before running up the tests.
Setup
Note: all of the setup is encapsulated in the makefile targets. So you can run the test targets (test|integration) directly and it will setup and start the tests.
To set up the development, firstly clone this project
$ git clone https://github.com/cloudfoundry/app-autoscaler.git
Generate scheduler test certs
Initialize the Database
Note: The makefile will init the database if it has not already been run before running the tests.
-
Postgres
make init-db
-
MySQL
make init-db db_type=mysql
Generate TLS Certificates
Create the certificates.
Note:
- on macos it will install
certstrap
automatically but on other OS's it needs to be pre-installed - The makefile will create the certificates if it has not already been run before running the tests.
make test-certs
Unit tests
The default database is postgres
- Postgres:
make test
To use a specific postgres version:
make clean #Only if you're changing versions to refresh the running docker image.
make test POSTGRES_TAG=x.y
where:
-
x is the major version
-
y is the minor version ( this can be left out to get the most recent patch)
-
MySQL:
make test db_type=mysql
To use a specific MySQL version:
make clean #Only if you're changing versions to refresh the running docker image.
make test db_type=mysql MYSQL_TAG=x.y
where:
- x is the major version
- y is the minor version ( this can be left out to get the most recent patch)
Integration tests
The default database is postgres
- Postgres:
make integration
To use a specific postgres version:
make clean #Only if you're changing versions to refresh the running docker image.
make integration POSTGRES_TAG=x.y
where:
-
x is the major version
-
y is the minor version ( this can be left out to get the most recent patch)
-
MySQL:
make integration db_type=mysql
To use a specific MySQL version:
make clean #Only if you're changing versions to refresh the running docker image.
make integration db_type=mysql MYSQL_TAG=x.y
where:
- x is the major version
- y is the minor version ( this can be left out to get the most recent patch)
Build App-AutoScaler
make build
Clean up
You can use the make clean
to remove:
- database ( postgres or mysql)
- autoscaler build artifacts
Coding Standards
Autoscaler uses Golangci and Checkstyle for its code base. Refer to style-guide
Bosh Release for app-autoscaler service
Purpose
The purpose of this bosh release is to deploy and setup the app-autoscaler service.
Usage
Bosh Lite Deployment
-
Install Bosh-cli-v2
-
Install and start BOSH-Deployment, following its README.
-
Install CF-deployment
-
Create a new autoscaler client UAA CLI is required to here to create a new UAA client id.
-
Install the UAA CLI,
uaac
.gem install cf-uaac
-
Obtain
uaa_admin_client_secret
bosh interpolate --path /uaa_admin_client_secret /path/to/cf-deployment/deployment-vars.yml
-
Use the
uaac target uaa.YOUR-DOMAIN
command to target your UAA server and obtain an access token for the admin client.uaac target uaa.bosh-lite.com --skip-ssl-validation uaac token client get admin -s <uaa_admin_client_secret>
-
Create a new autoscaler client
uaac client add "autoscaler_client_id" \ --authorized_grant_types "client_credentials" \ --authorities "cloud_controller.read,cloud_controller.admin,uaa.resource" \ --secret <AUTOSCALE_CLIENT_SECRET>
-
-
Create and upload App-Autoscaler release
git clone https://github.com/cloudfoundry/app-autoscaler-release cd app-autoscaler-release make go-mod-tidy vendor db scheduler bosh create-release bosh -e YOUR_ENV upload-release
-
Deploy app-autoscaler with the newly created autoscaler client
In the latest App-Autoscaler v2.0 release , App-Autoscaler retrieves application's metrics with loggregator V2 API via gRPC over mutual TLS connection.
So the valid TLS certification to access Loggregator Reverse Log Proxy is required here. When deploying in bosh-lite, the most easy way is to provide loggregator certificates generated by
cf-deployments
.bosh -e YOUR_ENV -d app-autoscaler \ deploy templates/app-autoscaler-deployment.yml \ --vars-store=bosh-lite/deployments/vars/autoscaler-deployment-vars.yml \ -l <PATH_TO_CF_DEPLOYMENT_VAR_FILES> \ -v system_domain=bosh-lite.com \ -v cf_client_id=autoscaler_client_id \ -v cf_client_secret=<AUTOSCALE_CLIENT_SECRET> \ -v skip_ssl_validation=true
-
Deploy autoscaler with cf deployment mysql database
Notes: It is blocked by the pull request cf-deployment #881 temporarily. If you would like to use the cf mysql, please apply the
set-autoscaler-db.yml
in the pull request when deploy cf deployment.The lastest Autoscaler release add the support for mysql database, Autoscaler can connect the same mysql database with cf deployment. Use the operation file
example/operation/cf-mysql-db.yml
which including the cf database host , password and tls.ca cert.bosh -e YOUR_ENV -d app-autoscaler \ deploy templates/app-autoscaler-deployment.yml \ --vars-store=bosh-lite/deployments/vars/autoscaler-deployment-vars.yml \ -l <PATH_TO_CF_DEPLOYMENT_VAR_FILES> \ -v system_domain=bosh-lite.com \ -v cf_client_id=autoscaler_client_id \ -v cf_client_secret=<AUTOSCALE_CLIENT_SECRET> \ -v skip_ssl_validation=true \ -o example/operation/cf-mysql-db.yml
-
Deploy autoscaler with external postgres database and mysql database
bosh -e YOUR_ENV -d app-autoscaler \ deploy templates/app-autoscaler-deployment.yml \ --vars-store=bosh-lite/deployments/vars/autoscaler-deployment-vars.yml \ -l <PATH_TO_CF_DEPLOYMENT_VAR_FILE> \ -l <PATH_TO_DATABASE_VAR_FILE> \ -v system_domain=bosh-lite.com \ -v cf_client_id=autoscaler_client_id \ -v cf_client_secret=<AUTOSCALE_CLIENT_SECRET> \ -v skip_ssl_validation=true \ -o example/operation/external-db.yml
** The DATABASE_VAR_FILE should look like as below
database:
name: <database_name>
host: <database_host>
port: <database_port>
scheme: <database_scheme>
username: <database_username>
password: <database_password>
sslmode: <database_sslmode>
tls:
ca: |
-----BEGIN CERTIFICATE-----
-----END CERTIFICATE-----
The table below shows the description of all the variables:
Property | Description |
---|---|
database.name | The database name. |
database.host | The database server ip address or hostname. |
database.port | The database server port. |
database.scheme | The database scheme. Currently Autoscaler supports "postgres" and "mysql". |
database.username | The username of the database specified above in "database.name". |
database.password | The password of the user specified above in "database.username". |
database.sslmode | There are 6 values allowed for "postgres": disable, allow, prefer, require, verify-ca and verify-full. Please refer to Postgres SSL definition when define database_sslmode . For "mysql", there are 7 values allowed: false, true, skip-verify, preferred, verify-ca, verify_identity.Please refer to Mysql SSL definition(Golang) and Mysql Connector SSL |
database.tls.ca | PEM-encoded certification authority for secure TLS communication. Only required when sslmode is verify-ca or verify-full(postgres) or verify_identity(mysql) and can be omitted for other sslmode. |
Run linting
Linting can be run through make:
make lint
Autofix can be trigger by providing the following options:
OPTS=--fix RUBOCOP_OPTS=-A make lint
Register service
Log in to Cloud Foundry with admin user, and use the following commands to register app-autoscaler
service
cf create-service-broker autoscaler <brokerUserName> <brokerPassword> <brokerURL>
brokerUserName
: the user name to authenticate with service broker. It's default value isautoscaler_service_broker_user
.brokerPassword
: the password to authenticate with service broker. It will be stored in the file passed to the --vars-store flag (bosh-lite/deployments/vars/autoscaler-deployment-vars.yml in the example). You can find them by searching forautoscaler_service_broker_password
.brokerURL
: the URL of the service broker
All these parameters are configured in the bosh deployment. If you are using default values of deployment manifest, register the service with the commands below.
cf create-service-broker autoscaler autoscaler_service_broker_user `bosh int ./bosh-lite/deployments/vars/autoscaler-deployment-vars.yml --path /autoscaler_service_broker_password` https://autoscalerservicebroker.bosh-lite.com
Acceptance test
Refer to AutoScaler UAT guide to run acceptance test.
Use service
To use the service to auto-scale your applications, log in to Cloud Foundry with admin user, and use the following command to enable service access to all or specific orgs.
cf enable-service-access autoscaler [-o ORG]
The following commands don't require admin rights, but user needs to be Space Developer. Create the service instance, and then bind your application to the service instance with the policy as parameter.
cf create-service autoscaler autoscaler-free-plan <service_instance_name>
cf bind-service <app_name> <service_instance_name> -c <policy>
Remove the service
Log in to Cloud Foundry with admin user, and use the following commands to remove all the service instances and the service broker of app-autoscaler
from Cloud Foundry.
cf purge-service-offering autoscaler
cf delete-service-broker autoscaler
Monitoring the service
The app-autoscaler provides a number of health endpoints that are available externally that can be used to check the state of each component. Each health endpoint is protected with basic auth (apart from the api server), the usernames are listed in the table below, but the passwords are available in credhub.
Component | Health URL | Username | Password Key |
---|---|---|---|
eventgenerator | https://autoscaler-eventgenerator.((system_domain))/health | eventgenerator | /autoscaler_eventgenerator_health_password |
metricsforwarder | https://autoscaler-metricsforwarder.((system_domain))/health | metricsforwarder | /autoscaler_metricsforwarder_health_password |
metricsgateway | https://autoscaler-metricsgateway.((system_domain))/health | metricsgateway | /autoscaler_metricsgateway_health_password |
metricsserver | https://autoscaler-metricsserver.((system_domain))/health | metricsserver | /autoscaler_metricsserver_health_password |
scalingengine | https://autoscaler-scalingengine.((system_domain))/health | scalingengine | /autoscaler_scalingengine_health_password |
operator | https://autoscaler-operator.((system_domain))/health | operator | /autoscaler_operator_health_password |
scheduler | https://autoscaler-scheduler.((system_domain))/health | scheduler | /autoscaler_scheduler_health_password |
These endpoints can be disabled by using the ops file example/operations/disable-basicauth-on-health-endpoints.yml
You can follow the development progress on Pivotal Tracker.
Deploy and offer Autoscaler as a service
Go to app-autoscaler-release project for how to BOSH deploy App-AutoScaler
Use Autoscaler service
Refer to user guide for the details of how to use the Auto-Scaler service, including policy definition, supported metrics, public API specification and command line tool.
License
This project is released under version 2.0 of the Apache License.