Compare commits
9 Commits
81af16cedf
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
868b78f476 | ||
| 066033a4d6 | |||
| e4726a478e | |||
| 3668563736 | |||
| d750ad84a5 | |||
|
|
ae4e83dafe | ||
| fcbd2c5452 | |||
| 039531ce7b | |||
| 91fe69a0a2 |
@@ -1,19 +1,19 @@
|
||||
name: Zabbix APK Builder
|
||||
|
||||
on:
|
||||
# Trigger on pushes to main/test branch
|
||||
# Trigger on pushes to main/test branch into the zabbix-apk-builder directory
|
||||
push:
|
||||
branches: [ main, test ]
|
||||
paths: [ 'zabbix-apk-builder/**' ]
|
||||
|
||||
# Scheduled check for new versions (daily at 6 AM UTC)
|
||||
# Scheduled runs at 06:00 UTC daily
|
||||
schedule:
|
||||
- cron: '0 6 * * *'
|
||||
|
||||
jobs:
|
||||
check-version:
|
||||
runs-on: ubuntu-latest
|
||||
# Skip the execution if the commit message contains [ci skip]
|
||||
# Skip the execution if the commit author is the bot itself to prevent loops
|
||||
if: ${{ gitea.event.head_commit.author.name != 'Gitea Action' }}
|
||||
outputs:
|
||||
should_build: ${{ steps.version-check.outputs.should_build }}
|
||||
@@ -30,47 +30,28 @@ jobs:
|
||||
run: |
|
||||
set -euo pipefail
|
||||
|
||||
# Install jq for JSON parsing (remove sudo for container environment)
|
||||
apt-get update && apt-get install -y jq
|
||||
# Remove jq installation
|
||||
# apt-get update && apt-get install -y jq
|
||||
|
||||
# Detect trigger type
|
||||
if [[ "${{ gitea.event_name }}" == "push" ]]; then
|
||||
echo "is_push_trigger=true" >> "${GITHUB_OUTPUT}"
|
||||
echo "Triggered by push event - force build"
|
||||
else
|
||||
echo "is_push_trigger=false" >> "${GITHUB_OUTPUT}"
|
||||
echo "Triggered by schedule - check version"
|
||||
fi
|
||||
IS_PUSH="${{ gitea.event_name == 'push' }}"
|
||||
echo "is_push_trigger=${IS_PUSH}" >> "${GITHUB_OUTPUT}"
|
||||
|
||||
# Get current version from APKBUILD
|
||||
# Get versions
|
||||
CURRENT_VERSION=$(grep '^pkgver=' zabbix-apk-builder/APKBUILD | cut -d'=' -f2)
|
||||
echo "current_version=${CURRENT_VERSION}" >> "${GITHUB_OUTPUT}"
|
||||
echo "Current version: ${CURRENT_VERSION}"
|
||||
|
||||
# Get latest version from Zabbix API (stable releases only)
|
||||
LATEST_VERSION=$(curl -s "https://git.zabbix.com/rest/api/1.0/projects/ZBX/repos/zabbix/tags?limit=100" | \
|
||||
jq -r '.values[].displayId' | \
|
||||
grep -E '^[0-9]+\.[0-9]+\.[0-9]+$' | \
|
||||
grep -v 'rc\|beta\|alpha' | \
|
||||
sort -V | \
|
||||
tail -1)
|
||||
grep -o '"displayId":"[^"]*"' | cut -d'"' -f4 | \
|
||||
grep -E '^[0-9]+\.[0-9]+\.[0-9]+$' | grep -v 'rc\|beta\|alpha' | \
|
||||
sort -V | tail -1)
|
||||
|
||||
echo "current_version=${CURRENT_VERSION}" >> "${GITHUB_OUTPUT}"
|
||||
echo "latest_version=${LATEST_VERSION}" >> "${GITHUB_OUTPUT}"
|
||||
echo "Latest version: ${LATEST_VERSION}"
|
||||
|
||||
# Determine if we should build based on trigger type
|
||||
if [[ "${{ gitea.event_name }}" == "push" ]]; then
|
||||
# Push trigger: always build to test changes
|
||||
# Always build on push, build on schedule if versions differ
|
||||
if [[ "${IS_PUSH}" == "true" || "${CURRENT_VERSION}" != "${LATEST_VERSION}" ]]; then
|
||||
echo "should_build=true" >> "${GITHUB_OUTPUT}"
|
||||
echo "Build required: Push trigger detected"
|
||||
elif [[ "${CURRENT_VERSION}" != "${LATEST_VERSION}" ]]; then
|
||||
# Schedule trigger: only build if version changed
|
||||
echo "should_build=true" >> "${GITHUB_OUTPUT}"
|
||||
echo "Build required: New version ${LATEST_VERSION} available"
|
||||
else
|
||||
# Schedule trigger: no new version
|
||||
echo "should_build=false" >> "${GITHUB_OUTPUT}"
|
||||
echo "No build required: Version ${CURRENT_VERSION} is current"
|
||||
fi
|
||||
|
||||
update-version:
|
||||
@@ -125,18 +106,6 @@ jobs:
|
||||
token: ${{ secrets.ACCESS_TOKEN }}
|
||||
ref: ${{ gitea.ref }}
|
||||
|
||||
- name: Pull latest changes if version was updated
|
||||
run: |
|
||||
set -euo pipefail
|
||||
|
||||
# Pull any version updates that may have been committed
|
||||
if [[ "${{ needs.check-version.outputs.is_push_trigger }}" == "false" ]]; then
|
||||
echo "Scheduled build - pulling latest changes"
|
||||
git pull origin "${GITEA_REF_NAME:-main}" || true
|
||||
else
|
||||
echo "Push build - using current ref"
|
||||
fi
|
||||
|
||||
- name: Verify build environment
|
||||
run: |
|
||||
set -euo pipefail
|
||||
@@ -151,6 +120,8 @@ jobs:
|
||||
uses: docker/setup-buildx-action@v3
|
||||
|
||||
- name: Build Zabbix packages
|
||||
env:
|
||||
CI_RUN_ID: ${{ gitea.run_id }}
|
||||
run: |
|
||||
set -euo pipefail
|
||||
|
||||
@@ -162,42 +133,19 @@ jobs:
|
||||
run: |
|
||||
set -euo pipefail
|
||||
|
||||
echo "=== Verifying package build ==="
|
||||
cd zabbix-apk-builder
|
||||
|
||||
if [[ ! -d "packages" ]]; then
|
||||
echo "❌ ERROR: packages directory does not exist"
|
||||
echo "Current directory contents:"
|
||||
ls -la .
|
||||
# Verify packages exist somewhere
|
||||
PACKAGE_COUNT=$(find packages -name "*.apk" | wc -l)
|
||||
|
||||
if [[ $PACKAGE_COUNT -eq 0 ]]; then
|
||||
echo "ERROR: No packages found"
|
||||
find packages -type f 2>/dev/null || echo "packages directory is empty"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Check for packages in the standard Alpine directory structure
|
||||
PACKAGE_DIRS=(
|
||||
"packages/*.apk"
|
||||
"packages/builder/x86_64/*.apk"
|
||||
"packages/x86_64/*.apk"
|
||||
)
|
||||
|
||||
FOUND_PACKAGES=false
|
||||
for pattern in "${PACKAGE_DIRS[@]}"; do
|
||||
if ls $pattern >/dev/null 2>&1; then
|
||||
FOUND_PACKAGES=true
|
||||
echo "✅ Packages found in: $(dirname $pattern)"
|
||||
ls -la $pattern
|
||||
break
|
||||
fi
|
||||
done
|
||||
|
||||
if [[ "$FOUND_PACKAGES" == "false" ]]; then
|
||||
echo "❌ ERROR: No packages found in any expected location"
|
||||
echo "Directory structure:"
|
||||
find packages -type f -name "*.apk" 2>/dev/null || echo "No .apk files found"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "=== Package details ==="
|
||||
find packages -name "*.apk" -exec bash -c 'echo "Package: $(basename "$1")"; echo "Size: $(du -h "$1" | cut -f1)"; echo "---"' _ {} \;
|
||||
echo "Found $PACKAGE_COUNT packages:"
|
||||
find packages -name "*.apk" -exec ls -lh {} \;
|
||||
|
||||
- name: Upload packages as artifacts
|
||||
uses: actions/upload-artifact@v3
|
||||
@@ -223,60 +171,33 @@ jobs:
|
||||
run: |
|
||||
set -euo pipefail
|
||||
|
||||
echo "=== Testing package installation ==="
|
||||
# Find packages
|
||||
AGENT_PKG=$(find packages -name "zabbix-agent-*.apk" | head -1)
|
||||
PROXY_PKG=$(find packages -name "zabbix-proxy-*.apk" | head -1)
|
||||
|
||||
# Debug: Show what was actually downloaded
|
||||
echo "Downloaded packages:"
|
||||
ls -la packages/
|
||||
echo "Builder directory:"
|
||||
ls -la packages/builder/ 2>/dev/null || echo "No builder directory"
|
||||
echo "x86_64 directory:"
|
||||
ls -la packages/builder/x86_64/ 2>/dev/null || echo "No x86_64 directory"
|
||||
echo "All .apk files:"
|
||||
find packages/ -name "*.apk" -type f 2>/dev/null || echo "No .apk files found"
|
||||
# Test function
|
||||
test_package() {
|
||||
local pkg="$1"
|
||||
local binary="$2"
|
||||
|
||||
# Use known paths - packages are uploaded from zabbix-apk-builder/packages/**/*.apk
|
||||
# and downloaded to packages/, so they should be in packages/builder/x86_64/
|
||||
PACKAGE_DIR="packages/builder/x86_64"
|
||||
AGENT_PKG="$PACKAGE_DIR/zabbix-agent-7.4.2-r0.apk"
|
||||
PROXY_PKG="$PACKAGE_DIR/zabbix-proxy-7.4.2-r0.apk"
|
||||
|
||||
# Test agent package
|
||||
if [[ -f "$AGENT_PKG" ]]; then
|
||||
echo "Testing agent package at: $AGENT_PKG"
|
||||
echo "File size: $(du -h "$AGENT_PKG")"
|
||||
|
||||
# Create container, copy package, install and test
|
||||
if [[ -f "$pkg" ]]; then
|
||||
echo "Testing $(basename "$pkg")..."
|
||||
CONTAINER_ID=$(docker run -d alpine:latest sleep 30)
|
||||
docker cp "$AGENT_PKG" "$CONTAINER_ID:/$(basename "$AGENT_PKG")"
|
||||
docker exec "$CONTAINER_ID" sh -c "
|
||||
ls -la /$(basename "$AGENT_PKG")
|
||||
apk add --allow-untrusted /$(basename "$AGENT_PKG")
|
||||
which zabbix_agentd
|
||||
zabbix_agentd --version
|
||||
" && echo "✅ Agent test passed" || echo "❌ Agent test failed"
|
||||
docker cp "$pkg" "$CONTAINER_ID:/$(basename "$pkg")"
|
||||
if docker exec "$CONTAINER_ID" sh -c "
|
||||
apk add --allow-untrusted /$(basename "$pkg") >/dev/null 2>&1
|
||||
which $binary >/dev/null 2>&1
|
||||
$binary --version >/dev/null 2>&1
|
||||
"; then
|
||||
echo "SUCCESS: $(basename "$pkg") test passed"
|
||||
else
|
||||
echo "FAIL: $(basename "$pkg") test failed"
|
||||
fi
|
||||
docker rm -f "$CONTAINER_ID" >/dev/null
|
||||
else
|
||||
echo "⚠️ Agent package not found at $AGENT_PKG"
|
||||
echo "ERROR: Package not found: $pkg"
|
||||
fi
|
||||
}
|
||||
|
||||
# Test proxy package
|
||||
if [[ -f "$PROXY_PKG" ]]; then
|
||||
echo "Testing proxy package at: $PROXY_PKG"
|
||||
echo "File size: $(du -h "$PROXY_PKG")"
|
||||
|
||||
# Create container, copy package, install and test
|
||||
CONTAINER_ID=$(docker run -d alpine:latest sleep 30)
|
||||
docker cp "$PROXY_PKG" "$CONTAINER_ID:/$(basename "$PROXY_PKG")"
|
||||
docker exec "$CONTAINER_ID" sh -c "
|
||||
ls -la /$(basename "$PROXY_PKG")
|
||||
apk add --allow-untrusted /$(basename "$PROXY_PKG")
|
||||
which zabbix_proxy
|
||||
zabbix_proxy --version
|
||||
" && echo "✅ Proxy test passed" || echo "❌ Proxy test failed"
|
||||
docker rm -f "$CONTAINER_ID" >/dev/null
|
||||
else
|
||||
echo "⚠️ Proxy package not found at $PROXY_PKG"
|
||||
fi
|
||||
|
||||
echo "✅ Package deployment test completed"
|
||||
test_package "$AGENT_PKG" "zabbix_agentd"
|
||||
test_package "$PROXY_PKG" "zabbix_proxy"
|
||||
@@ -1,7 +1,7 @@
|
||||
# Contributor: Maksym Buz <maksym.buz@zabbix.com>
|
||||
# Maintainer: Maksym Buz <maksym.buz@zabbix.com>
|
||||
pkgname=zabbix
|
||||
pkgver=7.4.2
|
||||
pkgver=7.4.4
|
||||
pkgrel=0
|
||||
pkgdesc="Enterprise-class open source distributed monitoring solution"
|
||||
url="https://www.zabbix.com/"
|
||||
@@ -139,7 +139,7 @@ proxy() {
|
||||
install -dm755 "$subpkgdir"/var/run/zabbix
|
||||
}
|
||||
# --- TEST ---
|
||||
sha512sums="
|
||||
sha512sums="SKIP"
|
||||
SKIP
|
||||
SKIP
|
||||
SKIP
|
||||
|
||||
@@ -4,8 +4,7 @@ Automated Alpine Linux package builder for Zabbix Agent and Proxy with CI/CD pip
|
||||
|
||||
## Features
|
||||
|
||||
- 🔄 **Automatic Version Detection**: Monitors Zabbix releases using official Bitbucket API
|
||||
- 🏗️ **Docker-based Building**: Consistent, reproducible builds in isolated environment
|
||||
- 🔄 **Automatic Version Detection**: Monitors Zabbix releases using Bitbucket API
|
||||
- 🚀 **CI/CD Pipeline**: Full automation from version detection to package deployment
|
||||
- 📦 **Multi-package Support**: Builds agent and proxy packages
|
||||
- 🧪 **Automated Testing**: Tests package installation in Alpine containers
|
||||
@@ -13,34 +12,24 @@ Automated Alpine Linux package builder for Zabbix Agent and Proxy with CI/CD pip
|
||||
|
||||
## Quick Start
|
||||
|
||||
### 1. Repository Setup
|
||||
### Prerequisites
|
||||
|
||||
- Docker installed
|
||||
- Gitea repository with Actions enabled
|
||||
|
||||
### Manual Build
|
||||
|
||||
```bash
|
||||
# Clone this repository
|
||||
git clone https://git.mbuz.uk/mbuz/Zabbix.git
|
||||
# Clone the repository
|
||||
git clone <your-gitea-repo>
|
||||
cd zabbix-apk-builder
|
||||
|
||||
# Make build script executable
|
||||
chmod +x build.sh
|
||||
```
|
||||
|
||||
### 2. Manual Build
|
||||
|
||||
```bash
|
||||
# Build packages locally
|
||||
chmod +x build.sh
|
||||
./build.sh
|
||||
|
||||
# Packages will be in ./packages/
|
||||
ls -la packages/
|
||||
```
|
||||
|
||||
### 3. CI/CD Setup
|
||||
|
||||
```bash
|
||||
# Run the setup script
|
||||
./setup-cicd.sh
|
||||
|
||||
# Follow the prompts to configure GitHub secrets
|
||||
# Check built packages
|
||||
ls -la packages/builder/x86_64/
|
||||
```
|
||||
|
||||
## Package Information
|
||||
@@ -51,19 +40,12 @@ ls -la packages/
|
||||
2. **zabbix-proxy** - Zabbix Proxy
|
||||
3. **zabbix** - Meta package
|
||||
|
||||
### Current Version
|
||||
|
||||
- **Zabbix Version**: 7.4.2
|
||||
- **Alpine Base**: latest
|
||||
- **Architecture**: all
|
||||
|
||||
## CI/CD Pipeline
|
||||
|
||||
### Automatic Triggers
|
||||
|
||||
- **Daily**: Checks for new Zabbix versions at 6 AM UTC
|
||||
- **Push**: Builds when code changes in main/test branches
|
||||
- **Manual**: Force builds via Gitea Actions
|
||||
|
||||
### Version Detection
|
||||
|
||||
@@ -91,48 +73,22 @@ GITEA_SSH_KEY # SSH private key for Gitea access
|
||||
### File Structure
|
||||
|
||||
```
|
||||
.
|
||||
└── zabbix-git
|
||||
└── zabbix-apk-builder
|
||||
├── .gitea/workflows # Workflows for Gitea actions
|
||||
├── .gitignore # Ignore files
|
||||
├── APKBUILD # APKBUILD file for Zabbix
|
||||
├── Dockerfile # Dockerfile for building packages
|
||||
├── README.md # Project description
|
||||
├── build.sh # Script for manual builds
|
||||
├── packages/ # Directory for built packages
|
||||
├── zabbix-agent.* # Agent configuration files
|
||||
└── zabbix-proxy.* # Proxy configuration files
|
||||
```
|
||||
|
||||
## Usage
|
||||
|
||||
### Install Packages
|
||||
|
||||
```bash
|
||||
# Add repository
|
||||
echo "http://gitea-repo/mbuz/Zabbix/raw/branch/main/alpine/v3.18/main" >> /etc/apk/repositories
|
||||
|
||||
# Update and install
|
||||
apk update
|
||||
apk add zabbix-agent
|
||||
|
||||
# Enable and start
|
||||
rc-update add zabbix-agent default
|
||||
rc-service zabbix-agent start
|
||||
```
|
||||
|
||||
### Configuration
|
||||
|
||||
```bash
|
||||
# Configure agent
|
||||
vim /etc/zabbix/zabbix_agentd.conf
|
||||
|
||||
# Set server IP
|
||||
Server=your.zabbix.server
|
||||
|
||||
# Restart service
|
||||
rc-service zabbix-agent restart
|
||||
zabbix-git/
|
||||
└── zabbix-apk-builder/
|
||||
├── .gitea/
|
||||
│ └── workflows/
|
||||
│ └── build.yaml # Main CI/CD pipeline
|
||||
├── APKBUILD # Alpine package definition
|
||||
├── Dockerfile # Build environment container
|
||||
├── README.md # This file
|
||||
├── build.sh # Local build script
|
||||
├── packages/ # Generated packages (gitignored)
|
||||
├── zabbix-agent.confd # Agent configuration
|
||||
├── zabbix-agent.initd # Agent init script
|
||||
├── zabbix-agent.pre-install # Agent pre-install script
|
||||
├── zabbix-proxy.confd # Proxy configuration
|
||||
├── zabbix-proxy.initd # Proxy init script
|
||||
└── zabbix-proxy.pre-install # Proxy pre-install script
|
||||
```
|
||||
|
||||
## Development
|
||||
@@ -154,28 +110,16 @@ docker run --rm -it \
|
||||
|
||||
### Branch Strategy
|
||||
|
||||
- **main**: Production releases, auto-deployed
|
||||
- **test**: Testing and validation, no auto-deploy
|
||||
- **main**: Production releases, merge only
|
||||
- **test**: Testing and validation
|
||||
|
||||
### Making Changes
|
||||
|
||||
1. Create feature branch from `test`
|
||||
1. Create feature branch from `main`
|
||||
2. Test changes thoroughly
|
||||
3. Merge to `test` for CI validation
|
||||
4. Merge to `main` for production release
|
||||
3. Validate CI
|
||||
4. Merge to `main`
|
||||
|
||||
## Troubleshooting
|
||||
|
||||
### Build Issues
|
||||
|
||||
```bash
|
||||
# Check build logs
|
||||
docker logs $(docker ps -l -q)
|
||||
|
||||
# Manual build debug
|
||||
docker run -it --rm -v $(pwd):/build alpine:3.18 sh
|
||||
cd /build && ./build.sh
|
||||
```
|
||||
|
||||
### Version Detection
|
||||
|
||||
|
||||
68
zabbix-tests/host-cleanup.py
Executable file
68
zabbix-tests/host-cleanup.py
Executable file
@@ -0,0 +1,68 @@
|
||||
#!/usr/bin/env python3
|
||||
import requests
|
||||
import json
|
||||
import time
|
||||
|
||||
# === CONFIGURATION ===
|
||||
ZABBIX_URL = "http://10.0.0.101:8887/api_jsonrpc.php"
|
||||
ZABBIX_TOKEN = "c785634354e760a6843055ba4581bc7b6cd6eb2ec75f7c2a79f251c1719933f7"
|
||||
GROUP_ID = "19"
|
||||
BATCH_SIZE = 100
|
||||
HOST_PATTERN = "dummy-host-"
|
||||
|
||||
HEADERS = {
|
||||
"Content-Type": "application/json-rpc",
|
||||
"Authorization": f"Bearer {ZABBIX_TOKEN}"
|
||||
}
|
||||
|
||||
def zbx_request(method, params):
|
||||
payload = {
|
||||
"jsonrpc": "2.0",
|
||||
"method": method,
|
||||
"params": params,
|
||||
"id": int(time.time())
|
||||
}
|
||||
r = requests.post(ZABBIX_URL, headers=HEADERS, data=json.dumps(payload))
|
||||
r.raise_for_status()
|
||||
resp = r.json()
|
||||
if "error" in resp:
|
||||
raise Exception(f"API error: {resp['error']}")
|
||||
return resp
|
||||
|
||||
def cleanup_hosts():
|
||||
# Get all hosts in the group
|
||||
resp = zbx_request("host.get", {
|
||||
"groupids": [GROUP_ID],
|
||||
"output": ["hostid", "host"]
|
||||
})
|
||||
|
||||
# Filter hosts that contain the dummy pattern
|
||||
hosts = [h for h in resp.get("result", []) if HOST_PATTERN in h["host"]]
|
||||
|
||||
if not hosts:
|
||||
print("No dummy hosts found")
|
||||
return
|
||||
|
||||
print(f"Deleting {len(hosts)} hosts")
|
||||
|
||||
# Delete in batches
|
||||
host_ids = [h["hostid"] for h in hosts]
|
||||
total_deleted = 0
|
||||
|
||||
for i in range(0, len(host_ids), BATCH_SIZE):
|
||||
batch = host_ids[i:i + BATCH_SIZE]
|
||||
try:
|
||||
resp = zbx_request("host.delete", batch)
|
||||
deleted = len(resp.get("result", {}).get("hostids", []))
|
||||
total_deleted += deleted
|
||||
print(f"Deleted batch {i//BATCH_SIZE + 1}: {deleted} hosts")
|
||||
except Exception as e:
|
||||
print(f"Error in batch {i//BATCH_SIZE + 1}: {e}")
|
||||
|
||||
if i + BATCH_SIZE < len(host_ids):
|
||||
time.sleep(0.5)
|
||||
|
||||
print(f"Total deleted: {total_deleted}")
|
||||
|
||||
if __name__ == "__main__":
|
||||
cleanup_hosts()
|
||||
62
zabbix-tests/host-creator.py
Executable file
62
zabbix-tests/host-creator.py
Executable file
@@ -0,0 +1,62 @@
|
||||
#!/usr/bin/env python3
|
||||
import requests
|
||||
import json
|
||||
import time
|
||||
|
||||
# === CONFIGURATION ===
|
||||
ZABBIX_URL = "http://10.0.0.101:8887/api_jsonrpc.php"
|
||||
ZABBIX_TOKEN = "c785634354e760a6843055ba4581bc7b6cd6eb2ec75f7c2a79f251c1719933f7"
|
||||
PROXY_GROUP_ID = "1" # your proxy group ID
|
||||
GROUP_ID = "19" # host group for these hosts
|
||||
NUM_HOSTS = 1000 # number of hosts to create
|
||||
BATCH_SIZE = 100 # how many to create per call
|
||||
|
||||
HEADERS = {
|
||||
"Content-Type": "application/json-rpc",
|
||||
"Authorization": f"Bearer {ZABBIX_TOKEN}"
|
||||
}
|
||||
|
||||
def zbx_request(method, params):
|
||||
"""Send Zabbix API request using Bearer token authentication."""
|
||||
payload = {
|
||||
"jsonrpc": "2.0",
|
||||
"method": method,
|
||||
"params": params,
|
||||
"id": int(time.time())
|
||||
}
|
||||
r = requests.post(ZABBIX_URL, headers=HEADERS, data=json.dumps(payload))
|
||||
r.raise_for_status()
|
||||
resp = r.json()
|
||||
if "error" in resp:
|
||||
raise Exception(f"Zabbix API error: {resp['error']}")
|
||||
return resp
|
||||
|
||||
def create_hosts():
|
||||
hosts = []
|
||||
for i in range(1, NUM_HOSTS + 1):
|
||||
host_name = f"dummy-host-{i:04d}"
|
||||
host = {
|
||||
"host": host_name,
|
||||
"groups": [{"groupid": GROUP_ID}],
|
||||
"templates": [{"templateid": "10048"}], # assign Proxy Health template
|
||||
"monitored_by": 2, # 2 = proxy group
|
||||
"proxy_groupid": PROXY_GROUP_ID # your proxy group ID
|
||||
}
|
||||
hosts.append(host)
|
||||
|
||||
for i in range(0, len(hosts), BATCH_SIZE):
|
||||
batch = hosts[i:i + BATCH_SIZE]
|
||||
print(f"Creating hosts {i+1}-{i+len(batch)}...")
|
||||
try:
|
||||
resp = zbx_request("host.create", batch)
|
||||
created = len(resp.get("result", {}).get("hostids", []))
|
||||
print(f"Created {created} hosts.")
|
||||
except Exception as e:
|
||||
print(f"Error in batch {i+1}-{i+len(batch)}: {e}")
|
||||
time.sleep(1)
|
||||
|
||||
if __name__ == "__main__":
|
||||
try:
|
||||
create_hosts()
|
||||
except Exception as e:
|
||||
print(f"Fatal error: {e}")
|
||||
28
zabbix-tests/server-docker/.env
Normal file
28
zabbix-tests/server-docker/.env
Normal file
@@ -0,0 +1,28 @@
|
||||
# Database Configuration
|
||||
MYSQL_DATABASE=zabbix
|
||||
MYSQL_USER=zabbix
|
||||
MYSQL_PASSWORD=strong-password
|
||||
MYSQL_ROOT_PASSWORD=very-strong-password
|
||||
|
||||
# Image Versions (uncomment to override defaults)
|
||||
ZABBIX_VERSION=latest
|
||||
# MYSQL_VERSION=8.4.0-oraclelinux8 # Keep oraclelinux variant for architecture compatibility
|
||||
|
||||
# Port Configuration
|
||||
ZABBIX_SERVER_PORT=10051
|
||||
ZABBIX_WEB_PORT=8887
|
||||
|
||||
# Server Settings
|
||||
PHP_TIMEZONE=Europe/Warsaw
|
||||
ZBX_STARTSNMPTRAPPER=1
|
||||
ZBX_SNMPTRAPPERFILE=/tmp/traps.log
|
||||
ZBX_CACHESIZE=128M
|
||||
ZBX_VALUECACHESIZE=64M
|
||||
ZBX_TRENDCACHESIZE=32M
|
||||
|
||||
# Common Proxy Settings (applied to all proxies)
|
||||
PROXY_CACHE_SIZE=128M
|
||||
PROXY_HISTORY_CACHE_SIZE=32M
|
||||
PROXY_HISTORY_INDEX_CACHE_SIZE=16M
|
||||
PROXY_BUFFER_MODE=hybrid
|
||||
PROXY_MEMORY_BUFFER_SIZE=64M
|
||||
224
zabbix-tests/server-docker/docker-compose.yaml
Normal file
224
zabbix-tests/server-docker/docker-compose.yaml
Normal file
@@ -0,0 +1,224 @@
|
||||
### This will create a Zabbix server with six active proxies and a MySQL database.
|
||||
### You need to configure proxies in Zabbix frontend after deployment.
|
||||
### Adjust .env file for customization.
|
||||
|
||||
services:
|
||||
mysql-server:
|
||||
image: mysql:${MYSQL_VERSION:-8.4.0-oraclelinux8}
|
||||
container_name: zabbix-mysql-server
|
||||
command:
|
||||
- 'mysqld'
|
||||
- '--character-set-server=utf8mb4'
|
||||
- '--collation-server=utf8mb4_bin'
|
||||
- '--log-bin-trust-function-creators=1'
|
||||
environment:
|
||||
- MYSQL_DATABASE=${MYSQL_DATABASE}
|
||||
- MYSQL_USER=${MYSQL_USER}
|
||||
- MYSQL_PASSWORD=${MYSQL_PASSWORD}
|
||||
- MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}
|
||||
volumes:
|
||||
- ./zabbix/mysql:/var/lib/mysql
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- zabbix-net
|
||||
|
||||
zabbix-server:
|
||||
image: zabbix/zabbix-server-mysql:${ZABBIX_VERSION:-latest}
|
||||
container_name: zabbix-server
|
||||
depends_on:
|
||||
- mysql-server
|
||||
ports:
|
||||
- "${ZABBIX_SERVER_PORT}:10051"
|
||||
environment:
|
||||
- DB_SERVER_HOST=mysql-server
|
||||
- MYSQL_DATABASE=${MYSQL_DATABASE}
|
||||
- MYSQL_USER=${MYSQL_USER}
|
||||
- MYSQL_PASSWORD=${MYSQL_PASSWORD}
|
||||
- ZBX_STARTSNMPTRAPPER=${ZBX_STARTSNMPTRAPPER}
|
||||
- ZBX_SNMPTRAPPERFILE=${ZBX_SNMPTRAPPERFILE}
|
||||
- ZBX_CACHESIZE=${ZBX_CACHESIZE}
|
||||
- ZBX_VALUECACHESIZE=${ZBX_VALUECACHESIZE}
|
||||
- ZBX_TRENDCACHESIZE=${ZBX_TRENDCACHESIZE}
|
||||
volumes:
|
||||
- ./zabbix/alertscripts:/usr/lib/zabbix/alertscripts
|
||||
- ./zabbix/externalscripts:/usr/lib/zabbix/externalscripts
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- zabbix-net
|
||||
|
||||
zabbix-web:
|
||||
image: zabbix/zabbix-web-nginx-mysql:${ZABBIX_VERSION:-latest}
|
||||
container_name: zabbix-web
|
||||
depends_on:
|
||||
- mysql-server
|
||||
- zabbix-server
|
||||
ports:
|
||||
- "${ZABBIX_WEB_PORT}:8080"
|
||||
environment:
|
||||
- DB_SERVER_HOST=mysql-server
|
||||
- MYSQL_DATABASE=${MYSQL_DATABASE}
|
||||
- MYSQL_USER=${MYSQL_USER}
|
||||
- MYSQL_PASSWORD=${MYSQL_PASSWORD}
|
||||
- ZBX_SERVER_HOST=zabbix-server
|
||||
- PHP_TZ=${PHP_TIMEZONE}
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- zabbix-net
|
||||
|
||||
zabbix-proxy-active-01:
|
||||
image: zabbix/zabbix-proxy-sqlite3:${ZABBIX_VERSION:-latest}
|
||||
container_name: zabbix-proxy-active-01
|
||||
depends_on:
|
||||
- zabbix-server
|
||||
ports:
|
||||
- "10101:10051"
|
||||
environment:
|
||||
- ZBX_HOSTNAME=zabbix-proxy-active-01
|
||||
- ZBX_SERVER_HOST=zabbix-server
|
||||
- ZBX_PROXYMODE=0
|
||||
- ZBX_CACHESIZE=${PROXY_CACHE_SIZE}
|
||||
- ZBX_HISTORYCACHESIZE=${PROXY_HISTORY_CACHE_SIZE}
|
||||
- ZBX_HISTORYINDEXCACHESIZE=${PROXY_HISTORY_INDEX_CACHE_SIZE}
|
||||
- ZBX_PROXYBUFFERMODE=${PROXY_BUFFER_MODE}
|
||||
- ZBX_PROXYMEMORYBUFFERSIZE=${PROXY_MEMORY_BUFFER_SIZE}
|
||||
volumes:
|
||||
- ./zabbix/proxy-01:/var/lib/zabbix/db_data:rw
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- zabbix-net
|
||||
|
||||
zabbix-proxy-active-02:
|
||||
image: zabbix/zabbix-proxy-sqlite3:${ZABBIX_VERSION:-latest}
|
||||
container_name: zabbix-proxy-active-02
|
||||
depends_on:
|
||||
- zabbix-server
|
||||
ports:
|
||||
- "10102:10051"
|
||||
environment:
|
||||
- ZBX_HOSTNAME=zabbix-proxy-active-02
|
||||
- ZBX_SERVER_HOST=zabbix-server
|
||||
- ZBX_PROXYMODE=0
|
||||
- ZBX_CACHESIZE=${PROXY_CACHE_SIZE}
|
||||
- ZBX_HISTORYCACHESIZE=${PROXY_HISTORY_CACHE_SIZE}
|
||||
- ZBX_HISTORYINDEXCACHESIZE=${PROXY_HISTORY_INDEX_CACHE_SIZE}
|
||||
- ZBX_PROXYBUFFERMODE=${PROXY_BUFFER_MODE}
|
||||
- ZBX_PROXYMEMORYBUFFERSIZE=${PROXY_MEMORY_BUFFER_SIZE}
|
||||
volumes:
|
||||
- ./zabbix/proxy-02:/var/lib/zabbix/db_data:rw
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- zabbix-net
|
||||
|
||||
zabbix-proxy-active-03:
|
||||
image: zabbix/zabbix-proxy-sqlite3:${ZABBIX_VERSION:-latest}
|
||||
container_name: zabbix-proxy-active-03
|
||||
depends_on:
|
||||
- zabbix-server
|
||||
ports:
|
||||
- "10103:10051"
|
||||
environment:
|
||||
- ZBX_HOSTNAME=zabbix-proxy-active-03
|
||||
- ZBX_SERVER_HOST=zabbix-server
|
||||
- ZBX_PROXYMODE=0
|
||||
- ZBX_CACHESIZE=${PROXY_CACHE_SIZE}
|
||||
- ZBX_HISTORYCACHESIZE=${PROXY_HISTORY_CACHE_SIZE}
|
||||
- ZBX_HISTORYINDEXCACHESIZE=${PROXY_HISTORY_INDEX_CACHE_SIZE}
|
||||
- ZBX_PROXYBUFFERMODE=${PROXY_BUFFER_MODE}
|
||||
- ZBX_PROXYMEMORYBUFFERSIZE=${PROXY_MEMORY_BUFFER_SIZE}
|
||||
volumes:
|
||||
- ./zabbix/proxy-03:/var/lib/zabbix/db_data:rw
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- zabbix-net
|
||||
|
||||
zabbix-proxy-active-04:
|
||||
image: zabbix/zabbix-proxy-sqlite3:${ZABBIX_VERSION:-latest}
|
||||
container_name: zabbix-proxy-active-04
|
||||
depends_on:
|
||||
- zabbix-server
|
||||
ports:
|
||||
- "10104:10051"
|
||||
environment:
|
||||
- ZBX_HOSTNAME=zabbix-proxy-active-04
|
||||
- ZBX_SERVER_HOST=zabbix-server
|
||||
- ZBX_PROXYMODE=0
|
||||
- ZBX_CACHESIZE=${PROXY_CACHE_SIZE}
|
||||
- ZBX_HISTORYCACHESIZE=${PROXY_HISTORY_CACHE_SIZE}
|
||||
- ZBX_HISTORYINDEXCACHESIZE=${PROXY_HISTORY_INDEX_CACHE_SIZE}
|
||||
- ZBX_PROXYBUFFERMODE=${PROXY_BUFFER_MODE}
|
||||
- ZBX_PROXYMEMORYBUFFERSIZE=${PROXY_MEMORY_BUFFER_SIZE}
|
||||
volumes:
|
||||
- ./zabbix/proxy-04:/var/lib/zabbix/db_data:rw
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- zabbix-net
|
||||
|
||||
zabbix-proxy-active-05:
|
||||
image: zabbix/zabbix-proxy-sqlite3:${ZABBIX_VERSION:-latest}
|
||||
container_name: zabbix-proxy-active-05
|
||||
depends_on:
|
||||
- zabbix-server
|
||||
ports:
|
||||
- "10105:10051"
|
||||
environment:
|
||||
- ZBX_HOSTNAME=zabbix-proxy-active-05
|
||||
- ZBX_SERVER_HOST=zabbix-server
|
||||
- ZBX_PROXYMODE=0
|
||||
- ZBX_CACHESIZE=${PROXY_CACHE_SIZE}
|
||||
- ZBX_HISTORYCACHESIZE=${PROXY_HISTORY_CACHE_SIZE}
|
||||
- ZBX_HISTORYINDEXCACHESIZE=${PROXY_HISTORY_INDEX_CACHE_SIZE}
|
||||
- ZBX_PROXYBUFFERMODE=${PROXY_BUFFER_MODE}
|
||||
- ZBX_PROXYMEMORYBUFFERSIZE=${PROXY_MEMORY_BUFFER_SIZE}
|
||||
volumes:
|
||||
- ./zabbix/proxy-05:/var/lib/zabbix/db_data:rw
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- zabbix-net
|
||||
|
||||
zabbix-proxy-active-06:
|
||||
image: zabbix/zabbix-proxy-sqlite3:${ZABBIX_VERSION:-latest}
|
||||
container_name: zabbix-proxy-active-06
|
||||
depends_on:
|
||||
- zabbix-server
|
||||
ports:
|
||||
- "10106:10051"
|
||||
environment:
|
||||
- ZBX_HOSTNAME=zabbix-proxy-active-06
|
||||
- ZBX_SERVER_HOST=zabbix-server
|
||||
- ZBX_PROXYMODE=0
|
||||
- ZBX_CACHESIZE=${PROXY_CACHE_SIZE}
|
||||
- ZBX_HISTORYCACHESIZE=${PROXY_HISTORY_CACHE_SIZE}
|
||||
- ZBX_HISTORYINDEXCACHESIZE=${PROXY_HISTORY_INDEX_CACHE_SIZE}
|
||||
- ZBX_PROXYBUFFERMODE=${PROXY_BUFFER_MODE}
|
||||
- ZBX_PROXYMEMORYBUFFERSIZE=${PROXY_MEMORY_BUFFER_SIZE}
|
||||
volumes:
|
||||
- ./zabbix/proxy-06:/var/lib/zabbix/db_data:rw
|
||||
restart: unless-stopped
|
||||
networks:
|
||||
- zabbix-net
|
||||
|
||||
# zabbix-proxy-passive-03:
|
||||
# image: zabbix/zabbix-proxy-sqlite3:${ZABBIX_VERSION:-latest}
|
||||
# container_name: zabbix-proxy-passive-03
|
||||
# depends_on:
|
||||
# - zabbix-server
|
||||
# ports:
|
||||
# - "10103:10051"
|
||||
# environment:
|
||||
# - ZBX_HOSTNAME=zabbix-proxy-passive-03
|
||||
# - ZBX_SERVER_HOST=zabbix-server
|
||||
# - ZBX_PROXYMODE=1
|
||||
# - ZBX_CACHESIZE=${PROXY_CACHE_SIZE}
|
||||
# - ZBX_HISTORYCACHESIZE=${PROXY_HISTORY_CACHE_SIZE}
|
||||
# - ZBX_HISTORYINDEXCACHESIZE=${PROXY_HISTORY_INDEX_CACHE_SIZE}
|
||||
# - ZBX_PROXYBUFFERMODE=${PROXY_BUFFER_MODE}
|
||||
# - ZBX_PROXYMEMORYBUFFERSIZE=${PROXY_MEMORY_BUFFER_SIZE}
|
||||
# volumes:
|
||||
# - ./zabbix/proxy-03:/var/lib/zabbix/db_data:rw
|
||||
# restart: unless-stopped
|
||||
# networks:
|
||||
# - zabbix-net
|
||||
|
||||
networks:
|
||||
zabbix-net:
|
||||
driver: bridge
|
||||
Reference in New Issue
Block a user