Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/deepmancer/redisinsight-docker-autoconfig
Automates the configuration of Redis databases in RedisInsight using Docker. This setup simplifies the integration of multiple Redis instances for efficient management and monitoring.
https://github.com/deepmancer/redisinsight-docker-autoconfig
automation bash-scripting configuration docker docker-compose redis redis-database redisinsight script
Last synced: 2 months ago
JSON representation
Automates the configuration of Redis databases in RedisInsight using Docker. This setup simplifies the integration of multiple Redis instances for efficient management and monitoring.
- Host: GitHub
- URL: https://github.com/deepmancer/redisinsight-docker-autoconfig
- Owner: deepmancer
- License: apache-2.0
- Created: 2024-08-05T08:46:00.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-08-16T12:03:57.000Z (5 months ago)
- Last Synced: 2024-10-11T20:02:55.728Z (3 months ago)
- Topics: automation, bash-scripting, configuration, docker, docker-compose, redis, redis-database, redisinsight, script
- Language: Shell
- Homepage:
- Size: 15.6 KB
- Stars: 4
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# π RedisInsight Docker Automated Configuration
Welcome to the **RedisInsight Docker AutoConfig** repository! This repository includes a Docker Compose setup for RedisInsight, alongside a powerful Bash script that automates the configuration of multiple Redis databases within RedisInsight. Simplify your workflow and let the script handle the heavy lifting for you!
---
## β¨ Features
Hereβs what the script does for you:
1. **Network Configuration**: Automatically retrieves the gateway IP of your specified Docker network.
2. **Initial Setup**: Applies essential settings to RedisInsight, including EULA acceptance.
3. **Redis Integration**: Adds multiple Redis databases to RedisInsight in one go.## π¨ Docker Compose Setup
Use the following `docker-compose.yml` to set up your RedisInsight service:
```yaml
services:
redis_insight:
image: "redislabs/redisinsight:latest"
container_name: redisinsight
ports:
- "5540:5540"
volumes:
- redis_insight_data:/data
volumes:
redis_insight_data:
```---
## π Script Overview
The `add_datasources.sh` script automates adding Redis databases to RedisInsight via its API. Hereβs what it covers:
### 1. Configuration
The script starts by defining the API URL for RedisInsight and the Docker network name. It then retrieves the gateway IP for your specified network. If the network is not found, it defaults to `127.0.0.1`:
```bash
API_URL="http://localhost:5540/api"
NETWORK_NAME="backend-network"GATEWAY_IP=$(docker network inspect "$NETWORK_NAME" --format '{{range .IPAM.Config}}{{.Gateway}}{{end}}')
if [ -z "$GATEWAY_IP" ]; then
echo "Warning: Unable to retrieve gateway IP for network '$NETWORK_NAME'. Using 127.0.0.1 as the default."
GATEWAY_IP="127.0.0.1"
fiecho "Gateway IP for network '$NETWORK_NAME' is $GATEWAY_IP"
```### 2. Apply Initial Settings
The script applies essential settings to RedisInsight, such as accepting the EULA and disabling analytics:
```bash
SETTINGS_PAYLOAD='{
"agreements": {
"eula": true,
"analytics": false,
"notifications": false,
"encryption": false
}
}'curl -X GET "${API_URL}/settings" -H "Content-Type: application/json" -d "$SETTINGS_PAYLOAD" > /dev/null 2>&1
```### 3. Define and Add Redis Databases
The script iterates over a list of Redis instances, adding each one to RedisInsight:
```bash
# Redis instances configuration
REDIS_INSTANCES=(
"Gateway Redis|6490|gateway_password|gateway_redis"
"User Redis|6235|user_password|user_redis"
"Restaurant Redis|6236|restaurant_password|restaurant_redis"
"Location Redis|6300|location_password|location_redis"
"Order Redis|6301|order_password|order_redis"
)# Function to add a Redis database to RedisInsight
add_redis_database() {
local NAME=$1
local PORT=$2
local PASSWORD=$3
local DB_NAME=$4echo "Adding Redis database: $NAME..."
curl -s -X POST "${API_URL}/databases" -H "Content-Type: application/json" -d "{
"host": "${GATEWAY_IP}",
"port": ${PORT},
"password": "${PASSWORD}",
"name": "${DB_NAME}"
}" > /dev/nullif [ $? -eq 0 ]; then
echo "Successfully added Redis database: $NAME"
else
echo "Error: Failed to add Redis database: $NAME"
fi
}# Iterate over the Redis instances and add them to RedisInsight
for redis in "${REDIS_INSTANCES[@]}"; do
IFS='|' read -r REDIS_NAME REDIS_PORT REDIS_PASSWORD REDIS_DB_NAME <<< "$redis"
add_redis_database "$REDIS_NAME" "$REDIS_PORT" "$REDIS_PASSWORD" "$REDIS_DB_NAME"
doneecho "All Redis databases have been added successfully."
```---
## π How to Use
1. **Customize the Script**: Edit the configuration variables to match your RedisInsight setup and Docker network. Modify the `REDIS_INSTANCES` array to include your Redis databases.
2. **Run the Script**: Make the script executable and run it:
```bash
chmod +x add_datasources.sh
./add_datasources.sh
```3. **Verify the Results**: Log into RedisInsight and check that your databases have been added successfully.
![image](https://github.com/user-attachments/assets/f6276046-624e-4690-bc28-d0d5df9a1eac)
---
## π License
This project is licensed under the MIT License. See the [LICENSE](LICENSE) file for more details.