mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-16 10:58:30 -05:00
Update mssql/sqltoolsservice for SKU recommendation changes (#18315)
* Add new contracts * Increment sqltoolsservice to 3.0.0-release.202
This commit is contained in:
279
extensions/mssql/src/mssql.d.ts
vendored
279
extensions/mssql/src/mssql.d.ts
vendored
@@ -615,6 +615,285 @@ export interface AssessmentResult {
|
||||
errors: ErrorModel[];
|
||||
}
|
||||
|
||||
// SKU recommendation interfaces, mirrored from Microsoft.SqlServer.Migration.SkuRecommendation
|
||||
export interface AzureSqlSkuCategory {
|
||||
sqlTargetPlatform: AzureSqlTargetPlatform;
|
||||
computeTier: ComputeTier;
|
||||
}
|
||||
|
||||
export interface AzureSqlSkuPaaSCategory extends AzureSqlSkuCategory {
|
||||
sqlPurchasingModel: AzureSqlPurchasingModel;
|
||||
sqlServiceTier: AzureSqlPaaSServiceTier;
|
||||
hardwareType: AzureSqlPaaSHardwareType;
|
||||
}
|
||||
|
||||
export interface AzureSqlSkuIaaSCategory extends AzureSqlSkuCategory {
|
||||
virtualMachineFamilyType: VirtualMachineFamilyType;
|
||||
}
|
||||
|
||||
export interface AzureManagedDiskSku {
|
||||
tier: AzureManagedDiskTier;
|
||||
size: string;
|
||||
caching: AzureManagedDiskCaching;
|
||||
}
|
||||
|
||||
export interface AzureVirtualMachineSku {
|
||||
virtualMachineFamily: VirtualMachineFamily;
|
||||
sizeName: string;
|
||||
computeSize: number;
|
||||
azureSkuName: string;
|
||||
vCPUsAvailable: number;
|
||||
}
|
||||
|
||||
export interface AzureSqlSkuMonthlyCost {
|
||||
computeCost: number;
|
||||
storageCost: number;
|
||||
totalCost: number;
|
||||
}
|
||||
|
||||
export interface AzureSqlSku {
|
||||
category: AzureSqlSkuPaaSCategory | AzureSqlSkuIaaSCategory;
|
||||
computeSize: number;
|
||||
predictedDataSizeInMb: number;
|
||||
predictedLogSizeInMb: number;
|
||||
}
|
||||
|
||||
export interface AzureSqlPaaSSku extends AzureSqlSku {
|
||||
category: AzureSqlSkuPaaSCategory;
|
||||
storageMaxSizeInMb: number;
|
||||
}
|
||||
|
||||
export interface AzureSqlIaaSSku extends AzureSqlSku {
|
||||
category: AzureSqlSkuIaaSCategory;
|
||||
virtualMachineSize: AzureVirtualMachineSku;
|
||||
dataDiskSizes: AzureManagedDiskSku[];
|
||||
logDiskSizes: AzureManagedDiskSku[];
|
||||
tempDbDiskSizes: AzureManagedDiskSku[];
|
||||
}
|
||||
|
||||
export interface SkuRecommendationResultItem {
|
||||
sqlInstanceName: string;
|
||||
databaseName: string;
|
||||
targetSku: AzureSqlIaaSSku | AzureSqlPaaSSku;
|
||||
monthlyCost: AzureSqlSkuMonthlyCost;
|
||||
ranking: number;
|
||||
positiveJustifications: string[];
|
||||
negativeJustifications: string[];
|
||||
}
|
||||
|
||||
export interface SqlInstanceRequirements {
|
||||
cpuRequirementInCores: number;
|
||||
dataStorageRequirementInMB: number;
|
||||
logStorageRequirementInMB: number;
|
||||
memoryRequirementInMB: number;
|
||||
dataIOPSRequirement: number;
|
||||
logIOPSRequirement: number;
|
||||
ioLatencyRequirementInMs: number;
|
||||
ioThroughputRequirementInMBps: number;
|
||||
tempDBSizeInMB: number;
|
||||
dataPointsStartTime: string;
|
||||
dataPointsEndTime: string;
|
||||
aggregationTargetPercentile: number;
|
||||
perfDataCollectionIntervalInSeconds: number;
|
||||
databaseLevelRequirements: SqlDatabaseRequirements[];
|
||||
numberOfDataPointsAnalyzed: number;
|
||||
}
|
||||
|
||||
export interface SqlDatabaseRequirements {
|
||||
cpuRequirementInCores: number;
|
||||
dataIOPSRequirement: number;
|
||||
logIOPSRequirement: number;
|
||||
ioLatencyRequirementInMs: number;
|
||||
ioThroughputRequirementInMBps: number;
|
||||
dataStorageRequirementInMB: number;
|
||||
logStorageRequirementInMB: number;
|
||||
databaseName: string;
|
||||
memoryRequirementInMB: number;
|
||||
cpuRequirementInPercentageOfTotalInstance: number;
|
||||
numberOfDataPointsAnalyzed: number;
|
||||
fileLevelRequirements: SqlFileRequirements[];
|
||||
}
|
||||
|
||||
export interface SqlFileRequirements {
|
||||
fileName: string;
|
||||
fileType: DatabaseFileType;
|
||||
sizeInMB: number;
|
||||
readLatencyInMs: number;
|
||||
writeLatencyInMs: number;
|
||||
iopsRequirement: number;
|
||||
ioThroughputRequirementInMBps: number;
|
||||
numberOfDataPointsAnalyzed: number;
|
||||
}
|
||||
|
||||
export interface PaaSSkuRecommendationResultItem extends SkuRecommendationResultItem {
|
||||
targetSku: AzureSqlPaaSSku;
|
||||
}
|
||||
|
||||
export interface IaaSSkuRecommendationResultItem extends SkuRecommendationResultItem {
|
||||
targetSku: AzureSqlIaaSSku;
|
||||
}
|
||||
|
||||
export interface SkuRecommendationResult {
|
||||
sqlDbRecommendationResults: PaaSSkuRecommendationResultItem[];
|
||||
sqlMiRecommendationResults: PaaSSkuRecommendationResultItem[];
|
||||
sqlVmRecommendationResults: IaaSSkuRecommendationResultItem[];
|
||||
instanceRequirements: SqlInstanceRequirements;
|
||||
}
|
||||
|
||||
// SKU recommendation enums, mirrored from Microsoft.SqlServer.Migration.SkuRecommendation
|
||||
export const enum DatabaseFileType {
|
||||
Rows = 0,
|
||||
Log = 1,
|
||||
Filestream = 2,
|
||||
NotSupported = 3,
|
||||
Fulltext = 4
|
||||
}
|
||||
|
||||
export const enum AzureSqlTargetPlatform {
|
||||
AzureSqlDatabase = 0,
|
||||
AzureSqlManagedInstance = 1,
|
||||
AzureSqlVirtualMachine = 2
|
||||
}
|
||||
|
||||
export const enum ComputeTier {
|
||||
Provisioned = 0,
|
||||
ServerLess = 1
|
||||
}
|
||||
|
||||
export const enum AzureManagedDiskTier {
|
||||
Standard = 0,
|
||||
Premium = 1,
|
||||
Ultra = 2
|
||||
}
|
||||
|
||||
export const enum AzureManagedDiskCaching {
|
||||
NotApplicable = 0,
|
||||
None = 1,
|
||||
ReadOnly = 2,
|
||||
ReadWrite = 3
|
||||
}
|
||||
|
||||
export const enum AzureSqlPurchasingModel {
|
||||
vCore = 0,
|
||||
}
|
||||
|
||||
export const enum AzureSqlPaaSServiceTier {
|
||||
GeneralPurpose = 0,
|
||||
BusinessCritical,
|
||||
HyperScale,
|
||||
}
|
||||
|
||||
export const enum AzureSqlPaaSHardwareType {
|
||||
Gen5 = 0,
|
||||
PremiumSeries,
|
||||
PremiumSeriesMemoryOptimized
|
||||
}
|
||||
|
||||
export const enum VirtualMachineFamilyType {
|
||||
GeneralPurpose,
|
||||
ComputeOptimized,
|
||||
MemoryOptimized,
|
||||
StorageOptimized,
|
||||
GPU,
|
||||
HighPerformanceCompute
|
||||
}
|
||||
|
||||
export const enum VirtualMachineFamily {
|
||||
basicAFamily,
|
||||
standardA0_A7Family,
|
||||
standardAv2Family,
|
||||
standardBSFamily,
|
||||
standardDFamily,
|
||||
standardDv2Family,
|
||||
standardDv2PromoFamily,
|
||||
standardDADSv5Family,
|
||||
standardDASv4Family,
|
||||
standardDASv5Family,
|
||||
standardDAv4Family,
|
||||
standardDDSv4Family,
|
||||
standardDDSv5Family,
|
||||
standardDDv4Family,
|
||||
standardDDv5Family,
|
||||
standardDSv3Family,
|
||||
standardDSv4Family,
|
||||
standardDSv5Family,
|
||||
standardDv3Family,
|
||||
standardDv4Family,
|
||||
standardDv5Family,
|
||||
standardDCADSv5Family,
|
||||
standardDCASv5Family,
|
||||
standardDCSv2Family,
|
||||
standardDSFamily,
|
||||
standardDSv2Family,
|
||||
standardDSv2PromoFamily,
|
||||
standardEIDSv5Family,
|
||||
standardEIDv5Family,
|
||||
standardEISv5Family,
|
||||
standardEIv5Family,
|
||||
standardEADSv5Family,
|
||||
standardEASv4Family,
|
||||
standardEASv5Family,
|
||||
standardEDSv4Family,
|
||||
standardEDSv5Family,
|
||||
standardEBDSv5Family,
|
||||
standardESv3Family,
|
||||
standardESv4Family,
|
||||
standardESv5Family,
|
||||
standardEBSv5Family,
|
||||
standardEAv4Family,
|
||||
standardEDv4Family,
|
||||
standardEDv5Family,
|
||||
standardEv3Family,
|
||||
standardEv4Family,
|
||||
standardEv5Family,
|
||||
standardEISv3Family,
|
||||
standardEIv3Family,
|
||||
standardXEIDSv4Family,
|
||||
standardXEISv4Family,
|
||||
standardECADSv5Family,
|
||||
standardECASv5Family,
|
||||
standardECIADSv5Family,
|
||||
standardECIASv5Family,
|
||||
standardFFamily,
|
||||
standardFSFamily,
|
||||
standardFSv2Family,
|
||||
standardGFamily,
|
||||
standardGSFamily,
|
||||
standardHFamily,
|
||||
standardHPromoFamily,
|
||||
standardLSFamily,
|
||||
standardLSv2Family,
|
||||
standardMSFamily,
|
||||
standardMDSMediumMemoryv2Family,
|
||||
standardMSMediumMemoryv2Family,
|
||||
standardMIDSMediumMemoryv2Family,
|
||||
standardMISMediumMemoryv2Family,
|
||||
standardMSv2Family,
|
||||
standardNCSv3Family,
|
||||
StandardNCASv3_T4Family,
|
||||
standardNVSv2Family,
|
||||
standardNVSv3Family,
|
||||
standardNVSv4Family
|
||||
}
|
||||
|
||||
export interface StartPerfDataCollectionResult {
|
||||
dateTimeStarted: Date;
|
||||
}
|
||||
|
||||
export interface StopPerfDataCollectionResult {
|
||||
dateTimeStopped: Date;
|
||||
}
|
||||
|
||||
export interface RefreshPerfDataCollectionResult {
|
||||
messages: string[];
|
||||
errors: string[];
|
||||
refreshTime: Date;
|
||||
}
|
||||
|
||||
export interface ISqlMigrationService {
|
||||
getAssessments(ownerUri: string, databases: string[]): Promise<AssessmentResult | undefined>;
|
||||
getSkuRecommendations(dataFolder: string, perfQueryIntervalInSec: number, targetPlatforms: string[], targetSqlInstance: string, targetPercentile: number, scalingFactor: number, startTime: string, endTime: string, includePreviewSkus: boolean, databaseAllowList: string[]): Promise<SkuRecommendationResult | undefined>;
|
||||
startPerfDataCollection(ownerUri: string, dataFolder: string, perfQueryIntervalInSec: number, staticQueryIntervalInSec: number, numberOfIterations: number): Promise<StartPerfDataCollectionResult | undefined>;
|
||||
stopPerfDataCollection(): Promise<StopPerfDataCollectionResult | undefined>;
|
||||
refreshPerfDataCollection(lastRefreshedTime: Date): Promise<RefreshPerfDataCollectionResult | undefined>;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user