Pre-Install Utility Help
Β π Overview
The Pre-Install Utility (PIU) can be used to verify property configurations are available and correct prior to the main MOC install. Because it is difficult to verify settings inside the cluster the PIU runs inside the cluster and allows the user to see the settings and health of the systems indirectly.
Β π Getting the Pre-Install Utility
Using Helm
The PIU is integrated into the MOC Helm install. You can simply enable the pre-install
service and the tool will be deployed so you can check important services as part of the install process.
PIU by default uses a SCCS (Spring Could Config Server) and is automatically configured if you enable the sccs
service (the most common configuration). You can also reference a config server or file outside MOC if needed.
Make sure you enable both the pre-install
and sccs
service in values.yaml or (starter yaml file)
Make sure to remove (or leave commented out) core
in the values.yaml file, as pre-install
may not be enabled at the same time as core
in the service list.
In the case where you do need to override properties or specify file(s) use the following parameters inside your helm pre-install.yaml template:
... spec: containers: - env: # This is an example of overrideing the mongo uri - name: modelop.mongodb-uri value: mongodb://modelop:modelop1234@mocaasin-prime.cluster-ccnbmpfpbzjf.us-east-2.docdb.amazonaws.com:27017/test?ssl=true&retryWrites=false # This is an example of overrideing the jira url - name: modelop.jira-url value: http://jira.qa.octopus.modelop.center # This is an example of specifing the config location file # see https://docs.spring.io/spring-boot/docs/1.4.1.RELEASE/reference/html/boot-features-external-config.html - name: spring.config.location value: classpath:/default.properties,classpath:/override.properties
Service Visibility
By default the service is not visible (set to ClusterIP
) so you either need to use port forwarding on the machine where you run your web browser or rest calls:
kubectl port-forward [Pod Name] 2888
β¦ or mark the service as LoadBalancer
as shown below:
moc: ... services: ... pre-install: serviceType: LoadBalancer
Using Docker
You can run PIU from docker using the commands below:
docker run --rm -p 2888:2888 modelop/pre-install:dev-bp
You can also override properties and parameters like as done in Helm, be sure to use the command line format (uppercase and separated by underscore character). To specify a SCCS server, for example, you would use the following command (Note you will need a server running on port 8097):
docker run --rm -p 2888:2888 -e SPRING_CLOUD_CONFIG_URI="http://localhost:8097" modelop/pre-install:dev-bp
or point override a specific property:
docker run --rm -p 2888:2888 -e MODELOP.MONGODB_URI="mongodb://admin:pass@mongodb:27017/test?authSource=admin" modelop/pre-install:dev-bp
Β π Pre-Install Utility Interface
Once running, you have two options to interact with PIU. Web interface and command line.
To view the interface simply go to the URL http://localhost:2888. From here you can check that property settings from the system are being found using the Properties links and then validate the setting using the Health links
The interface has the ability to check for property values specified by the user under the properties page. Under the Health page you can specify a URL to test for a valid connection relative to the PIU. Finally, the utility has the ability to verify the setup of an oauth provider for modelop services.
The commands available from the UI are also available from the command line, for example:
To get information about properties:
curl http://localhost:2888/api/properties
To get health information use:
curl http://localhost:2888/api/health (for all services)
Full API Details
Resource | Parameters | Example |
---|---|---|
| (optional) |
|
| (required) |
|
| (required) |
|
| (optional) |
|
Β π Options for updating properties
You can not directly update properties from the Pre-Install Utility, it is only for verifying that settings are valid. However you do have options to fix configuration issues:
The preferred method is to modify the environment variables of the system directly through the preinstall toolβs Environment Variables page. If you are using SCCS, you will likely need to set spring.cloud.config.overrideSystemProperties to false using one of the other options, in order to ensure that the PIU is able to correctly update its internal state from this page.
Ensure PIU is pointed to the correct SCCS (Spring Cloud Config) server in the helm configuration values.yaml file. A SCCS server is required for install so this is the best practice, however you use PIU without SCCS as noted under the Docker section above.
Update properties themselves directly. PIU will refresh properties internally when you update your browser page.
In addition (and while using options 2 or 3), you can override properties using Helm or Docker Desktop (as shown above). This is helpful if you want to override some parameters without changes to property files. You can also specify override the location for file locations themselves.
Using a parameters example (also see sections under Helm and Docker):
# For example overriding a specific property 'modelop.zipkin-url' with url value
docker run --rm -p 2888:2888 -e MODELOP_ZIPKIN-URL="http://localhost:9411/" modelop/pre-install:dev
Note: If you already have a SCCS server or are using the one provided by ModelOp then you only use the SCCS client (option 2 above)
Β π Advanced Options
Other options available
How do i disable / enable read write validation?
# change this setting as desired
moc:
preinstall:
validate-write-access: true
How do I filter some checks completely from the view
# change this setting as desired
moc:
preinstall:
included-health-checks: jenkins,jira,mongodb,rstudio,zipkin
You can also update the properties PIU scans for:
# change this setting as desired
moc:
preinstall:
included-properties: modelop.gateway-url,modelop.ws-gateway-url,modelop.moc-center-url