mirror of
				https://github.com/datahub-project/datahub.git
				synced 2025-10-26 08:25:02 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			138 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # Using Docker Images During Development
 | |
| 
 | |
| We've created a special `docker-compose.dev.yml` override file that should configure docker images to be easier to use
 | |
| during development.
 | |
| 
 | |
| Normally, you'd rebuild your images from scratch with a combination of gradle and docker compose commands. However,
 | |
| this takes way too long for development and requires reasoning about several layers of docker compose configuration
 | |
| yaml files which can depend on your hardware (Apple M1).
 | |
| 
 | |
| The `docker-compose.dev.yml` file bypasses the need to rebuild docker images by mounting binaries, startup scripts,
 | |
| and other data. These dev images, tagged with `debug` will use your _locally built code_ with gradle.
 | |
| Building locally and bypassing the need to rebuild the Docker images should be much faster.
 | |
| 
 | |
| We highly recommend you just invoke `./gradlew quickstartDebug` task. 
 | |
| 
 | |
| ```shell
 | |
| ./gradlew quickstartDebug
 | |
| ```
 | |
| 
 | |
| This task is defined in `docker/build.gradle` and executes the following steps:
 | |
| 
 | |
| 1. Builds all required artifacts to run DataHub. This includes both application code such as the GMS war, the frontend
 | |
| distribution zip which contains javascript, as well as secondary support docker containers.
 | |
|  
 | |
| 1. Locally builds Docker images with the expected `debug` tag required by the docker compose files.
 | |
| 
 | |
| 1. Runs the special `docker-compose.dev.yml` and supporting docker-compose files to mount local files directly in the
 | |
| containers with remote debugging ports enabled.
 | |
| 
 | |
| Once the `debug` docker images are constructed you'll see images similar to the following:
 | |
| 
 | |
| ```shell
 | |
| acryldata/datahub-frontend-react                 debug              e52fef698025   28 minutes ago   763MB
 | |
| acryldata/datahub-kafka-setup                    debug              3375aaa2b12d   55 minutes ago   659MB
 | |
| acryldata/datahub-gms                            debug              ea2b0a8ea115   56 minutes ago   408MB
 | |
| acryldata/datahub-upgrade                       debug              322377a7a21d   56 minutes ago   463MB
 | |
| acryldata/datahub-mysql-setup                   debug              17768edcc3e5   2 hours ago      58.2MB
 | |
| acryldata/datahub-elasticsearch-setup            debug              4d935be7c62c   2 hours ago      26.1MB
 | |
| ```
 | |
| 
 | |
| At this point it is possible to view the DataHub UI at `http://localhost:9002` as you normally would with quickstart.
 | |
| 
 | |
| ## Reloading
 | |
| 
 | |
| Next, perform the desired modifications and rebuild the frontend and/or GMS components.
 | |
| 
 | |
| **Builds GMS**
 | |
| ```shell
 | |
| ./gradlew :metadata-service:war:build
 | |
| ```
 | |
| 
 | |
| **Builds the frontend**
 | |
| 
 | |
| Including javascript components.
 | |
| 
 | |
| ```shell
 | |
| ./gradlew :datahub-frontend:build
 | |
| ```
 | |
| 
 | |
| After building the artifacts only a restart of the container(s) is required to run with the updated code. 
 | |
| The restart can be performed using a docker UI, the docker cli, or the following gradle task.
 | |
| 
 | |
| ```shell
 | |
| ./gradlew :docker:debugReload
 | |
| ```
 | |
| 
 | |
| ## Start/Stop
 | |
| 
 | |
| The following commands can pause the debugging environment to release resources when not needed.
 | |
| 
 | |
| Pause containers and free resources.
 | |
| ```shell
 | |
| docker compose -p datahub stop
 | |
| ```
 | |
| 
 | |
| Resume containers for further debugging.
 | |
| ```shell
 | |
| docker compose -p datahub start
 | |
| ```
 | |
| 
 | |
| ## Debugging
 | |
| 
 | |
| The default debugging process uses your local code and enables debugging by default for both GMS and the frontend. Attach
 | |
| to the instance using your IDE by using its Remote Java Debugging features.
 | |
| 
 | |
| Environment variables control the debugging ports for GMS and the frontend.
 | |
| 
 | |
| - `DATAHUB_MAPPED_GMS_DEBUG_PORT` - Default: 5001
 | |
| - `DATAHUB_MAPPED_FRONTEND_DEBUG_PORT` - Default: 5002
 | |
| 
 | |
| ### IntelliJ Remote Debug Configuration
 | |
| 
 | |
| The screenshot shows an example configuration for IntelliJ using the default GMS debugging port of 5001.
 | |
| 
 | |
| 
 | |
| <p align="center">
 | |
|   <img width="70%"  src="https://raw.githubusercontent.com/datahub-project/static-assets/main/imgs/development/intellij-remote-debug.png"/>
 | |
| </p>
 | |
| 
 | |
| 
 | |
| 
 | |
| ## Tips for People New To Docker
 | |
| 
 | |
| ### Accessing Logs
 | |
| 
 | |
| It is highly recommended you use [Docker Desktop's dashboard](https://www.docker.com/products/docker-desktop) to access service logs. If you double click an image it will pull up the logs for you.
 | |
| 
 | |
| ### Quickstart Conflicts
 | |
| 
 | |
| If you run quickstart, use `./gradlew quickstartDebug` to return to using the debugging containers.
 | |
| 
 | |
| ### Docker Prune
 | |
| 
 | |
| If you run into disk space issues and prune the images & containers you will need to execute the `./gradlew quickstartDebug`
 | |
| again.
 | |
| 
 | |
| ### System Update
 | |
| 
 | |
| The `datahub-upgrade` job will not block the startup of the other containers as it normally
 | |
| does in a quickstart or production environment. Normally this is process is required when making updates which
 | |
| require Elasticsearch reindexing. If reindexing is required, the UI will render but may temporarily return errors
 | |
| until this job finishes.
 | |
| 
 | |
| ### Running a specific service
 | |
| 
 | |
| `docker-compose up` will launch all services in the configuration, including dependencies, unless they're already
 | |
| running. If you, for some reason, wish to change this behavior, check out these example commands.
 | |
| 
 | |
| ```
 | |
| docker-compose -p datahub -f docker-compose.yml -f docker-compose.override.yml -f docker-compose-without-neo4j.m1.yml -f docker-compose.dev.yml up datahub-gms
 | |
| ```
 | |
| Will only start `datahub-gms` and its dependencies.
 | |
| 
 | |
| ```
 | |
| docker-compose -p datahub -f docker-compose.yml -f docker-compose.override.yml -f docker-compose-without-neo4j.m1.yml -f docker-compose.dev.yml up --no-deps datahub-gms
 | |
| ```
 | |
| Will only start `datahub-gms`, without dependencies.
 | 
