Keeper UI - ZooKeeper UI and HTTP Proxy
Keeper UI is a complete UI and an HTTP proxy server for Apache ZooKeeper. You can check out a deployed version of the frontend at https://zk.ankitsultana.com.
- Multi-Instance Support: Connect to multiple ZooKeeper clusters simultaneously
- RESTful HTTP Proxy: Complete CRUD operations for ZooKeeper nodes
- Node Statistics: Retrieve detailed ZooKeeper node metadata
- Ephemeral & Persistent Nodes: Support for both node types
- Configurable: YAML-based configuration for easy deployment
All endpoints are prefixed with /{instance} where instance is the configured ZooKeeper instance name.
- GET /{instance}/ls?path=/- List children of a node
- GET /{instance}/get?path=/- Get node data, statistics, and children
- POST /{instance}/create- Create a new node
- DELETE /{instance}/delete?path=/&version=-1- Delete a node
- POST /{instance}/set?path=/&version=-1- Update node data
- Java 11 or higher
- Maven 3.6+
- Access to a ZooKeeper cluster
mvn clean packageMake sure you have a ZK cluster running and configured in the application.yml file.
java -jar target/keeper-ui-1.0-SNAPSHOT.jarjava -jar target/keeper-ui-1.0-SNAPSHOT.jar /path/to/your/application.ymlThe HTTP Proxy server will start on port 12345 by default. Next, you can spin up the Keeper UI or simply use the one hosted at https://zk.ankitsultana.com/
Once your HTTP Proxy is up and able to connect to your Zookeeper instance (see Configuration section below), you can go to zk.ankitsultana.com to browse your Zookeeper instance's contents.
You can also run the frontend locally by using the submodule under the app folder. Simply run npm install and npm run dev.
Create an application.yml file to configure the server and ZooKeeper instances:
server:
  port: 12345
zookeeper:
  dev:
    host: localhost:9180
    session-timeout: 5000
  prod:
    host: prod-zk1:2181,prod-zk2:2181,prod-zk3:2181
    session-timeout: 10000
  local:
    host: localhost:2181
    session-timeout: 3000- server.port: HTTP server port (default: 12345)
Each ZooKeeper instance supports:
- host: ZooKeeper connection string (single host or comma-separated cluster)
- session-timeout: Session timeout in milliseconds
# List root children for 'dev' instance
curl "http://localhost:12345/dev/ls?path=/"
# Get node data for 'prod' instance
curl "http://localhost:12345/prod/get?path=/config"
# Create a new node
curl -X POST "http://localhost:12345/dev/create" \
  -H "Content-Type: application/json" \
  -d '{"path": "/test", "data": "hello world", "isEphemeral": false}'
# Delete a node
curl -X DELETE "http://localhost:12345/dev/delete?path=/test&version=-1"All API responses return JSON:
Success responses:
{
  "children": ["node1", "node2"],
  "data": "node content",
  "stat": {
    "czxid": 123,
    "mzxid": 456,
    "version": 1,
    ...
  }
}Error responses:
{
  "message": "Error description"
}src/main/java/com/ankitsultana/keeper/ui/
├── KeeperUIApplication.java    # Main Spring Boot application
├── ZookeeperFacade.java       # ZooKeeper client wrapper
├── ZookeeperFactory.java      # Multi-instance connection factory
└── AppConfig.java             # Configuration binding
- UI: Built with ❤️ by lovable.dev
- HTTP Proxy: Built with Claude AI Assistant
- Framework: Spring Boot + Apache ZooKeeper Client
This project is licensed under the MIT License - see the LICENSE file for details.
This is an experimental project created for educational and demonstration purposes.