This is a docker container or Standalone Script to install/run an On-Premise Deployment of AppDynamics - https://www.appdynamics.com/
NOTE - This should only be used for Demo / Small environments and is not intended for a Production installation.
- Enterprise Console
- Controller
- Events Server
- EUM Server
- Synthetic Server
- Custom GEO Server
- Machine Agent
- Analytics Agent (When chosen, will also run Machine Agent as its bundled)
- Database Agent
This is intended to be a light-weight installation, however the following minimum specs should be sufficient
Device | Minimum | Recommended |
---|---|---|
CPU Cores | 8 | 16 |
RAM | 16GB | 32GB |
Disk Space | 500GB | 1 TB |
- For disk space, note actual install is less than 1GB however once AppD starts monitoring transactions your data pool will fill up.
- RHEL
- CentOS
- Ubuntu
This will check for and utilize the 'your-platform.env' file located within /opt/appdynamics directory (DOCKER) or in the same directory as the 'firstrun.sh' script file (STANDALONE install). If you don't have the file already downlaoded/modified and placed into the directory a default will be copied over and utilized. You will need to modify 'your-platform.env' prior to installation. For the best use of this feature, modify the entire file and copy to each host that will be running all of your appd dockers/hosts and utilize the SCENARIO variable outlined below.
By default, this will install the latest version of each component found on download.appdynamics.com, and (IN A FUTURE RELEASE) will auto update itself to the latest version on each container start or execution of 'firstrun.sh' script (STANDALONE), but if you want to run a different version (to go back to the previous version perhaps), modify your-platform.env file appropriately.
SCENARIO variable is treated as a string, adding any text containing the substrings below will add the component(s).
- EC = Enterprise Console
- CONT = Controller
- ES = Events Service
- EUM = End User Monitoring Server
- SYN = Synthetic Server
- GEO = Custom Geo Server for Browser RUM
- MA = Machine Agent
- AA = Analytics Agent
- DA = Database Agent
Port Requirements for Components (Expose these at the container via -p command or ensure --net="host" is used)
- Enterprise Console: 9191
- Controller: 8090, 8181
- Events Service: 9080, 9081
- End User Monitoring: 7001, 7002
- Synthetic Server: 10001, 10002, 10101, 10102, 12101, 12102, 16101, 16102 (optional 16101 and 16102 are for AppD externally hosted agents)
- Custom Geo Server: 8080 (Configurable, internal container port needs to be 8080 however)
- Machine Agent: No inbound communication (no need to expose)
- Database Agent: No inbound communication (no need to expose)
- Analytics Agent: 9090, 9091
-
You can download the latest software at download.appdynamics.com and place the binaries of the enterprise console (optional components) in the 'APPD_INSTALL_DIR' (host directory for docker) or in the same directory as the 'firstrun.sh' script file. Otherwise, the script will download it for you if you have given your AppDynamics Community credentials in the 'your-platform.env' file which will be placed in '/opt/appdynamics'.
-
You can place your 'license.lic' file in '/opt/appdynamics' or directory of 'firstrun.sh' before install and it will activate on initial build or upon startup of container. This is handy for updating your license file periodically.
-
Configure User Limits in Linux. AppDynamics requires the following hard and soft per-user limits in Linux: Open file descriptor limit (nofile): 65535 Process limit (nproc): 8192 https://docs.appdynamics.com/appd/20.x/en/appdynamics-application-performance-monitoring-platform/planning-your-deployment/physical-machine-controller-deployment-guide/prepare-the-controller-host/prepare-linux-for-the-controller
-
DOCKER USERS - If you are running on anything other than Unraid OS you can open a console to your container via
docker exec -i -t appdynamics-server-all-in-one /bin/bash
- Unraid users - simply click the container in your web ui and select ">_ console"
-
AppDynamics Software will be installed in </opt/appdynamics>/appdynamics directory (DOCKER) or /opt/appdynamics for Standalone (to change this please see below section 'Your Platform Configuration'. This allows you to view/modify contents easily from your host. You can also delete and recreate the container while data persists.
-
If your installation goes sour, backup your license file, delete the folder </opt/appdynamics>/appdynamics and restart the container.
-
DOCKER USERS - You can monitor the the logs of your container by issuing the following command
docker logs -f container-name
Tip - docker ps
- this command will list all containers
- Download the entire source code and place it in a directory of your choice
- Execute the firstrun.sh script this will create a template your-platform.env file in the install directory (default /opt/appdynamics)
- Modify your-platform.env file to suit your needs.
- Execute the firstrun.sh script to install and start all of your components
Ensure you have docker-compose installed on your system.
-
Download the sample docker-compose.yml and /install-scripts/your-platform.env files into a single directory.
-
Modify the files if necessary, note if you don't download the appd binaries you will need to enter your appd community credentials into the .env file.
-
Execute the below command in the directory you downloaded the yml and env file.
docker-compose up -d
On Unraid, install from the Community Applications and enter the app folder location, your Appdynamics Community Email and Password. Note: I am not storing your password or doing anything malicious it is required to download the AppDynamics binary from the website, also note is not required if you choose to download the latest version and place it in your app directory. All source code for the installation is found here on Github.
- By default this will install all components in a single container. If this is not your intended install, please see the section 'Install Scenarios' below.
On other platforms, you can run this docker with the following command:
docker run -d --name="appdynamics-server-all-in-one" --net="host" -v /host/install/dir:/opt/appdynamics:rw -v /etc/localtime:/etc/localtime:ro csek06/appdynamics-server-all-in-one
- Replace the "/opt/appdynamics" with your choice of host location
- If the -v /etc/localtime:/etc/localtime:ro mapping causes issues, you can try -e TZ="" with the timezone in the format of "America/New_York" instead
docker run -d --name="appdynamics-server-EC-CONT" --net="host" -p 9191:9191 -p 8090:8090 -p 8181:8181 -v /host/install/dir:/opt/appdynamics:rw -v /etc/localtime:/etc/localtime:ro csek06/appdynamics-server-all-in-one
docker run -d --name="appdynamics-server-EC-Cont-ES" --net="host" -p 9191:9191 -p 8090:8090 -p 8181:8181 -p 9080:9080 -p 9081:9081 -v /host/install/dir:/opt/appdynamics:rw -v /etc/localtime:/etc/localtime:ro csek06/appdynamics-server-all-in-one
docker run -d --name="appdynamics-server-EUM" --net="host" -p 7001:7001 -p 7002:7002 -v /host/install/dir:/opt/appdynamics:rw -v /etc/localtime:/etc/localtime:ro csek06/appdynamics-server-all-in-one
docker run -d --name="appdynamics-server-SYN" --net="host" -p 10001-10002:10001-10002 -p 10101-10102:10101-10102 -p 12101-12102:12101-12102 -p 16101-16102:16101-16102 -v /host/install/dir:/opt/appdynamics:rw -v /etc/localtime:/etc/localtime:ro csek06/appdynamics-server-all-in-one
docker run -d --name="appdynamics-server-GEO" --net="host" -p 80:80 -v /host/install/dir:/opt/appdynamics:rw -v /etc/localtime:/etc/localtime:ro csek06/appdynamics-server-all-in-one
docker run -d --name="appdynamics-server-MA" --net="host" -e AppdUser="[email protected]" -e AppdPass="XXXX" -e CONTROLLER_HOST=192.168.2.X -e CONTROLLER_PORT=8090 -e SCENARIO=MA -e -v /host/install/dir:/opt/appdynamics:rw -v /etc/localtime:/etc/localtime:ro csek06/appdynamics-server-all-in-one
Additional Optional Variables - configured within your-platform.env
-
MA_ENABLE_SIM - (true | false) Enable server visibility for container
-
MA_ENABLE_SIM_DOCKER - (true | false) Enable host server visibility https://docs.appdynamics.com/display/CLOUD/Monitoring+Docker+Containers
- REQUIRED paths if true
-v /var/run/docker.sock:/var/run/docker.sock -v /proc:/hostroot/proc:ro -v /etc:/hostroot/etc:ro -v /sys:/hostroot/sys:ro
docker run -d --name="appdynamics-server-AA" --net="host" -p 9090:9090 -p 9091:9091 -e AppdUser="[email protected]" -e AppdPass="XXXX" -e EVENTS_SERVICE_HOST=192.168.2.X -e EVENTS_SERVICE_PORT=9080 -e CONTROLLER_HOST=192.168.2.X -e CONTROLLER_PORT=8090 -e SCENARIO=AA -v /host/install/dir:/opt/appdynamics:rw -v /etc/localtime:/etc/localtime:ro csek06/appdynamics-server-all-in-one
docker run -d --name="appdynamics-server-DA" --net="host" -e AppdUser="[email protected]" -e AppdPass="XXXX" -e CONTROLLER_HOST=192.168.2.X -e CONTROLLER_PORT=8090 -e SCENARIO=DA -e -v /host/install/dir:/opt/appdynamics:rw -v /etc/localtime:/etc/localtime:ro csek06/appdynamics-server-all-in-one
The install process takes about 15 minutes on recent hardware. You can monitor the install process via the logs - docker command below.
docker logs -f container-name
- Login - admin
- Password - appd
Once installed, open the WebUI at http://CONTROLLERHOST:9191/ and validate that your controller, MySQL DB, and Events Service are running.
- Navigate to http://CONTROLLERHOST:7001/eumaggregator/ping to validate the EUM server started.
- Navigate to http://CONTROLLERHOST:8090/controller/#/location=LICENSE_MANAGEMENT_PEAK_USAGE&timeRange=last_1_hour.BEFORE_NOW.-1.-1.60 to validate your license has been applied.
- 2019-12-03 - Implemented Synthetic Server, Avoid online lookup via FILENAME variable feature, minor code fixes
- 2019-11-21 - Created docker-compose file, Standardized on Install Directory, minor code fixes
- 2019-10-17 - Standardized on using FORM, Modularized script to install components outside of Docker, minor code fixes
- 2019-08-05 - Implemented FORM feature: see 'FORM' section above
- 2019-07-31 - Implemented Custom Geo Server for Browser RUM
- 2019-07-30 - Implemented Analytics Agent, Implemented Deployment Sizing Variable, minor code fixes
- 2019-03-14 - Implemented Database Agent
- 2019-03-11 - Implemented Machine Agent
- 2019-03-05 - Separated install/startup scripts - Instrumented Install Scenarios
- 2019-02-28 - Release 1.0.0 - Removed manual post-installation steps. Everything is now automatic!
- 2019-02-27 - Changed startup script to validate if software is installed.
- 2019-02-26 - Initial release - successfully downloads and installs Enterprise Console / Controller / Events Service / EUM Server (it will not upgrade and expects a clean slate in the config directory - known bugs around deleting downloaded files)
- 2019-02-25 - Initial release - still not completely functional - only downloads binary for installation at this point.