Applications
Starting Apps for Development
In order to run a component, it is required to run csw-location-server. Moreover, even to start the Event Service or Configuration Service, csw-location-server should be running.
A shell script has been provided to make the starting of services more convenient for developers. This script will start the Location Service, and then a set of CSW services that a developer may make use of. All services are started by default, but specific services can be started using the command line options (see below).
Assuming that developer has downloaded csw-apps-<some-version>.zip from csw releases and unzipped it, there are four folders, as follows, in csw-apps-<some-version>
- bin
- lib
- logging_aggregator
- conf
All the shell scripts provided by CSW reside in bin folder. The shell script referred in this segment is named as csw-services.sh. Go to the bin folder and type ./csw-services.sh --help. This will list all possible options applicable for the script.
Environment variables which are needed to start CSW services are documented in environment variables.
This shell script will start csw-location-server as the first step regardless of any options provided. 
The execution of the script is such that it starts csw-location-server, then start all the CSW services, unless one or more of the following options are specified.
- --all|- -aif provide, starts all the services mentioned below
- --config|- -cif provided, starts configuration service.
- --event|- -eif provided, starts event service.
- --alarm|- -rif provided, starts alarm service.
- --database|- -dif provided, starts database service.
- --auth|- -kif provided, starts authentication service.
While starting the Database Service, make sure that
- The PGDATAenvironment variable is set to the Postgres data directory where Postgres is installed e.g. for mac: “/usr/local/var/postgres” and
- there is a password set for the valid Postgres user. If not, go to the Postgres shell via psqland runALTER USER <username> WITH PASSWORD '<mypassword>';.
To start all the CSW services, run ./csw-services.sh start --all command. 
With this, the component code is now ready to connect to the provided services via csw-services.sh. 
csw-services.sh script additionally support custom CSW version as a command line argument along with others mentioned above. Let’s say you want to start all the services for CSW version of 2.0.0, then you can run following command:
./csw-services.sh start --all -v 2.0.0
By default csw-services.sh script runs services in the foreground, you can press ctr+c to stop all the services. If you start services in background by running ./csw-services.sh start & command, then you can stop these services using csw-services.sh stop command.
Starting Elastic Logging Aggregator for Development
Elastic stack (Elasticsearch, Logstash, Kibana and Filebeat) is used to aggregate logs generated from TMT applications (Scala/Java/Python/C++/C) and CSW services (mentioned in the previous section). For development purposes, Docker compose is used. Hence, make sure that latest Docker setup is installed and running before starting the Elastic stack. To know more about how Elastic stack works please refer to Logging Aggregator.
For the host setup, follow the below given steps:
- Install Docker version 18.09+
- Install Docker Compose version 1.24.0+
On distributions which have SELinux enabled out-of-the-box, you will need to either re-context the files or set SELinux into Permissive mode in order for docker-elk to start properly. For example, on Redhat and CentOS, the following will apply the proper context:
$ chcon -R system_u:object_r:admin_home_t:s0 docker-elk/
To know more about running Docker for Mac please refer to this link. For Windows, ensure that the “Shared Drives” feature is enabled for the C: drive (Docker for Windows > Settings > Shared Drives). See Configuring Docker for Windows Shared Drives (MSDN Blog).
Assuming that the developer has downloaded csw-apps-<some-version>.zip from csw releases and unzipped it, there are four folders, as follows, in csw-apps-<some-version>:
- bin
- lib
- logging_aggregator
- conf
Go to logging_aggreator/dev and run
- docker-compose build --no-cache
- docker-compose up --force-recreate
This will start Filebeat, Elasticsearch, Logstash and Kibana in a Docker container. Note that csw-services.sh will generate all log files under /tmp/tmt/logs/csw and Filebeat will watch for them there.
Once, the Docker container is up, open an browser and go to http://localhost:5601/ to use Kibana. Go to:
- Management->- Kibana->- Index Patternsand create an index pattern as per the requirement.
- Discover->- Select the index pattern createdand explore
To use a different Elastic Stack version than the one currently available in the repository, simply change the version in logging_aggreator/dev/.env file, and rebuild the stack with:
- docker-compose build --no-cache
- docker-compose up --force-recreate
Always pay attention to the upgrade instructions for each individual component before performing a stack upgrade.