bpmct / jetbrains-indexer

Generate & package JetBrains shared indexes with a Docker container.
https://coder.com/blog/faster-jetbrains-ides-with-shared-indexes
MIT License
25 stars 12 forks source link
goland ide indexing intellij-idea jetbrains pycharm shared-indexes

jetbrains-indexer

Generate & package JetBrains shared indexes with a Docker container.

Shared indexes are often hosted on a CDN and used by IDEs to speed up loading (indexing) time for JetBrains IDEs (IntelliJ IDEA, PyCharm, GoLand, etc). Blog post: https://coder.com/blog/faster-jetbrains-ides-with-shared-indexes

Basic usage

  1. Generate indexes for your project

    cd your-project/
    
    docker run -it --rm \
        -v "$(pwd)":/var/project \
        -v "$HOME/indexes-out":/shared-index \
        -e INDEXES_CDN_URL=http://localhost:3000/project \
        bencdr/indexer:idea-2021.3
    
    # you may need to fix the file permissions for the generated indexes
    sudo chown -R $(id -u):$(id -g) $HOME/indexes-out
  2. Upload indexes to CDN (or test locally)

    # test with local Python server
    cd $HOME/indexes-out/
    python3 -m http.server 3000

    this URL must be the same as INDEXES_CDN_URL in step 1.

  3. Add intellij.yaml to your project if you don't have one

    sharedIndex:
      project:
        - url: http://localhost:3000/project
  4. Open your IDE and test (use File → Invalidate Caches to load indexes for the first time again)

IDE support

By default, this project indexes version 2021.3 of your IDE. Specify the IDE name by using the appropriate tag (e.g bencdr/indexer:[ide-name]-2021.3). You can verify with DockerHub.

If an IDE/version is not on DockerHub, we recommend you manually pulling and building the image yourself using these build arguments.

Docs and examples

⚠️ Many of these are a work in progress

Troubleshooting

See ./docs/troubleshooting.md


If you just want to generate raw shared indexes with Docker, you can use damintsew/idea-shared-index-dockerfile. This project is based on that.