mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-28 22:45:26 +08:00
Related to #46133 Move jemalloc_stats.go and its test file from pkg/util/hardware to internal/util/segcore. This is a more appropriate location because: - jemalloc_stats depends on milvus_core C++ library via cgo - The pkg directory should remain independent of internal C++ dependencies - segcore is the natural home for core memory allocator utilities <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit * **Refactor** * Improved internal code organization by reorganizing memory statistics collection infrastructure for better maintainability and modularity. No impact on end-user functionality or behavior. <sub>✏️ Tip: You can customize this high-level summary in your review settings.</sub> <!-- end of auto-generated comment: release notes by coderabbit.ai --> Signed-off-by: Congqi Xia <congqi.xia@zilliz.com>
71 lines
3.5 KiB
Go
71 lines
3.5 KiB
Go
// Copyright (C) 2019-2025 Zilliz. All rights reserved.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance
|
|
// with the License. You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software distributed under the License
|
|
// is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
|
|
// or implied. See the License for the specific language governing permissions and limitations under the License.
|
|
|
|
package segcore
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestGetJemallocStats(t *testing.T) {
|
|
stats := GetJemallocStats()
|
|
|
|
// The test should always succeed, whether jemalloc is available or not
|
|
if stats.Success {
|
|
// If jemalloc is available, verify the stats make sense
|
|
assert.GreaterOrEqual(t, stats.Active, stats.Allocated,
|
|
"Active memory should be >= allocated memory (includes fragmentation)")
|
|
assert.GreaterOrEqual(t, stats.Resident, stats.Active,
|
|
"Resident memory should be >= active memory")
|
|
assert.GreaterOrEqual(t, stats.Mapped, stats.Resident,
|
|
"Mapped memory should be >= resident memory")
|
|
|
|
// Verify derived metrics
|
|
expectedFragmentation := uint64(0)
|
|
if stats.Active > stats.Allocated {
|
|
expectedFragmentation = stats.Active - stats.Allocated
|
|
}
|
|
assert.Equal(t, expectedFragmentation, stats.Fragmentation,
|
|
"Fragmentation should equal active - allocated")
|
|
|
|
expectedOverhead := uint64(0)
|
|
if stats.Resident > stats.Active {
|
|
expectedOverhead = stats.Resident - stats.Active
|
|
}
|
|
assert.Equal(t, expectedOverhead, stats.Overhead,
|
|
"Overhead should equal resident - active")
|
|
|
|
t.Logf("Jemalloc stats (all 8 metrics):")
|
|
t.Logf(" Allocated: %d bytes (%.2f MB)", stats.Allocated, float64(stats.Allocated)/1024/1024)
|
|
t.Logf(" Active: %d bytes (%.2f MB)", stats.Active, float64(stats.Active)/1024/1024)
|
|
t.Logf(" Metadata: %d bytes (%.2f MB)", stats.Metadata, float64(stats.Metadata)/1024/1024)
|
|
t.Logf(" Resident: %d bytes (%.2f MB)", stats.Resident, float64(stats.Resident)/1024/1024)
|
|
t.Logf(" Mapped: %d bytes (%.2f MB)", stats.Mapped, float64(stats.Mapped)/1024/1024)
|
|
t.Logf(" Retained: %d bytes (%.2f MB)", stats.Retained, float64(stats.Retained)/1024/1024)
|
|
t.Logf(" Fragmentation: %d bytes (%.2f MB)", stats.Fragmentation, float64(stats.Fragmentation)/1024/1024)
|
|
t.Logf(" Overhead: %d bytes (%.2f MB)", stats.Overhead, float64(stats.Overhead)/1024/1024)
|
|
} else {
|
|
// If jemalloc is not available, all values should be zero
|
|
assert.Equal(t, uint64(0), stats.Allocated, "Allocated should be 0 when jemalloc is unavailable")
|
|
assert.Equal(t, uint64(0), stats.Active, "Active should be 0 when jemalloc is unavailable")
|
|
assert.Equal(t, uint64(0), stats.Metadata, "Metadata should be 0 when jemalloc is unavailable")
|
|
assert.Equal(t, uint64(0), stats.Resident, "Resident should be 0 when jemalloc is unavailable")
|
|
assert.Equal(t, uint64(0), stats.Mapped, "Mapped should be 0 when jemalloc is unavailable")
|
|
assert.Equal(t, uint64(0), stats.Retained, "Retained should be 0 when jemalloc is unavailable")
|
|
assert.Equal(t, uint64(0), stats.Fragmentation, "Fragmentation should be 0 when jemalloc is unavailable")
|
|
assert.Equal(t, uint64(0), stats.Overhead, "Overhead should be 0 when jemalloc is unavailable")
|
|
|
|
t.Log("Jemalloc is not available on this system (e.g., macOS)")
|
|
}
|
|
}
|