Display Valkey version on admin dashboard

This commit is contained in:
Yamagishi Kazutoshi 2025-08-14 18:43:25 +00:00
parent 25f1a515f8
commit 3994366651
4 changed files with 56 additions and 20 deletions

View File

@ -55,6 +55,24 @@ services:
networks: networks:
- internal_network - internal_network
valkey:
image: valkey/valkey:8-alpine
restart: unless-stopped
volumes:
- valkey-data:/data
networks:
- internal_network
dragonfly:
image: docker.dragonflydb.io/dragonflydb/dragonfly
restart: unless-stopped
volumes:
- dragonfly-data:/data
networks:
- internal_network
ulimits:
memlock: -1
es: es:
image: docker.elastic.co/elasticsearch/elasticsearch-oss:7.10.2 image: docker.elastic.co/elasticsearch/elasticsearch-oss:7.10.2
restart: unless-stopped restart: unless-stopped
@ -84,6 +102,8 @@ services:
volumes: volumes:
postgres-data: postgres-data:
redis-data: redis-data:
valkey-data:
dragonfly-data:
es-data: es-data:
lt-data: lt-data:

View File

@ -1,7 +1,7 @@
# frozen_string_literal: true # frozen_string_literal: true
class Admin::Metrics::Dimension::SoftwareVersionsDimension < Admin::Metrics::Dimension::BaseDimension class Admin::Metrics::Dimension::SoftwareVersionsDimension < Admin::Metrics::Dimension::BaseDimension
include Redisable include Admin::Metrics::Dimension::StoreHelper
def key def key
'software_versions' 'software_versions'
@ -45,13 +45,11 @@ class Admin::Metrics::Dimension::SoftwareVersionsDimension < Admin::Metrics::Dim
end end
def redis_version def redis_version
value = redis_info['redis_version']
{ {
key: 'redis', key: 'redis',
human_key: 'Redis', human_key: store_name,
value: value, value: store_version,
human_value: value, human_value: store_version,
} }
end end
@ -117,8 +115,4 @@ class Admin::Metrics::Dimension::SoftwareVersionsDimension < Admin::Metrics::Dim
rescue Terrapin::CommandNotFoundError, Terrapin::ExitStatusError, Oj::ParseError rescue Terrapin::CommandNotFoundError, Terrapin::ExitStatusError, Oj::ParseError
nil nil
end end
def redis_info
@redis_info ||= redis.info
end
end end

View File

@ -1,8 +1,8 @@
# frozen_string_literal: true # frozen_string_literal: true
class Admin::Metrics::Dimension::SpaceUsageDimension < Admin::Metrics::Dimension::BaseDimension class Admin::Metrics::Dimension::SpaceUsageDimension < Admin::Metrics::Dimension::BaseDimension
include Redisable
include ActionView::Helpers::NumberHelper include ActionView::Helpers::NumberHelper
include Admin::Metrics::Dimension::StoreHelper
def key def key
'space_usage' 'space_usage'
@ -27,14 +27,12 @@ class Admin::Metrics::Dimension::SpaceUsageDimension < Admin::Metrics::Dimension
end end
def redis_size def redis_size
value = redis_info['used_memory']
{ {
key: 'redis', key: 'redis',
human_key: 'Redis', human_key: store_name,
value: value.to_s, value: store_size.to_s,
unit: 'bytes', unit: 'bytes',
human_value: number_to_human_size(value), human_value: number_to_human_size(store_size),
} }
end end
@ -57,10 +55,6 @@ class Admin::Metrics::Dimension::SpaceUsageDimension < Admin::Metrics::Dimension
} }
end end
def redis_info
@redis_info ||= redis.info
end
def search_size def search_size
return unless Chewy.enabled? return unless Chewy.enabled?

View File

@ -0,0 +1,28 @@
# frozen_string_literal: true
module Admin::Metrics::Dimension::StoreHelper
include Redisable
protected
def store_name
return 'Valkey' if redis_info.key?('valkey_version')
return 'Dragonfly' if redis_info.key?('dragonfly_version')
'Redis'
end
def store_version
redis_info['valkey_version'] || redis_info['dragonfly_version'] || redis_info['redis_version']
end
def store_size
redis_info['used_memory']
end
private
def redis_info
@redis_info ||= redis.info
end
end