mirror of
https://github.com/xcp-ng/xenadmin.git
synced 2025-01-20 15:29:26 +01:00
Merge pull request #390 from stephen-turner/CA-163782
CA-163782: Read the read-caching reason from the server
This commit is contained in:
commit
4ecc70a307
@ -1400,7 +1400,9 @@ namespace XenAdmin.TabPages
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
s.AddEntry(FriendlyName("VM.read_caching_status"), Messages.VM_READ_CACHING_DISABLED);
|
s.AddEntry(FriendlyName("VM.read_caching_status"), Messages.VM_READ_CACHING_DISABLED);
|
||||||
s.AddEntry(FriendlyName("VM.read_caching_reason"), vm.ReadCachingDisabledReason);
|
var reason = vm.ReadCachingDisabledReason;
|
||||||
|
if (reason != null)
|
||||||
|
s.AddEntry(FriendlyName("VM.read_caching_reason"), reason);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
28
XenModel/Messages.Designer.cs
generated
28
XenModel/Messages.Designer.cs
generated
@ -33884,7 +33884,7 @@ namespace XenAdmin {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized string similar to This VM is not using Read Caching.
|
/// Looks up a localized string similar to This VM is not using read caching.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static string VM_READ_CACHING_DISABLED {
|
public static string VM_READ_CACHING_DISABLED {
|
||||||
get {
|
get {
|
||||||
@ -33893,7 +33893,7 @@ namespace XenAdmin {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized string similar to Not licensed for Read Caching.
|
/// Looks up a localized string similar to This pool is not licensed for read caching.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static string VM_READ_CACHING_DISABLED_REASON_LICENSE {
|
public static string VM_READ_CACHING_DISABLED_REASON_LICENSE {
|
||||||
get {
|
get {
|
||||||
@ -33902,7 +33902,25 @@ namespace XenAdmin {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized string similar to Read Caching is not supported on any of the Storage Repositories used by this VM.
|
/// Looks up a localized string similar to This VM does not have any read-only disks or disks with a read-only parent.
|
||||||
|
/// </summary>
|
||||||
|
public static string VM_READ_CACHING_DISABLED_REASON_NO_RO_IMAGE {
|
||||||
|
get {
|
||||||
|
return ResourceManager.GetString("VM_READ_CACHING_DISABLED_REASON_NO_RO_IMAGE", resourceCulture);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Looks up a localized string similar to This pool was not licensed for read caching when the VM was started.
|
||||||
|
/// </summary>
|
||||||
|
public static string VM_READ_CACHING_DISABLED_REASON_PREV_LICENSE {
|
||||||
|
get {
|
||||||
|
return ResourceManager.GetString("VM_READ_CACHING_DISABLED_REASON_PREV_LICENSE", resourceCulture);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Looks up a localized string similar to Read caching is not supported on the type of Storage Repository used by this VM.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static string VM_READ_CACHING_DISABLED_REASON_SR_TYPE {
|
public static string VM_READ_CACHING_DISABLED_REASON_SR_TYPE {
|
||||||
get {
|
get {
|
||||||
@ -33911,7 +33929,7 @@ namespace XenAdmin {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized string similar to Read Caching is disabled on all supported Storage Repositories used by this VM.
|
/// Looks up a localized string similar to Read caching has been disabled on the Storage Repository used by this VM.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static string VM_READ_CACHING_DISABLED_REASON_TURNED_OFF {
|
public static string VM_READ_CACHING_DISABLED_REASON_TURNED_OFF {
|
||||||
get {
|
get {
|
||||||
@ -33920,7 +33938,7 @@ namespace XenAdmin {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized string similar to This VM has Read Caching enabled.
|
/// Looks up a localized string similar to This VM is using read caching.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static string VM_READ_CACHING_ENABLED {
|
public static string VM_READ_CACHING_ENABLED {
|
||||||
get {
|
get {
|
||||||
|
@ -11736,19 +11736,25 @@ To learn more about the XenServer Dynamic Workload Balancing feature or to start
|
|||||||
<value>Succeeded</value>
|
<value>Succeeded</value>
|
||||||
</data>
|
</data>
|
||||||
<data name="VM_READ_CACHING_DISABLED" xml:space="preserve">
|
<data name="VM_READ_CACHING_DISABLED" xml:space="preserve">
|
||||||
<value>This VM is not using Read Caching</value>
|
<value>This VM is not using read caching</value>
|
||||||
</data>
|
</data>
|
||||||
<data name="VM_READ_CACHING_DISABLED_REASON_LICENSE" xml:space="preserve">
|
<data name="VM_READ_CACHING_DISABLED_REASON_LICENSE" xml:space="preserve">
|
||||||
<value>Not licensed for Read Caching</value>
|
<value>This pool is not licensed for read caching</value>
|
||||||
|
</data>
|
||||||
|
<data name="VM_READ_CACHING_DISABLED_REASON_NO_RO_IMAGE" xml:space="preserve">
|
||||||
|
<value>This VM does not have any read-only disks or disks with a read-only parent</value>
|
||||||
|
</data>
|
||||||
|
<data name="VM_READ_CACHING_DISABLED_REASON_PREV_LICENSE" xml:space="preserve">
|
||||||
|
<value>This pool was not licensed for read caching when the VM was started</value>
|
||||||
</data>
|
</data>
|
||||||
<data name="VM_READ_CACHING_DISABLED_REASON_SR_TYPE" xml:space="preserve">
|
<data name="VM_READ_CACHING_DISABLED_REASON_SR_TYPE" xml:space="preserve">
|
||||||
<value>Read Caching is not supported on any of the Storage Repositories used by this VM</value>
|
<value>Read caching is not supported on the type of Storage Repository used by this VM</value>
|
||||||
</data>
|
</data>
|
||||||
<data name="VM_READ_CACHING_DISABLED_REASON_TURNED_OFF" xml:space="preserve">
|
<data name="VM_READ_CACHING_DISABLED_REASON_TURNED_OFF" xml:space="preserve">
|
||||||
<value>Read Caching is disabled on all supported Storage Repositories used by this VM</value>
|
<value>Read caching has been disabled on the Storage Repository used by this VM</value>
|
||||||
</data>
|
</data>
|
||||||
<data name="VM_READ_CACHING_ENABLED" xml:space="preserve">
|
<data name="VM_READ_CACHING_ENABLED" xml:space="preserve">
|
||||||
<value>This VM has Read Caching enabled</value>
|
<value>This VM is using read caching</value>
|
||||||
</data>
|
</data>
|
||||||
<data name="VM_READ_CACHING_ENABLED_SEARCH" xml:space="preserve">
|
<data name="VM_READ_CACHING_ENABLED_SEARCH" xml:space="preserve">
|
||||||
<value>Using read caching</value>
|
<value>Using read caching</value>
|
||||||
@ -12680,4 +12686,4 @@ You will need to navigate to the Console on each of the selected VMs to complete
|
|||||||
<data name="YOU_ARE_HERE" xml:space="preserve">
|
<data name="YOU_ARE_HERE" xml:space="preserve">
|
||||||
<value>You are here</value>
|
<value>You are here</value>
|
||||||
</data>
|
</data>
|
||||||
</root>
|
</root>
|
@ -335,16 +335,31 @@ namespace XenAPI
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Whether read caching is supported on this disk
|
/// ... and if not, why not
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public bool ReadCachingSupported
|
public ReadCachingDisabledReasonCode ReadCachingDisabledReason(Host host)
|
||||||
{
|
{
|
||||||
get
|
string reasonstr;
|
||||||
|
if (sm_config.TryGetValue("read-caching-reason-" + host.uuid, out reasonstr))
|
||||||
{
|
{
|
||||||
var sr = Connection.Resolve(SR);
|
ReadCachingDisabledReasonCode reason;
|
||||||
var srType = sr != null ? sr.GetSRType(false) : XenAPI.SR.SRTypes.unknown;
|
if (Enum.TryParse(reasonstr, out reason))
|
||||||
return srType == XenAPI.SR.SRTypes.ext || srType == XenAPI.SR.SRTypes.nfs;
|
return reason;
|
||||||
}
|
}
|
||||||
|
return ReadCachingDisabledReasonCode.UNKNOWN;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Possible reasons for read caching being disabled
|
||||||
|
/// If there are multiple reasons, the topmost reason will be returned
|
||||||
|
/// </summary>
|
||||||
|
public enum ReadCachingDisabledReasonCode
|
||||||
|
{
|
||||||
|
UNKNOWN, // catch-all, shouldn't occur if read caching is disabled
|
||||||
|
LICENSE_RESTRICTION, // self-explanatory
|
||||||
|
SR_NOT_SUPPORTED, // the SR is not NFS or EXT
|
||||||
|
NO_RO_IMAGE, // no part of the VDI is read-only => nothing to cache
|
||||||
|
SR_OVERRIDE, // the feature has been explicitly disabled for the VDI's SR
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1760,32 +1760,45 @@ namespace XenAPI
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
public string ReadCachingDisabledReason
|
||||||
/// Whether the Read Caching is supported on any of the VDIs
|
|
||||||
/// </summary>
|
|
||||||
public bool ReadCachingSupported
|
|
||||||
{
|
{
|
||||||
get
|
// The code in VDI.ReadCachingDisabledReason returns the first matching reason from the list
|
||||||
|
// (LICENSE_RESTRICTION, SR_NOT_SUPPORTED, NO_RO_IMAGE, SR_OVERRIDE). In the case that there
|
||||||
|
// are several VDIs with different reasons, this function returns the last matching reason,
|
||||||
|
// because that is the VDI that is nearest to being read-cachable in some sense. As the reasons
|
||||||
|
// are stored in an enum, we can just use greater-than to find the last reason
|
||||||
|
get
|
||||||
{
|
{
|
||||||
|
var ans = VDI.ReadCachingDisabledReasonCode.UNKNOWN;
|
||||||
foreach (var vbd in Connection.ResolveAll(VBDs).Where(vbd => vbd != null && vbd.currently_attached))
|
foreach (var vbd in Connection.ResolveAll(VBDs).Where(vbd => vbd != null && vbd.currently_attached))
|
||||||
{
|
{
|
||||||
var vdi = Connection.Resolve(vbd.VDI);
|
var vdi = Connection.Resolve(vbd.VDI);
|
||||||
if (vdi != null && vdi.ReadCachingSupported)
|
var resident_host = Connection.Resolve(resident_on);
|
||||||
return true;
|
if (vdi != null && resident_host != null && !vdi.ReadCachingEnabled(resident_host))
|
||||||
|
{
|
||||||
|
var reason = vdi.ReadCachingDisabledReason(resident_host);
|
||||||
|
if (reason > ans)
|
||||||
|
ans = reason;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (ans)
|
||||||
|
{
|
||||||
|
case VDI.ReadCachingDisabledReasonCode.LICENSE_RESTRICTION:
|
||||||
|
if (Helpers.FeatureForbidden(Connection, Host.RestrictReadCaching))
|
||||||
|
return Messages.VM_READ_CACHING_DISABLED_REASON_LICENSE;
|
||||||
|
else
|
||||||
|
return Messages.VM_READ_CACHING_DISABLED_REASON_PREV_LICENSE;
|
||||||
|
case VDI.ReadCachingDisabledReasonCode.SR_NOT_SUPPORTED:
|
||||||
|
return Messages.VM_READ_CACHING_DISABLED_REASON_SR_TYPE;
|
||||||
|
case VDI.ReadCachingDisabledReasonCode.NO_RO_IMAGE:
|
||||||
|
return Messages.VM_READ_CACHING_DISABLED_REASON_NO_RO_IMAGE;
|
||||||
|
case VDI.ReadCachingDisabledReasonCode.SR_OVERRIDE:
|
||||||
|
return Messages.VM_READ_CACHING_DISABLED_REASON_TURNED_OFF;
|
||||||
|
default:
|
||||||
|
// should only happen transiently
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public string ReadCachingDisabledReason
|
|
||||||
{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
if (Helpers.FeatureForbidden(Connection, Host.RestrictReadCaching))
|
|
||||||
return Messages.VM_READ_CACHING_DISABLED_REASON_LICENSE;
|
|
||||||
if (!ReadCachingSupported)
|
|
||||||
return Messages.VM_READ_CACHING_DISABLED_REASON_SR_TYPE;
|
|
||||||
return Messages.VM_READ_CACHING_DISABLED_REASON_TURNED_OFF;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user