blob: cd19366d285c7f41a50dbce6993abcb87ee331e8 [file] [log] [blame]
//-
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You 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.
include /app/helpers/jade/mixins
include /app/configuration/mixins
-var form = 'swap'
-var model = '$ctrl.clonedCluster'
-var swapModel = model + '.swapSpaceSpi'
-var fileSwapModel = swapModel + '.FileSwapSpaceSpi'
panel-collapsible(
ng-form=form
on-open=`ui.loadPanel('${form}')`
ng-show='$ctrl.available(["1.0.0", "2.0.0"])'
)
panel-title Swap
panel-description
| Settings for overflow data to disk if it cannot fit in memory.
| #[a.link-success(href="https://apacheignite.readme.io/v1.9/docs/off-heap-memory#swap-space" target="_blank") More info]
panel-content.pca-form-row(ng-if=`$ctrl.available(["1.0.0", "2.0.0"]) && ui.isPanelLoaded('${form}')`)
.pca-form-column-6.pc-form-grid-row
.pc-form-grid-col-60
+form-field__dropdown({
label: 'Swap space SPI:',
model: `${swapModel}.kind`,
name: '"swapSpaceSpi"',
placeholder: 'Choose swap SPI',
options: '::$ctrl.Clusters.swapSpaceSpis',
tip: 'Provides a mechanism in grid for storing data on disk<br/>\
Ignite cache uses swap space to overflow data to disk if it cannot fit in memory\
<ul>\
<li>File-based swap - File-based swap space SPI implementation which holds keys in memory</li>\
<li>Not set - File-based swap space SPI with default configuration when it needed</li>\
</ul>'
})
.pc-form-group.pc-form-grid-row(ng-show=`${swapModel}.kind`)
.pc-form-grid-col-60
+form-field__text({
label: 'Base directory:',
model: `${fileSwapModel}.baseDirectory`,
name: '"baseDirectory"',
placeholder: 'swapspace',
tip: 'Base directory where to write files'
})
.pc-form-grid-col-30
+form-field__number({
label: 'Read stripe size:',
model: `${fileSwapModel}.readStripesNumber`,
name: '"readStripesNumber"',
placeholder: '{{ ::$ctrl.Clusters.swapSpaceSpi.readStripesNumber.default }}',
tip: 'Read stripe size defines number of file channels to be used concurrently'
})(
ui-validate=`{
powerOfTwo: '$ctrl.Clusters.swapSpaceSpi.readStripesNumber.customValidators.powerOfTwo($value)'
}`
)
+form-field__error({ error: 'powerOfTwo', message: 'Read stripe size must be positive and power of two' })
.pc-form-grid-col-30
+form-field__number({
label: 'Maximum sparsity:',
model: `${fileSwapModel}.maximumSparsity`,
name: '"maximumSparsity"',
placeholder: '0.5',
min: '0',
max: '0.999',
step: '0.001',
tip: 'This property defines maximum acceptable wasted file space to whole file size ratio<br/>\
When this ratio becomes higher than specified number compacting thread starts working'
})
.pc-form-grid-col-30
+form-field__number({
label: 'Max write queue size:',
model: `${fileSwapModel}.maxWriteQueueSize`,
name: '"maxWriteQueueSize"',
placeholder: '1024 * 1024',
min: '0',
tip: 'Max write queue size in bytes<br/>\
If there are more values are waiting for being written to disk then specified size, SPI will block on store operation'
})
.pc-form-grid-col-30
+form-field__number({
label: 'Write buffer size:',
model: `${fileSwapModel}.writeBufferSize`,
name: '"writeBufferSize"',
placeholder: '64 * 1024',
min: '0',
tip: 'Write buffer size in bytes<br/>\
Write to disk occurs only when this buffer is full'
})
.pca-form-column-6
+preview-xml-java(model, 'clusterSwap')