-
Notifications
You must be signed in to change notification settings - Fork 0
ARM_PACKAGES
This guide explains how to install and use pre-built ThemisDB packages for ARM architectures.
ThemisDB provides pre-built packages for the following ARM platforms:
| Distribution | Architecture | Format | Status |
|---|---|---|---|
| Debian 11+ | ARM64 | .deb |
✅ Available |
| Ubuntu 20.04+ | ARM64 | .deb |
✅ Available |
| Raspberry Pi OS | ARM64 | .deb |
✅ Available |
| Raspberry Pi OS | ARMv7 (32-bit) | .deb |
✅ Available |
| Fedora 38+ | ARM64 | .rpm |
✅ Available |
| RHEL 9+ | ARM64 | .rpm |
✅ Available |
| Rocky Linux 9+ | ARM64 | .rpm |
✅ Available |
| Arch Linux ARM | ARM64 | .pkg.tar.zst |
✅ Available |
Download and install:
# Download the latest ARM64 package
wget https://github.com/makr-code/ThemisDB/releases/download/v1.0.0/themisdb_1.0.0-1_arm64.deb
# Install package and dependencies
sudo apt update
sudo apt install ./themisdb_1.0.0-1_arm64.debStart the service:
# Enable and start ThemisDB
sudo systemctl enable themisdb
sudo systemctl start themisdb
# Check status
sudo systemctl status themisdbConfiguration:
Default configuration is at /etc/themisdb/config.yaml. Edit as needed:
sudo nano /etc/themisdb/config.yaml
sudo systemctl restart themisdbFor older Raspberry Pi models running 32-bit OS:
# Download ARMv7 package
wget https://github.com/makr-code/ThemisDB/releases/download/v1.0.0/themisdb_1.0.0-1_armhf.deb
# Install
sudo apt update
sudo apt install ./themisdb_1.0.0-1_armhf.deb
# Start service
sudo systemctl enable themisdb
sudo systemctl start themisdbDownload and install:
# Fedora/RHEL 9+
wget https://github.com/makr-code/ThemisDB/releases/download/v1.0.0/themisdb-1.0.0-1.fc39.aarch64.rpm
# Install package
sudo dnf install themisdb-1.0.0-1.fc39.aarch64.rpmStart the service:
sudo systemctl enable themisdb
sudo systemctl start themisdb
sudo systemctl status themisdbDownload and install:
# Download package
wget https://github.com/makr-code/ThemisDB/releases/download/v1.0.0/themisdb-1.0.0-1-aarch64.pkg.tar.zst
# Install with pacman
sudo pacman -U themisdb-1.0.0-1-aarch64.pkg.tar.zstStart the service:
sudo systemctl enable themisdb
sudo systemctl start themisdbAll packages include:
-
/usr/bin/themis_server- Main database server
-
/etc/themisdb/config.yaml- Main configuration file - Default settings optimized for ARM platforms
-
/var/lib/themisdb/- Database data storage - Owned by
themisdb:themisdbuser/group
/usr/lib/systemd/system/themisdb.service- Automatic startup and supervision
-
/usr/share/doc/themisdb/- Documentation files -
/usr/share/licenses/themisdb/- License information
# Check version
themis_server --version
# Check service status
sudo systemctl status themisdb
# View logs
sudo journalctl -u themisdb -fEdit /etc/themisdb/config.yaml:
# Raspberry Pi 4 optimized settings
storage:
rocksdb_path: /var/lib/themisdb/rocksdb
memtable_size_mb: 128
block_cache_size_mb: 512
server:
host: 0.0.0.0
port: 8765
worker_threads: 4
vector_index:
engine: hnsw
hnsw_m: 16
use_gpu: falseAfter editing, restart the service:
sudo systemctl restart themisdbThe package creates a dedicated themisdb user and group:
# Check user
id themisdb
# Verify permissions
ls -la /var/lib/themisdb
ls -la /etc/themisdbRecommended permissions:
- Data directory:
750(themisdb:themisdb) - Config directory:
750(root:themisdb) - Config file:
640(root:themisdb)
Open required ports:
UFW (Ubuntu/Debian):
sudo ufw allow 8765/tcp # ThemisDB API
sudo ufw reloadfirewalld (Fedora/RHEL):
sudo firewall-cmd --permanent --add-port=8765/tcp
sudo firewall-cmd --reload# Download new version
wget https://github.com/makr-code/ThemisDB/releases/download/v1.1.0/themisdb_1.1.0-1_arm64.deb
# Upgrade
sudo apt install ./themisdb_1.1.0-1_arm64.deb
# Service restarts automatically# Download new version
wget https://github.com/makr-code/ThemisDB/releases/download/v1.1.0/themisdb-1.1.0-1.fc39.aarch64.rpm
# Upgrade
sudo dnf upgrade themisdb-1.1.0-1.fc39.aarch64.rpm# Download new version
wget https://github.com/makr-code/ThemisDB/releases/download/v1.1.0/themisdb-1.1.0-1-aarch64.pkg.tar.zst
# Upgrade
sudo pacman -U themisdb-1.1.0-1-aarch64.pkg.tar.zst# Stop service
sudo systemctl stop themisdb
sudo systemctl disable themisdb
# Remove package (keep data)
sudo apt remove themisdb
# Remove package and data
sudo apt purge themisdb
# Clean up data manually if needed
sudo rm -rf /var/lib/themisdb# Stop service
sudo systemctl stop themisdb
sudo systemctl disable themisdb
# Remove package
sudo dnf remove themisdb
# Clean up data if not auto-removed
sudo rm -rf /var/lib/themisdb# Stop service
sudo systemctl stop themisdb
# Remove package
sudo pacman -R themisdb
# Clean up data
sudo rm -rf /var/lib/themisdbCheck logs:
sudo journalctl -u themisdb -n 100 --no-pagerCheck configuration:
themis_server --check-config /etc/themisdb/config.yamlVerify permissions:
sudo ls -la /var/lib/themisdb
sudo ls -la /etc/themisdbIf port 8765 is in use:
- Edit
/etc/themisdb/config.yaml - Change
server.portto different port - Restart service
For Raspberry Pi with 2GB RAM or less:
storage:
memtable_size_mb: 64
block_cache_size_mb: 256Then restart:
sudo systemctl restart themisdbFix ownership:
sudo chown -R themisdb:themisdb /var/lib/themisdb
sudo chmod 750 /var/lib/themisdbDevelopment headers and libraries are available in separate packages:
sudo apt install themisdb-devsudo dnf install themisdb-develDevelopment files are included in main package.
Development package includes:
- Header files in
/usr/include/themis/ - Static library:
/usr/lib/libthemis_core.a - CMake configuration files
If you need to build packages yourself:
# Install build dependencies
sudo apt install build-essential debhelper cmake ninja-build
# Clone repository
git clone https://github.com/makr-code/ThemisDB.git
cd ThemisDB
# Build package
dpkg-buildpackage -b -uc -us
# Install built package
sudo dpkg -i ../themisdb_*.deb# Install build tools
sudo dnf install rpm-build rpmdevtools
# Setup build tree
rpmdev-setuptree
# Build from spec file
rpmbuild -bb themisdb.spec# Install build dependencies
sudo pacman -S base-devel
# Build from PKGBUILD
makepkg -s
# Install
sudo pacman -U themisdb-*.pkg.tar.zstPlanned: APT and YUM repositories for easier installation:
# Debian/Ubuntu (planned)
echo "deb https://packages.themisdb.org/debian stable main" | \
sudo tee /etc/apt/sources.list.d/themisdb.list
wget -O - https://packages.themisdb.org/key.gpg | sudo apt-key add -
sudo apt update
sudo apt install themisdb
# Fedora/RHEL (planned)
sudo dnf config-manager --add-repo https://packages.themisdb.org/rpm/themisdb.repo
sudo dnf install themisdbEnable performance governor:
echo performance | sudo tee /sys/devices/system/cpu/cpu*/cpufreq/scaling_governorUse SSD for data:
Mount fast storage at /var/lib/themisdb for better performance.
Optimize config:
storage:
memtable_size_mb: 128 # 4GB RAM
block_cache_size_mb: 512
max_background_jobs: 4
server:
worker_threads: 4 # Match CPU coresCheck resource usage:
# CPU and memory
top -p $(pgrep themis_server)
# Disk I/O
sudo iotop -p $(pgrep themis_server)
# Service stats
sudo systemctl status themisdb- Issues: https://github.com/makr-code/ThemisDB/issues
- Documentation: https://github.com/makr-code/ThemisDB/tree/main/docs
- ARM Guide: docs/ARM_RASPBERRY_PI_BUILD.md
ThemisDB is released under the MIT License. See /usr/share/licenses/themisdb/LICENSE for details.
- AQL Overview
- AQL Syntax Reference
- EXPLAIN and PROFILE
- Hybrid Queries
- Pattern Matching
- Subquery Implementation
- Subquery Quick Reference
- Fulltext Release Notes
- Hybrid Search Design
- Fulltext Search API
- Content Search
- Pagination Benchmarks
- Stemming
- Hybrid Fusion API
- Performance Tuning
- Migration Guide
- Storage Overview
- RocksDB Layout
- Geo Schema
- Index Types
- Index Statistics
- Index Backup
- HNSW Persistence
- Vector Index
- Graph Index
- Secondary Index
- Security Overview
- RBAC and Authorization
- TLS Setup
- Certificate Pinning
- Encryption Strategy
- Column Encryption
- Key Management
- Key Rotation
- HSM Integration
- PKI Integration
- eIDAS Signatures
- PII Detection
- PII API
- Threat Model
- Hardening Guide
- Incident Response
- SBOM
- Enterprise Overview
- Scalability Features
- Scalability Strategy
- HTTP Client Pool
- Enterprise Build Guide
- Enterprise Ingestion
- Benchmarks Overview
- Compression Benchmarks
- Compression Strategy
- Memory Tuning
- Hardware Acceleration
- GPU Acceleration Plan
- CUDA Backend
- Vulkan Backend
- Multi-CPU Support
- TBB Integration
- Time Series
- Vector Operations
- Graph Features
- Temporal Graphs
- Path Constraints
- Recursive Queries
- Audit Logging
- Change Data Capture
- Transactions
- Semantic Cache
- Cursor Pagination
- Compliance Features
- GNN Embeddings
- Geo Overview
- Geo Architecture
- 3D Game Acceleration
- Geo Feature Tiering
- G3 Phase 2 Status
- G5 Implementation
- Integration Guide
- Content Architecture
- Content Pipeline
- Content Manager
- JSON Ingestion
- Content Ingestion
- Filesystem API
- Image Processor
- Geo Processor
- Policy Implementation
- Developer Guide
- Implementation Status
- Development Roadmap
- Build Strategy
- Build Acceleration
- Code Quality Guide
- AQL LET Implementation
- Audit API Implementation
- SAGA API Implementation
- PKI eIDAS
- WAL Archiving
- Architecture Overview
- Strategic Overview
- Ecosystem
- MVCC Design
- Base Entity
- Caching Strategy
- Caching Data Structures
- Docker Build
- Docker Status
- Multi-Arch CI/CD
- ARM Build Guide
- ARM Packages
- Raspberry Pi Tuning
- Packaging Guide
- Package Maintainers
- Roadmap
- Changelog
- Database Capabilities
- Implementation Summary
- Sachstandsbericht 2025
- Enterprise Final Report
- Test Report
- Build Success Report
- Integration Analysis
- Source Overview
- API Implementation
- Query Engine
- Storage Layer
- Security Implementation
- CDC Implementation
- Time Series
- Utils and Helpers
Updated: 2025-11-30