2018-11-13 12:38:37 -05:00
<!--
~ Licensed to the Apache Software Foundation (ASF) under one
~ or more contributor license agreements. See the NOTICE file
~ distributed with this work for additional information
~ regarding copyright ownership. The ASF licenses this file
~ to you under the Apache License, Version 2.0 (the
~ "License"); you may not use this file except in compliance
~ with the License. You may obtain a copy of the License at
~
~ http://www.apache.org/licenses/LICENSE-2.0
~
~ Unless required by applicable law or agreed to in writing,
~ software distributed under the License is distributed on an
~ "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
~ KIND, either express or implied. See the License for the
~ specific language governing permissions and limitations
~ under the License.
-->
2017-05-16 12:26:16 -04:00
# IntelliJ Setup
2019-04-17 09:27:14 -04:00
This document contains some examples and instructions on how to get IntelliJ setup to run local debugging and test
setups of Druid.
2017-05-16 12:26:16 -04:00
2017-11-09 12:27:27 -05:00
## Project SDK
The "SDK", configured for the Druid project, *must* be called `1.8` , to avoid annoying changes of
2020-03-23 23:57:03 -04:00
[`.idea/misc.xml` ](/.idea/misc.xml ) file, that you shouldn't check into your commits. If you don't have an SDK on your
2017-11-09 12:27:27 -05:00
dev machine with this name, you should either rename one of the existing SDKs to `1.8` , or create another one with this
name, and it could point to the same files as some other existing SDK, even if it's actually JDK 9+. `1.8` is just
an alias name. You can do this in Using `File` -> `Project Structure...` -> `Platform Settings` -> `SDKs`
(see also [IntelliJ help page about this ](https://www.jetbrains.com/help/idea/configuring-intellij-platform-plugin-sdk.html )):
![IntelliJ SDK Config ](intellij-sdk-config.jpg )
2017-05-16 12:26:16 -04:00
## Code Style
The Code Style is available in XML format at [druid_intellij_formatting.xml ](druid_intellij_formatting.xml ) and can be [imported into IntelliJ ](https://www.jetbrains.com/help/idea/2017.1/copying-code-style-settings.html ).
2020-06-05 17:19:42 -04:00
## Git Checkstyle Verification Hook (Optional)
Git Checkstyle pre-commit hook can be installed to automatically run checkstyle verification before committing,
saving cycle from avoiding the checkstyle failing later in Travis/CI environment.
The hook can be setup easily by running the < DRUID_HOME > /setup-hooks.sh script.
2017-05-16 12:26:16 -04:00
## Metadata
2020-03-22 20:41:18 -04:00
The installation of a MySQL metadata store is outside the scope of this document, but instructions on setting up MySQL can be found at [docs/development/extensions-core/mysql.md ](/docs/development/extensions-core/mysql.md ). This assumes you followed the example there and have a database named `druid` with proper permissions for a user named `druid` and a password of `diurd` .
2017-05-16 12:26:16 -04:00
Use of other databases such as Postgres or Derby are entirely reasonable, but doing so is left as an excercise to the reader.
## ZooKeeper
This also assumes you have [ZooKeeper ](http://zookeeper.apache.org/releases.html ) running locally, which usually just involves downloading the latst distribution of ZooKeeper, doing some minor configuration in ZooKeeper's `conf/` directory (most defaults are fine), then running `./bin/zkServer.sh start` in the ZooKeeper directory.
2020-05-21 15:35:54 -04:00
On macOS, you can also achieve this through the following commands
1. `brew install zookeeper`
2. `brew services start zookeeper`
2017-05-16 12:26:16 -04:00
## Initial Build
2020-05-21 15:35:54 -04:00
Before running or debugging the apps, you should do a `mvn clean install -Pdist -DskipTests` in the Druid source in order to make sure directories are populated correctly.
`-Pdist` is required because it puts all core extensions under `distribution\target\extensions` directory, where `runConfigurations` below could load extensions from.
You may also add `-Ddruid.console.skip=true` to the command if you're focusing on backend servers instead of frontend project. This option saves great building time.
2017-05-16 12:26:16 -04:00
## XML App Def
2020-03-23 23:57:03 -04:00
You can configure application definitions in XML for import into IntelliJ. Below are a few examples. These should be placed in an XML file in `.idea/runConfigurations` in the Druid source code.
2017-05-16 12:26:16 -04:00
### Historical.xml
```xml
< component name = "ProjectRunConfigurationManager" >
< configuration default = "false" name = "Historical" type = "Application" factoryName = "Application" >
< extension name = "coverage" enabled = "false" merge = "false" sample_coverage = "true" runner = "idea" / >
2018-08-30 12:56:26 -04:00
< option name = "MAIN_CLASS_NAME" value = "org.apache.druid.cli.Main" / >
2019-01-02 03:44:02 -05:00
< option name = "VM_PARAMETERS" value = "-server -Duser.timezone=UTC -Dfile.encoding=UTF-8 -Xmx2G -XX:MaxJavaStackTraceDepth=9999 -XX:+UseG1GC -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintAdaptiveSizePolicy -XX:+PrintReferenceGC -verbose:gc -XX:+PrintFlagsFinal -Djava.util.logging.manager=org.apache.logging.log4j.jul.LogManager -Dorg.jboss.logging.provider=slf4j -Dlog4j.configurationFile=$PROJECT_DIR$/core/src/main/resources/log4j2.debug.xml -Ddruid.host=localhost -Ddruid.service=historical -Ddruid.server.maxSize=10000000000 -Ddruid.processing.buffer.sizeBytes=100000000 -Ddruid.extensions.hadoopDependenciesDir=$PROJECT_DIR$/distribution/target/hadoop-dependencies/ -Ddruid.extensions.directory=$PROJECT_DIR$/distribution/target/extensions/ -Ddruid.extensions.loadList=[ \"druid-s3-extensions \", \"druid-histogram \", \"mysql-metadata-storage \"] -Ddruid.historical.cache.useCache=false -Ddruid.historical.cache.populateCache=false -Ddruid.segmentCache.locations="[{ \"path \": \"/tmp/druid/indexCache \", \"maxSize \":10000000000}]" -Ddruid.zk.service.host=localhost -Ddruid.processing.numThreads=1 -Ddruid.server.http.numThreads=50 -Ddruid.serverview.type=batch -Ddruid.emitter=logging" />
2017-05-16 12:26:16 -04:00
< option name = "PROGRAM_PARAMETERS" value = "server historical" / >
< option name = "WORKING_DIRECTORY" value = "file://$PROJECT_DIR$" / >
< option name = "ALTERNATIVE_JRE_PATH_ENABLED" value = "false" / >
< option name = "ALTERNATIVE_JRE_PATH" value = "1.8" / >
< option name = "ENABLE_SWING_INSPECTOR" value = "false" / >
< option name = "ENV_VARIABLES" / >
< option name = "PASS_PARENT_ENVS" value = "true" / >
< module name = "druid-services" / >
< envs / >
< method / >
< / configuration >
< / component >
```
### Coordinator.xml
```xml
< component name = "ProjectRunConfigurationManager" >
< configuration default = "false" name = "Coordinator" type = "Application" factoryName = "Application" >
< extension name = "coverage" enabled = "false" merge = "false" sample_coverage = "true" runner = "idea" / >
2018-08-30 12:56:26 -04:00
< option name = "MAIN_CLASS_NAME" value = "org.apache.druid.cli.Main" / >
2019-01-02 03:44:02 -05:00
< option name = "VM_PARAMETERS" value = "-server -Duser.timezone=UTC -Dfile.encoding=UTF-8 -Xmx256M -Xmx256M -XX:+UseG1GC -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintAdaptiveSizePolicy -XX:+PrintReferenceGC -verbose:gc -XX:+PrintFlagsFinal -Djava.util.logging.manager=org.apache.logging.log4j.jul.LogManager -Dorg.jboss.logging.provider=slf4j -Ddruid.host=localhost -Ddruid.service=coordinator -Ddruid.extensions.directory=$PROJECT_DIR$/distribution/target/extensions/ -Ddruid.extensions.loadList=[ \"druid-s3-extensions \", \"druid-histogram \", \"mysql-metadata-storage \"] -Ddruid.zk.service.host=localhost -Ddruid.metadata.storage.type=mysql -Ddruid.metadata.storage.connector.connectURI="jdbc:mysql://localhost:3306/druid" -Ddruid.metadata.storage.connector.user=druid -Ddruid.metadata.storage.connector.password=diurd -Ddruid.serverview.type=batch -Ddruid.emitter=logging -Ddruid.coordinator.period=PT10S -Ddruid.coordinator.startDelay=PT5S" />
2017-05-16 12:26:16 -04:00
< option name = "PROGRAM_PARAMETERS" value = "server coordinator" / >
< option name = "WORKING_DIRECTORY" value = "file://$PROJECT_DIR$" / >
< option name = "ALTERNATIVE_JRE_PATH_ENABLED" value = "false" / >
< option name = "ALTERNATIVE_JRE_PATH" value = "1.8" / >
< option name = "ENABLE_SWING_INSPECTOR" value = "false" / >
< option name = "ENV_VARIABLES" / >
< option name = "PASS_PARENT_ENVS" value = "true" / >
< module name = "druid-services" / >
< envs / >
< method / >
< / configuration >
< / component >
```
2020-05-21 15:35:54 -04:00
## property files
You can also provide a property file for running or debugging the application through intellij.
For example, put a file named as `common.properties` under `.idea/conf` directory, then add `-Ddruid.properties.file=$PROJECT_DIR$/.idea/conf/common.properties` to `VM_PARAMETERS` in the App Def file.