Skip to content

Proxy and Caching

Lorenzo Mangani edited this page Oct 19, 2021 · 5 revisions

Clickhouse Proxy w/ Cache

When using cLoki with many users and dashboards, you might want to protect against the dogpile effect by caching and distributing queries or distribute your queries and inserts across multiple nodes.

⭐ chproxy provides a fast, transparent caching proxy for cLoki in front of a clickhouse server or server cluster.

Installation

wget -qO- https://github.com/Vertamedia/chproxy/releases/download/v1.14.0/chproxy-linux-amd64-v1.14.0.tar.gz | tar xvz - -C /tmp
mv /tmp/chproxy /usr/local/bin/chproxy
chmod +x /usr/local/bin/chproxy

Proxy Configuration

Create a configuration file for chproxy in /etc/chproxy.yml using your clickhouse settings:

server:
  http:
    listen_addr: ":8124"
    allowed_networks: ["127.0.0.0/24"]

users:
  - name: "default"
    password: "password"
    to_cluster: "default"
    to_user: "default"
    cache: "shortterm"

clusters:
  - name: "default"
    nodes: ["127.0.0.1:8123"]
    users:
      - name: "default"
        password: "password"

caches:
  - name: "shortterm"
    dir: "/tmp"
    max_size: 150Mb
    # Cached responses will expire in 130s.
    expire: 130s

Service Configuration

Create a service file in /etc/systemd/system/chproxy.service

[Unit]
Description=Clickhouse Proxy
After=network.target

[Service]
ExecStart=/usr/local/bin/chproxy -config=/etc/chproxy.yml
ExecStop=/bin/kill ${MAINPID}
Restart=on-failure
RestartSec=10s
Type=simple

[Install]
WantedBy=multi-user.target

Start Service

systemctl daemon-reload
systemctl start chproxy

cLoki Configuration

  • Reconfigure your cloki instance to use the proxy port (8124) instead of the native clickhouse port (8123)
  • Restart your cloki service
Clone this wiki locally