Major integrations and fixes: - Added BACKBEAT SDK integration for P2P operation timing - Implemented beat-aware status tracking for distributed operations - Added Docker secrets support for secure license management - Resolved KACHING license validation via HTTPS/TLS - Updated docker-compose configuration for clean stack deployment - Disabled rollback policies to prevent deployment failures - Added license credential storage (CHORUS-DEV-MULTI-001) Technical improvements: - BACKBEAT P2P operation tracking with phase management - Enhanced configuration system with file-based secrets - Improved error handling for license validation - Clean separation of KACHING and CHORUS deployment stacks 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
37 lines
699 B
Go
37 lines
699 B
Go
//go:build !windows
|
|
|
|
package bbolt
|
|
|
|
import "golang.org/x/sys/unix"
|
|
|
|
// mlock locks memory of db file
|
|
func mlock(db *DB, fileSize int) error {
|
|
sizeToLock := fileSize
|
|
if sizeToLock > db.datasz {
|
|
// Can't lock more than mmaped slice
|
|
sizeToLock = db.datasz
|
|
}
|
|
if err := unix.Mlock(db.dataref[:sizeToLock]); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// munlock unlocks memory of db file
|
|
func munlock(db *DB, fileSize int) error {
|
|
if db.dataref == nil {
|
|
return nil
|
|
}
|
|
|
|
sizeToUnlock := fileSize
|
|
if sizeToUnlock > db.datasz {
|
|
// Can't unlock more than mmaped slice
|
|
sizeToUnlock = db.datasz
|
|
}
|
|
|
|
if err := unix.Munlock(db.dataref[:sizeToUnlock]); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|