Compare commits
480 Commits
3.0.0.0rc2
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
03073a1b0d | ||
|
|
ced0d58d23 | ||
|
|
3c8bc6be62 | ||
|
|
635be7a009 | ||
|
|
fe50d270c3 | ||
|
|
27961d8574 | ||
|
|
408abaee49 | ||
|
|
ed0f7457fb | ||
|
|
680518ad6d | ||
|
|
cada9acced | ||
|
|
8211475478 | ||
|
|
c2ad4b28da | ||
|
|
296856101f | ||
|
|
2f2134fc7a | ||
|
|
cb6fb16097 | ||
|
|
cee72d2bda | ||
|
|
cd1154d09c | ||
|
|
90f6552c74 | ||
|
|
0368cea4c1 | ||
|
|
e1c8961a7c | ||
|
|
61cca16dcd | ||
|
|
f3d0ec5869 | ||
|
|
17a4c96c66 | ||
|
|
a562880b1c | ||
|
|
fe56660c44 | ||
|
|
6cb4e2fa83 | ||
|
|
9b1adaa7c7 | ||
|
|
f21df7ce1e | ||
|
|
b1aad46209 | ||
|
|
90009aac84 | ||
|
|
e5b18afa01 | ||
|
|
fedc74a5b0 | ||
|
|
a4b785e4f1 | ||
|
|
cdde0fb41e | ||
|
|
ef0f35192d | ||
|
|
c9bfb763c2 | ||
|
|
eb3fdb1e97 | ||
|
|
848cde3606 | ||
|
|
63cf35349c | ||
|
|
7106a12251 | ||
|
|
03c09825f7 | ||
|
|
2452c1e541 | ||
|
|
d91b550fc9 | ||
|
|
1668b9b9f8 | ||
|
|
5e05b50048 | ||
|
|
4d8f86b432 | ||
|
|
05d8f0e3c8 | ||
|
|
1a87abc666 | ||
|
|
fa4552b93f | ||
|
|
a07bfa141d | ||
|
|
a6668a1b39 | ||
|
|
534c340df1 | ||
|
|
a963e0ff85 | ||
|
|
457819072f | ||
|
|
6d155c4be6 | ||
|
|
83fea206df | ||
|
|
00a3edeac6 | ||
|
|
b69642181b | ||
|
|
616c8f4cc4 | ||
|
|
cc26b3b334 | ||
|
|
9003906bdc | ||
|
|
e06f1b0475 | ||
|
|
6d35be11ec | ||
|
|
1009c3781b | ||
|
|
5048a6e3ba | ||
|
|
84742be8c2 | ||
|
|
1fb89aeac3 | ||
|
|
1a9f17748e | ||
|
|
90f0c2264c | ||
|
|
3742e0a79c | ||
|
|
7b5243fa8d | ||
|
|
8309d9848a | ||
|
|
355671e979 | ||
|
|
9becb68495 | ||
|
|
37faf614e2 | ||
|
|
4080d5767d | ||
|
|
9925fd2cc9 | ||
|
|
27baff5184 | ||
|
|
8ca794cdbb | ||
|
|
f879b10b05 | ||
|
|
95d975f339 | ||
|
|
0435200fb1 | ||
|
|
adfe3858aa | ||
|
|
a1e7156c7e | ||
|
|
71470dac73 | ||
|
|
5ba086095c | ||
|
|
3e8392b8f1 | ||
|
|
20cd4a0394 | ||
|
|
374750847f | ||
|
|
2fe3b0cdbe | ||
|
|
9b9965265a | ||
|
|
98b56b66ac | ||
|
|
081cd5fae9 | ||
|
|
1ab5babbb6 | ||
|
|
d771d00c5a | ||
|
|
e3b813e27e | ||
|
|
c0a5abe29c | ||
|
|
bbe30f93f2 | ||
|
|
3bc5c72039 | ||
|
|
203b926be0 | ||
|
|
e64709ea08 | ||
|
|
94d8676db8 | ||
|
|
828bcadf6a | ||
|
|
93366df264 | ||
|
|
aa67096fe8 | ||
|
|
6f72e33de5 | ||
|
|
56d0a0d6ea | ||
|
|
de9eb2cd80 | ||
|
|
76de167171 | ||
|
|
70032aa477 | ||
|
|
16131e5cac | ||
|
|
bfbd136f4b | ||
|
|
fe8d8c8839 | ||
|
|
b8e0e6b01c | ||
|
|
6ea362da0b | ||
|
|
0f78386462 | ||
|
|
1529e3fadd | ||
|
|
31879d26f4 | ||
|
|
efbae9321e | ||
|
|
0599618add | ||
|
|
1d50c12e15 | ||
|
|
3860de0b1e | ||
|
|
15981117ee | ||
|
|
4f8c14646d | ||
|
|
520ec0b79b | ||
|
|
f42cb8557b | ||
|
|
b788a67c52 | ||
|
|
73f8728d22 | ||
|
|
bf6a28bd1e | ||
|
|
1256b24133 | ||
|
|
a559c0505e | ||
|
|
59757249bb | ||
|
|
58b25101e6 | ||
|
|
690a389369 | ||
|
|
1cdd392f96 | ||
|
|
20f231054a | ||
|
|
077c36be8a | ||
|
|
88d81c104e | ||
|
|
8ac8a29fda | ||
|
|
cd2910b0e9 | ||
|
|
167fb61b4e | ||
|
|
188e583dcb | ||
|
|
26e36e1620 | ||
|
|
a016b3f4ea | ||
|
|
9f6c8725ed | ||
|
|
040a7f5c41 | ||
|
|
3585e0cc3e | ||
|
|
ba8370e1ad | ||
|
|
97c4e70847 | ||
|
|
c6302edeca | ||
|
|
0651fff910 | ||
|
|
b36ba8399e | ||
|
|
4629402f38 | ||
|
|
86a260a2c7 | ||
|
|
63626d6fc3 | ||
|
|
0f5b6a07d0 | ||
|
|
7d90a079b0 | ||
|
|
891119470c | ||
|
|
9dea55bd64 | ||
|
|
b4ef969eec | ||
|
|
322c89d982 | ||
|
|
59607f616a | ||
|
|
3f6c7e406a | ||
|
|
fd3d8b67ff | ||
|
|
c73f126b15 | ||
|
|
17d1cf535a | ||
|
|
ae48f65f20 | ||
|
|
0ed3d4de83 | ||
|
|
6c5845721b | ||
|
|
77e7e4ef7b | ||
|
|
f38ab70ba4 | ||
|
|
7aabd6dd5a | ||
|
|
1b12e80882 | ||
|
|
9f685a8cf1 | ||
|
|
57b248f9fe | ||
|
|
278cb7e98c | ||
|
|
2c76da2868 | ||
|
|
c4acce91d6 | ||
|
|
adbcac9319 | ||
|
|
c9a1d06e7c | ||
|
|
25c1a8207f | ||
|
|
0702cb3869 | ||
|
|
03c107a4ce | ||
|
|
c7158b08d1 | ||
|
|
035e6584c7 | ||
|
|
253e97678c | ||
|
|
c7bb1fe52d | ||
|
|
a65e7e9b59 | ||
|
|
b671550c91 | ||
|
|
52bba70fec | ||
|
|
f2ee231f14 | ||
|
|
3861701f4a | ||
|
|
d167134265 | ||
|
|
539be503f0 | ||
|
|
bbf5c41cab | ||
|
|
df3d67a4ed | ||
|
|
82f1c720dd | ||
|
|
77a30ef281 | ||
|
|
383751904c | ||
|
|
6a1f19d314 | ||
|
|
342fe8882a | ||
|
|
7fcca0cc46 | ||
|
|
977f014cba | ||
|
|
753c44b0c4 | ||
|
|
dd0082c343 | ||
|
|
5f6fbaea56 | ||
|
|
6b81b34b27 | ||
|
|
961bbb9460 | ||
|
|
d56e8ee65a | ||
|
|
4527f89d8d | ||
|
|
e535177bc0 | ||
|
|
022d150d20 | ||
|
|
136e5d927c | ||
|
|
1968334b29 | ||
|
|
0b78f31e3a | ||
|
|
56b8c1211a | ||
|
|
3f26dc47f2 | ||
|
|
1b6f723cc3 | ||
|
|
d6cb38289e | ||
|
|
406be36c45 | ||
|
|
6bb761a803 | ||
|
|
a169d42b1f | ||
|
|
4827d6e766 | ||
|
|
2a2db362e3 | ||
|
|
32756dc7b4 | ||
|
|
ee447a2281 | ||
|
|
4d8bb57c8d | ||
|
|
70ba13ca6d | ||
|
|
da23fdc621 | ||
|
|
2ab27c0dfe | ||
|
|
811a704f80 | ||
|
|
99fea33fac | ||
|
|
9d37d705e4 | ||
|
|
fbb290b223 | ||
|
|
c80c940a4f | ||
|
|
f07694ba6c | ||
|
|
9abec18c8b | ||
|
|
1f8d06e075 | ||
|
|
29c94c102b | ||
|
|
3f3e660367 | ||
|
|
2eefaeed14 | ||
|
|
5fadd0de57 | ||
|
|
c5edad2246 | ||
|
|
405bb93030 | ||
|
|
5f79ab87c7 | ||
|
|
4d5022ab94 | ||
|
|
6adaedf696 | ||
|
|
f3ff65f233 | ||
|
|
b5e45b43b9 | ||
|
|
61afdd3df7 | ||
|
|
e8f9e31541 | ||
|
|
38288dd9c8 | ||
|
|
9d8b990fd1 | ||
|
|
0f96f99404 | ||
|
|
57177aebb2 | ||
|
|
2c4fb7a990 | ||
|
|
61a7dd85ca | ||
|
|
a7dd51390c | ||
|
|
a47cedecfa | ||
|
|
566a830f64 | ||
|
|
5c627a3aa3 | ||
|
|
a9dc3794a6 | ||
|
|
d6f169197e | ||
|
|
2bc49149b3 | ||
|
|
bc5922c684 | ||
|
|
f0935fb3e1 | ||
|
|
762686e99e | ||
|
|
0f0527abc1 | ||
|
|
6e26e41519 | ||
|
|
954fc282ee | ||
|
|
9d58a6d457 | ||
|
|
c95ce4ec17 | ||
|
|
9492c2190e | ||
|
|
808f1bcee3 | ||
|
|
3b224b5629 | ||
|
|
424e9a76af | ||
|
|
40e93407c7 | ||
|
|
721aec1cb6 | ||
|
|
8a3ee8f931 | ||
|
|
00fea975e2 | ||
|
|
fd6562382e | ||
|
|
ec90891636 | ||
|
|
7336a48057 | ||
|
|
922478fbda | ||
|
|
9f0eca2343 | ||
|
|
1e11c490a7 | ||
|
|
8a7a8db661 | ||
|
|
0610070e59 | ||
|
|
a0997a0423 | ||
|
|
4ea3eada3e | ||
|
|
cd1c0f3054 | ||
|
|
684350977d | ||
|
|
d28630b759 | ||
|
|
f7fbaf46a2 | ||
|
|
e7cda537e7 | ||
|
|
c7be34fbaa | ||
|
|
52da088011 | ||
|
|
6ac3a6febf | ||
|
|
e36b77ad6d | ||
|
|
6003322711 | ||
|
|
f4ffca01b8 | ||
|
|
5d70c207cd | ||
|
|
0b2e641d00 | ||
|
|
ff84b052a5 | ||
|
|
a43b040ebc | ||
|
|
749fa2507a | ||
|
|
76d61362ee | ||
|
|
c55143bc21 | ||
|
|
7609df3370 | ||
|
|
b57eac12cb | ||
|
|
ac6911d3c4 | ||
|
|
23c2010681 | ||
|
|
01d74d0a87 | ||
|
|
e4fab0ce7f | ||
|
|
76ecaaeb3a | ||
|
|
6dd2f2a9c1 | ||
|
|
a993849928 | ||
|
|
6dbac1f6ae | ||
|
|
c28756c48b | ||
|
|
2414f66e38 | ||
|
|
546b730c9b | ||
|
|
75be54aa89 | ||
|
|
4e9e75f4a0 | ||
|
|
e0779175cf | ||
|
|
1235153b4c | ||
|
|
bf5ce9aa3f | ||
|
|
204992ff6f | ||
|
|
386e288543 | ||
|
|
6f668133ad | ||
|
|
fb625bfa56 | ||
|
|
32cb132712 | ||
|
|
9ca44fa3ab | ||
|
|
2205f4e4e3 | ||
|
|
7cd4373707 | ||
|
|
a2123088bf | ||
|
|
863815153e | ||
|
|
76270c8383 | ||
|
|
58de9c405a | ||
|
|
8f0126f1fe | ||
|
|
ec21898978 | ||
|
|
e61f9b5e88 | ||
|
|
e91efbde01 | ||
|
|
63b6997c83 | ||
|
|
262edc8cc9 | ||
|
|
204b276693 | ||
|
|
f8a2877f24 | ||
|
|
af02bebca9 | ||
|
|
3aaa20908d | ||
|
|
5097665be3 | ||
|
|
09f6e3bde5 | ||
|
|
f488636fb8 | ||
|
|
11cb88c2cd | ||
|
|
16a0486655 | ||
|
|
2454d4d199 | ||
|
|
45dca00dee | ||
|
|
09b2383685 | ||
|
|
f8797a7f70 | ||
|
|
da283b49b8 | ||
|
|
e21e5f609e | ||
|
|
583c946061 | ||
|
|
cca0d9f7d7 | ||
|
|
25a0b184a1 | ||
|
|
ed59145354 | ||
|
|
19adfda3b9 | ||
|
|
fa56bc715e | ||
|
|
350ce66d3c | ||
|
|
1667046f58 | ||
|
|
3f7a508a2e | ||
|
|
f7f5659bca | ||
|
|
57f55190ff | ||
|
|
237550ad57 | ||
|
|
cad67702d6 | ||
|
|
ae678dfaaa | ||
|
|
5ad3960286 | ||
|
|
dbd86be363 | ||
|
|
9f0138e1cf | ||
|
|
097ac06f0b | ||
|
|
0869b1c75c | ||
|
|
527578a147 | ||
|
|
b0c411b22a | ||
|
|
4a1915bec4 | ||
|
|
751027858b | ||
|
|
12bd9c0590 | ||
|
|
1ff940598f | ||
|
|
9d495618d2 | ||
|
|
c6d2690aa3 | ||
|
|
623e44ecf9 | ||
|
|
5c34b6bc47 | ||
|
|
8a36ad5f87 | ||
|
|
6ff95efaf6 | ||
|
|
ba2f1804b0 | ||
|
|
44061326e9 | ||
|
|
0b4c4f1de6 | ||
|
|
9652571437 | ||
|
|
f0f15f89c6 | ||
|
|
075e374b3d | ||
|
|
eaa0dfea4b | ||
|
|
b7956de761 | ||
|
|
a30dbdd724 | ||
|
|
60a829e982 | ||
|
|
74cfa0fc8c | ||
|
|
5071c8f8fa | ||
|
|
0ef0f165cb | ||
|
|
25f313a3ef | ||
|
|
7218947c5b | ||
|
|
0aa5bb3265 | ||
|
|
7591beb65d | ||
|
|
7e9236939f | ||
|
|
e48c0893e7 | ||
|
|
38649b2df0 | ||
|
|
0ff8248f91 | ||
|
|
bf2caf8b1d | ||
|
|
6a6dbc1491 | ||
|
|
244e02c3d5 | ||
|
|
591e4a8f38 | ||
|
|
4bf59cfe51 | ||
|
|
de9d250537 | ||
|
|
3a3a487c71 | ||
|
|
f3c427bdef | ||
|
|
6a0fe94e5c | ||
|
|
1bb2aefec3 | ||
|
|
60a3f1f072 | ||
|
|
c17e96d38b | ||
|
|
fa37036304 | ||
|
|
8140173aa3 | ||
|
|
18a516b87a | ||
|
|
e71aaa66db | ||
|
|
4255d5b28f | ||
|
|
2591b03625 | ||
|
|
11d55bc9fc | ||
|
|
42f001d34c | ||
|
|
4cf722161b | ||
|
|
145fccdd23 | ||
|
|
3e4eda2a80 | ||
|
|
16b08c39e6 | ||
|
|
9b6629054a | ||
|
|
56b2f113ed | ||
|
|
83d37d2bee | ||
|
|
58083bb67b | ||
|
|
f79321ceeb | ||
|
|
05e81c3d88 | ||
|
|
ae83ef02e7 | ||
|
|
91b58a6775 | ||
|
|
8835576374 | ||
|
|
3bc05eaa00 | ||
|
|
693d214166 | ||
|
|
775be27719 | ||
|
|
db709691be | ||
|
|
6a173a9161 | ||
|
|
0c02b08a6a | ||
|
|
58eb481e19 | ||
|
|
002ea535ae | ||
|
|
6f43f2b003 | ||
|
|
ba43f766b8 | ||
|
|
42fea1c568 | ||
|
|
b7baa88010 | ||
|
|
65ec309050 | ||
|
|
f4fb4981f0 | ||
|
|
8ae9375e6b | ||
|
|
012c653432 | ||
|
|
a2f1089038 | ||
|
|
5171d84b8d | ||
|
|
4a269ba039 | ||
|
|
b5f8e9a910 | ||
|
|
0032ed9237 | ||
|
|
89055577e6 | ||
|
|
cc0c2d227e | ||
|
|
ab9a68c784 | ||
|
|
17f5a65a62 | ||
|
|
689ae25ef5 | ||
|
|
b3a3c686bf | ||
|
|
c644e23ca0 | ||
|
|
2b6ee38327 | ||
|
|
7d2191d4e6 | ||
|
|
a7b24ac6a5 | ||
|
|
ff5bc51052 | ||
|
|
f685bf62ab | ||
|
|
066f9e02e2 | ||
|
|
aa36e6a881 | ||
|
|
e835efaa3f |
62
.pre-commit-config.yaml
Normal file
62
.pre-commit-config.yaml
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
---
|
||||||
|
repos:
|
||||||
|
- repo: https://github.com/pre-commit/pre-commit-hooks
|
||||||
|
rev: v5.0.0
|
||||||
|
hooks:
|
||||||
|
# whitespace
|
||||||
|
- id: trailing-whitespace
|
||||||
|
- id: mixed-line-ending
|
||||||
|
args: ['--fix', 'lf']
|
||||||
|
exclude: '.*\.(svg)$'
|
||||||
|
- id: check-byte-order-marker
|
||||||
|
# file format and permissions
|
||||||
|
- id: check-ast
|
||||||
|
- id: debug-statements
|
||||||
|
- id: check-json
|
||||||
|
files: .*\.json$
|
||||||
|
- id: check-yaml
|
||||||
|
files: .*\.(yaml|yml)$
|
||||||
|
- id: check-executables-have-shebangs
|
||||||
|
- id: check-shebang-scripts-are-executable
|
||||||
|
# git
|
||||||
|
- id: check-added-large-files
|
||||||
|
- id: check-case-conflict
|
||||||
|
- id: detect-private-key
|
||||||
|
- id: check-merge-conflict
|
||||||
|
- repo: https://github.com/Lucas-C/pre-commit-hooks
|
||||||
|
rev: v1.5.5
|
||||||
|
hooks:
|
||||||
|
- id: remove-tabs
|
||||||
|
exclude: '.*\.(svg)$'
|
||||||
|
- repo: https://opendev.org/openstack/hacking
|
||||||
|
rev: 7.0.0
|
||||||
|
hooks:
|
||||||
|
- id: hacking
|
||||||
|
additional_dependencies: []
|
||||||
|
exclude: '^(doc|releasenotes|tools)/.*$'
|
||||||
|
- repo: https://github.com/PyCQA/bandit
|
||||||
|
rev: 1.8.3
|
||||||
|
hooks:
|
||||||
|
- id: bandit
|
||||||
|
args: ['-x', 'tests', '-s', 'B101,B311,B320']
|
||||||
|
- repo: https://github.com/hhatto/autopep8
|
||||||
|
rev: v2.3.2
|
||||||
|
hooks:
|
||||||
|
- id: autopep8
|
||||||
|
files: '^.*\.py$'
|
||||||
|
- repo: https://github.com/codespell-project/codespell
|
||||||
|
rev: v2.4.1
|
||||||
|
hooks:
|
||||||
|
- id: codespell
|
||||||
|
args: ['--ignore-words=doc/dictionary.txt']
|
||||||
|
- repo: https://github.com/sphinx-contrib/sphinx-lint
|
||||||
|
rev: v1.0.0
|
||||||
|
hooks:
|
||||||
|
- id: sphinx-lint
|
||||||
|
args: [--enable=default-role]
|
||||||
|
files: ^doc/|^releasenotes/|^api-guide/
|
||||||
|
types: [rst]
|
||||||
|
- repo: https://github.com/PyCQA/doc8
|
||||||
|
rev: v1.1.2
|
||||||
|
hooks:
|
||||||
|
- id: doc8
|
||||||
401
.zuul.yaml
401
.zuul.yaml
@@ -1,109 +1,24 @@
|
|||||||
- project:
|
|
||||||
templates:
|
|
||||||
- check-requirements
|
|
||||||
- openstack-cover-jobs
|
|
||||||
- openstack-lower-constraints-jobs
|
|
||||||
- openstack-python-jobs
|
|
||||||
- openstack-python3-train-jobs
|
|
||||||
- publish-openstack-docs-pti
|
|
||||||
- release-notes-jobs-python3
|
|
||||||
check:
|
|
||||||
jobs:
|
|
||||||
- watcher-tempest-functional
|
|
||||||
- watcher-grenade
|
|
||||||
- watcher-tempest-strategies
|
|
||||||
- watcher-tempest-actuator
|
|
||||||
- watcherclient-tempest-functional
|
|
||||||
- watcher-tls-test
|
|
||||||
- watcher-tempest-functional-ipv6-only
|
|
||||||
gate:
|
|
||||||
queue: watcher
|
|
||||||
jobs:
|
|
||||||
- watcher-tempest-functional
|
|
||||||
- watcher-tempest-functional-ipv6-only
|
|
||||||
|
|
||||||
- job:
|
|
||||||
name: watcher-tempest-dummy_optim
|
|
||||||
parent: watcher-tempest-multinode
|
|
||||||
vars:
|
|
||||||
tempest_test_regex: watcher_tempest_plugin.tests.scenario.test_execute_dummy_optim
|
|
||||||
|
|
||||||
- job:
|
- job:
|
||||||
name: watcher-tempest-actuator
|
name: watcher-tempest-actuator
|
||||||
parent: watcher-tempest-multinode
|
parent: watcher-tempest-multinode
|
||||||
vars:
|
vars:
|
||||||
tempest_test_regex: watcher_tempest_plugin.tests.scenario.test_execute_actuator
|
tempest_test_regex: watcher_tempest_plugin.tests.scenario.test_execute_actuator
|
||||||
|
|
||||||
- job:
|
|
||||||
name: watcher-tempest-basic_optim
|
|
||||||
parent: watcher-tempest-multinode
|
|
||||||
vars:
|
|
||||||
tempest_test_regex: watcher_tempest_plugin.tests.scenario.test_execute_basic_optim
|
|
||||||
|
|
||||||
- job:
|
|
||||||
name: watcher-tempest-vm_workload_consolidation
|
|
||||||
parent: watcher-tempest-multinode
|
|
||||||
vars:
|
|
||||||
tempest_test_regex: watcher_tempest_plugin.tests.scenario.test_execute_vm_workload_consolidation
|
|
||||||
devstack_local_conf:
|
|
||||||
test-config:
|
|
||||||
$WATCHER_CONFIG:
|
|
||||||
watcher_strategies.vm_workload_consolidation:
|
|
||||||
datasource: ceilometer
|
|
||||||
|
|
||||||
- job:
|
|
||||||
name: watcher-tempest-workload_balancing
|
|
||||||
parent: watcher-tempest-multinode
|
|
||||||
vars:
|
|
||||||
tempest_test_regex: watcher_tempest_plugin.tests.scenario.test_execute_workload_balancing
|
|
||||||
|
|
||||||
- job:
|
|
||||||
name: watcher-tempest-zone_migration
|
|
||||||
parent: watcher-tempest-multinode
|
|
||||||
vars:
|
|
||||||
tempest_test_regex: watcher_tempest_plugin.tests.scenario.test_execute_zone_migration
|
|
||||||
|
|
||||||
- job:
|
|
||||||
name: watcher-tempest-host_maintenance
|
|
||||||
parent: watcher-tempest-multinode
|
|
||||||
vars:
|
|
||||||
tempest_test_regex: watcher_tempest_plugin.tests.scenario.test_execute_host_maintenance
|
|
||||||
|
|
||||||
- job:
|
|
||||||
name: watcher-tempest-storage_balance
|
|
||||||
parent: watcher-tempest-multinode
|
|
||||||
vars:
|
|
||||||
tempest_test_regex: watcher_tempest_plugin.tests.scenario.test_execute_storage_balance
|
|
||||||
devstack_local_conf:
|
|
||||||
test-config:
|
|
||||||
$TEMPEST_CONFIG:
|
|
||||||
volume:
|
|
||||||
backend_names: ['BACKEND_1', 'BACKEND_2']
|
|
||||||
volume-feature-enabled:
|
|
||||||
multi_backend: true
|
|
||||||
|
|
||||||
- job:
|
- job:
|
||||||
name: watcher-tempest-strategies
|
name: watcher-tempest-strategies
|
||||||
parent: watcher-tempest-multinode
|
parent: watcher-tempest-multinode
|
||||||
vars:
|
vars:
|
||||||
tempest_concurrency: 1
|
tempest_concurrency: 1
|
||||||
tempest_test_regex: watcher_tempest_plugin.tests.scenario.test_execute_strategies
|
# All tests inside watcher_tempest_plugin.tests.scenario with tag "strategy"
|
||||||
|
# or test_execute_strategies file
|
||||||
- job:
|
# excluding tests with tag "real_load"
|
||||||
name: watcher-tls-test
|
tempest_test_regex: (^watcher_tempest_plugin.tests.scenario)(.*\[.*\bstrategy\b.*\].*)|(^watcher_tempest_plugin.tests.scenario.test_execute_strategies)
|
||||||
parent: watcher-tempest-multinode
|
tempest_exclude_regex: .*\[.*\breal_load\b.*\].*
|
||||||
group-vars:
|
|
||||||
subnode:
|
|
||||||
devstack_services:
|
|
||||||
tls-proxy: true
|
|
||||||
vars:
|
|
||||||
devstack_services:
|
|
||||||
tls-proxy: true
|
|
||||||
|
|
||||||
- job:
|
- job:
|
||||||
name: watcher-tempest-multinode
|
name: watcher-tempest-multinode
|
||||||
parent: watcher-tempest-functional
|
parent: watcher-tempest-functional
|
||||||
nodeset: openstack-two-node-bionic
|
nodeset: openstack-two-node-noble
|
||||||
roles:
|
roles:
|
||||||
- zuul: openstack/tempest
|
- zuul: openstack/tempest
|
||||||
group-vars:
|
group-vars:
|
||||||
@@ -117,12 +32,16 @@
|
|||||||
period: 120
|
period: 120
|
||||||
watcher_cluster_data_model_collectors.storage:
|
watcher_cluster_data_model_collectors.storage:
|
||||||
period: 120
|
period: 120
|
||||||
|
$CINDER_CONF:
|
||||||
|
# enable notifications in compute node, by default they are only
|
||||||
|
# configured in the controller
|
||||||
|
oslo_messaging_notifications:
|
||||||
|
driver: messagingv2
|
||||||
devstack_services:
|
devstack_services:
|
||||||
watcher-api: false
|
watcher-api: false
|
||||||
watcher-decision-engine: true
|
watcher-decision-engine: true
|
||||||
watcher-applier: false
|
watcher-applier: false
|
||||||
# We need to add TLS support for watcher plugin
|
c-bak: false
|
||||||
tls-proxy: false
|
|
||||||
ceilometer: false
|
ceilometer: false
|
||||||
ceilometer-acompute: false
|
ceilometer-acompute: false
|
||||||
ceilometer-acentral: false
|
ceilometer-acentral: false
|
||||||
@@ -133,6 +52,13 @@
|
|||||||
rabbit: false
|
rabbit: false
|
||||||
mysql: false
|
mysql: false
|
||||||
vars:
|
vars:
|
||||||
|
devstack_localrc:
|
||||||
|
GNOCCHI_ARCHIVE_POLICY_TEMPEST: "ceilometer-low-rate"
|
||||||
|
CEILOMETER_PIPELINE_INTERVAL: 15
|
||||||
|
devstack_services:
|
||||||
|
ceilometer-acompute: false
|
||||||
|
ceilometer-acentral: true
|
||||||
|
ceilometer-anotification: true
|
||||||
devstack_local_conf:
|
devstack_local_conf:
|
||||||
post-config:
|
post-config:
|
||||||
$WATCHER_CONF:
|
$WATCHER_CONF:
|
||||||
@@ -142,6 +68,11 @@
|
|||||||
period: 120
|
period: 120
|
||||||
watcher_cluster_data_model_collectors.storage:
|
watcher_cluster_data_model_collectors.storage:
|
||||||
period: 120
|
period: 120
|
||||||
|
$CINDER_CONF:
|
||||||
|
# enable notifications in compute node, by default they are only
|
||||||
|
# configured in the controller
|
||||||
|
oslo_messaging_notifications:
|
||||||
|
driver: messagingv2
|
||||||
test-config:
|
test-config:
|
||||||
$TEMPEST_CONFIG:
|
$TEMPEST_CONFIG:
|
||||||
compute:
|
compute:
|
||||||
@@ -152,6 +83,10 @@
|
|||||||
block_migration_for_live_migration: true
|
block_migration_for_live_migration: true
|
||||||
placement:
|
placement:
|
||||||
min_microversion: 1.29
|
min_microversion: 1.29
|
||||||
|
telemetry:
|
||||||
|
ceilometer_polling_interval: 15
|
||||||
|
optimize:
|
||||||
|
run_continuous_audit_tests: true
|
||||||
devstack_plugins:
|
devstack_plugins:
|
||||||
ceilometer: https://opendev.org/openstack/ceilometer
|
ceilometer: https://opendev.org/openstack/ceilometer
|
||||||
|
|
||||||
@@ -161,7 +96,6 @@
|
|||||||
timeout: 7200
|
timeout: 7200
|
||||||
required-projects: &base_required_projects
|
required-projects: &base_required_projects
|
||||||
- openstack/ceilometer
|
- openstack/ceilometer
|
||||||
- openstack/devstack-gate
|
|
||||||
- openstack/python-openstackclient
|
- openstack/python-openstackclient
|
||||||
- openstack/python-watcherclient
|
- openstack/python-watcherclient
|
||||||
- openstack/watcher
|
- openstack/watcher
|
||||||
@@ -171,7 +105,6 @@
|
|||||||
devstack_plugins:
|
devstack_plugins:
|
||||||
watcher: https://opendev.org/openstack/watcher
|
watcher: https://opendev.org/openstack/watcher
|
||||||
devstack_services:
|
devstack_services:
|
||||||
tls-proxy: false
|
|
||||||
watcher-api: true
|
watcher-api: true
|
||||||
watcher-decision-engine: true
|
watcher-decision-engine: true
|
||||||
watcher-applier: true
|
watcher-applier: true
|
||||||
@@ -180,13 +113,10 @@
|
|||||||
s-container: false
|
s-container: false
|
||||||
s-object: false
|
s-object: false
|
||||||
s-proxy: false
|
s-proxy: false
|
||||||
devstack_localrc:
|
tempest_plugins:
|
||||||
TEMPEST_PLUGINS: /opt/stack/watcher-tempest-plugin
|
- watcher-tempest-plugin
|
||||||
tempest_test_regex: watcher_tempest_plugin.tests.api
|
tempest_test_regex: watcher_tempest_plugin.tests.api
|
||||||
tox_envlist: all
|
tox_envlist: all
|
||||||
tox_environment:
|
|
||||||
# Do we really need to set this? It's cargo culted
|
|
||||||
PYTHONUNBUFFERED: 'true'
|
|
||||||
zuul_copy_output:
|
zuul_copy_output:
|
||||||
/etc/hosts: logs
|
/etc/hosts: logs
|
||||||
|
|
||||||
@@ -200,11 +130,13 @@
|
|||||||
|
|
||||||
- job:
|
- job:
|
||||||
name: watcher-grenade
|
name: watcher-grenade
|
||||||
parent: legacy-dsvm-base
|
parent: grenade
|
||||||
timeout: 10800
|
required-projects:
|
||||||
run: playbooks/legacy/grenade-devstack-watcher/run.yaml
|
- openstack/watcher
|
||||||
post-run: playbooks/legacy/grenade-devstack-watcher/post.yaml
|
- openstack/python-watcherclient
|
||||||
irrelevant-files:
|
- openstack/watcher-tempest-plugin
|
||||||
|
vars: *base_vars
|
||||||
|
irrelevant-files: &irrelevent_files
|
||||||
- ^(test-|)requirements.txt$
|
- ^(test-|)requirements.txt$
|
||||||
- ^.*\.rst$
|
- ^.*\.rst$
|
||||||
- ^api-ref/.*$
|
- ^api-ref/.*$
|
||||||
@@ -215,18 +147,259 @@
|
|||||||
- ^setup.cfg$
|
- ^setup.cfg$
|
||||||
- ^tools/.*$
|
- ^tools/.*$
|
||||||
- ^tox.ini$
|
- ^tox.ini$
|
||||||
required-projects:
|
|
||||||
- openstack/grenade
|
- job:
|
||||||
- openstack/devstack-gate
|
name: watcher-sg-core-tempest-base
|
||||||
|
parent: devstack-tempest
|
||||||
|
nodeset: openstack-two-node-noble
|
||||||
|
description: |
|
||||||
|
This job is for testing watcher and sg-core/prometheus installation
|
||||||
|
abstract: true
|
||||||
|
pre-run:
|
||||||
|
- playbooks/generate_prometheus_config.yml
|
||||||
|
irrelevant-files: *irrelevent_files
|
||||||
|
timeout: 7800
|
||||||
|
required-projects: &base_sg_required_projects
|
||||||
|
- openstack/aodh
|
||||||
|
- openstack/ceilometer
|
||||||
|
- openstack/tempest
|
||||||
|
- openstack-k8s-operators/sg-core
|
||||||
- openstack/watcher
|
- openstack/watcher
|
||||||
- openstack/python-watcherclient
|
- openstack/python-watcherclient
|
||||||
- openstack/watcher-tempest-plugin
|
- openstack/watcher-tempest-plugin
|
||||||
|
- openstack/devstack-plugin-prometheus
|
||||||
|
vars:
|
||||||
|
configure_swap_size: 8192
|
||||||
|
devstack_plugins:
|
||||||
|
ceilometer: https://opendev.org/openstack/ceilometer
|
||||||
|
aodh: https://opendev.org/openstack/aodh
|
||||||
|
sg-core: https://github.com/openstack-k8s-operators/sg-core
|
||||||
|
watcher: https://opendev.org/openstack/watcher
|
||||||
|
devstack-plugin-prometheus: https://opendev.org/openstack/devstack-plugin-prometheus
|
||||||
|
devstack_services:
|
||||||
|
ceilometer-acompute: true
|
||||||
|
watcher-api: true
|
||||||
|
watcher-decision-engine: true
|
||||||
|
watcher-applier: true
|
||||||
|
tempest: true
|
||||||
|
# We do not need Swift in this job so disable it for speed
|
||||||
|
# Swift services
|
||||||
|
s-account: false
|
||||||
|
s-container: false
|
||||||
|
s-object: false
|
||||||
|
s-proxy: false
|
||||||
|
# Prometheus related service
|
||||||
|
prometheus: true
|
||||||
|
node_exporter: true
|
||||||
|
devstack_localrc:
|
||||||
|
CEILOMETER_BACKENDS: "sg-core"
|
||||||
|
CEILOMETER_PIPELINE_INTERVAL: 15
|
||||||
|
CEILOMETER_ALARM_THRESHOLD: 6000000000
|
||||||
|
PROMETHEUS_CONFIG_FILE: "/home/zuul/prometheus.yml"
|
||||||
|
devstack_local_conf:
|
||||||
|
post-config:
|
||||||
|
$WATCHER_CONF:
|
||||||
|
watcher_datasources:
|
||||||
|
datasources: prometheus
|
||||||
|
prometheus_client:
|
||||||
|
host: 127.0.0.1
|
||||||
|
port: 9090
|
||||||
|
watcher_cluster_data_model_collectors.compute:
|
||||||
|
period: 120
|
||||||
|
watcher_cluster_data_model_collectors.baremetal:
|
||||||
|
period: 120
|
||||||
|
watcher_cluster_data_model_collectors.storage:
|
||||||
|
period: 120
|
||||||
|
compute_model:
|
||||||
|
enable_extended_attributes: true
|
||||||
|
nova_client:
|
||||||
|
api_version: "2.96"
|
||||||
|
test-config:
|
||||||
|
$TEMPEST_CONFIG:
|
||||||
|
compute:
|
||||||
|
min_compute_nodes: 2
|
||||||
|
min_microversion: 2.56
|
||||||
|
compute-feature-enabled:
|
||||||
|
live_migration: true
|
||||||
|
block_migration_for_live_migration: true
|
||||||
|
placement:
|
||||||
|
min_microversion: 1.29
|
||||||
|
service_available:
|
||||||
|
sg_core: True
|
||||||
|
telemetry_services:
|
||||||
|
metric_backends: prometheus
|
||||||
|
telemetry:
|
||||||
|
disable_ssl_certificate_validation: True
|
||||||
|
ceilometer_polling_interval: 15
|
||||||
|
optimize:
|
||||||
|
datasource: prometheus
|
||||||
|
extended_attributes_nova_microversion: "2.96"
|
||||||
|
data_model_collectors_period: 120
|
||||||
|
run_continuous_audit_tests: true
|
||||||
|
tempest_plugins:
|
||||||
|
- watcher-tempest-plugin
|
||||||
|
# All tests inside watcher_tempest_plugin.tests.scenario with tag "strategy"
|
||||||
|
# and test_execute_strategies, test_data_model files
|
||||||
|
# excluding tests with tag "real_load"
|
||||||
|
tempest_test_regex: (watcher_tempest_plugin.tests.scenario)(.*\[.*\bstrategy\b.*\].*)|(watcher_tempest_plugin.tests.scenario.(test_execute_strategies|test_data_model))
|
||||||
|
tempest_exclude_regex: .*\[.*\breal_load\b.*\].*
|
||||||
|
tempest_concurrency: 1
|
||||||
|
tox_envlist: all
|
||||||
|
zuul_copy_output:
|
||||||
|
/etc/prometheus/prometheus.yml: logs
|
||||||
|
group-vars:
|
||||||
|
subnode:
|
||||||
|
devstack_plugins:
|
||||||
|
ceilometer: https://opendev.org/openstack/ceilometer
|
||||||
|
devstack-plugin-prometheus: https://opendev.org/openstack/devstack-plugin-prometheus
|
||||||
|
devstack_services:
|
||||||
|
ceilometer-acompute: true
|
||||||
|
sg-core: false
|
||||||
|
prometheus: false
|
||||||
|
node_exporter: true
|
||||||
|
devstack_localrc:
|
||||||
|
CEILOMETER_BACKEND: "none"
|
||||||
|
CEILOMETER_BACKENDS: "none"
|
||||||
|
devstack_local_conf:
|
||||||
|
post-config:
|
||||||
|
$WATCHER_CONF:
|
||||||
|
watcher_cluster_data_model_collectors.compute:
|
||||||
|
period: 120
|
||||||
|
watcher_cluster_data_model_collectors.baremetal:
|
||||||
|
period: 120
|
||||||
|
watcher_cluster_data_model_collectors.storage:
|
||||||
|
period: 120
|
||||||
|
|
||||||
- job:
|
- job:
|
||||||
# This job is used in python-watcherclient repo
|
name: watcher-prometheus-integration
|
||||||
name: watcherclient-tempest-functional
|
parent: watcher-sg-core-tempest-base
|
||||||
parent: watcher-tempest-functional
|
|
||||||
timeout: 4200
|
|
||||||
vars:
|
vars:
|
||||||
tempest_concurrency: 1
|
devstack_services:
|
||||||
tempest_test_regex: watcher_tempest_plugin.tests.client_functional
|
ceilometer-acompute: false
|
||||||
|
node_exporter: false
|
||||||
|
group-vars:
|
||||||
|
subnode:
|
||||||
|
devstack_services:
|
||||||
|
ceilometer-acompute: false
|
||||||
|
node_exporter: false
|
||||||
|
|
||||||
|
- job:
|
||||||
|
name: watcher-aetos-integration
|
||||||
|
parent: watcher-sg-core-tempest-base
|
||||||
|
description: |
|
||||||
|
This job tests Watcher with Aetos reverse-proxy for Prometheus
|
||||||
|
using Keystone authentication instead of direct Prometheus access.
|
||||||
|
required-projects:
|
||||||
|
- openstack/python-observabilityclient
|
||||||
|
- openstack/aetos
|
||||||
|
vars: &aetos_vars
|
||||||
|
devstack_services:
|
||||||
|
ceilometer-acompute: false
|
||||||
|
node_exporter: false
|
||||||
|
devstack_plugins:
|
||||||
|
ceilometer: https://opendev.org/openstack/ceilometer
|
||||||
|
sg-core: https://github.com/openstack-k8s-operators/sg-core
|
||||||
|
watcher: https://opendev.org/openstack/watcher
|
||||||
|
devstack-plugin-prometheus: https://opendev.org/openstack/devstack-plugin-prometheus
|
||||||
|
aetos: https://opendev.org/openstack/aetos
|
||||||
|
devstack_local_conf:
|
||||||
|
post-config:
|
||||||
|
$WATCHER_CONF:
|
||||||
|
watcher_datasources:
|
||||||
|
datasources: aetos
|
||||||
|
aetos_client:
|
||||||
|
interface: public
|
||||||
|
region_name: RegionOne
|
||||||
|
fqdn_label: fqdn
|
||||||
|
instance_uuid_label: resource
|
||||||
|
test-config:
|
||||||
|
$TEMPEST_CONFIG:
|
||||||
|
optimize:
|
||||||
|
datasource: prometheus
|
||||||
|
group-vars:
|
||||||
|
subnode:
|
||||||
|
devstack_services:
|
||||||
|
ceilometer-acompute: false
|
||||||
|
node_exporter: false
|
||||||
|
|
||||||
|
- job:
|
||||||
|
name: watcher-prometheus-integration-realdata
|
||||||
|
parent: watcher-sg-core-tempest-base
|
||||||
|
vars: &realdata_vars
|
||||||
|
devstack_services:
|
||||||
|
ceilometer-acompute: true
|
||||||
|
node_exporter: true
|
||||||
|
devstack_localrc:
|
||||||
|
NODE_EXPORTER_COLLECTOR_EXCLUDE: ""
|
||||||
|
devstack_local_conf:
|
||||||
|
test-config:
|
||||||
|
$TEMPEST_CONFIG:
|
||||||
|
optimize:
|
||||||
|
datasource: ""
|
||||||
|
real_workload_period: 300
|
||||||
|
# All tests inside watcher_tempest_plugin.tests.scenario with tag "real_load"
|
||||||
|
tempest_test_regex: (^watcher_tempest_plugin.tests.scenario)(.*\[.*\breal_load\b.*\].*)
|
||||||
|
tempest_exclude_regex: ""
|
||||||
|
group-vars: &realdata_group_vars
|
||||||
|
subnode:
|
||||||
|
devstack_services:
|
||||||
|
ceilometer-acompute: true
|
||||||
|
node_exporter: true
|
||||||
|
devstack_localrc:
|
||||||
|
NODE_EXPORTER_COLLECTOR_EXCLUDE: ""
|
||||||
|
|
||||||
|
- job:
|
||||||
|
name: watcher-prometheus-integration-threading
|
||||||
|
parent: watcher-prometheus-integration
|
||||||
|
vars:
|
||||||
|
devstack_localrc:
|
||||||
|
'SYSTEMD_ENV_VARS["watcher-decision-engine"]': OS_WATCHER_DISABLE_EVENTLET_PATCHING=true
|
||||||
|
|
||||||
|
- job:
|
||||||
|
name: openstack-tox-py312-threading
|
||||||
|
parent: openstack-tox-py312
|
||||||
|
description: |
|
||||||
|
Run tox with the py3-threading environment.
|
||||||
|
vars:
|
||||||
|
tox_envlist: py3-threading
|
||||||
|
|
||||||
|
- job:
|
||||||
|
name: watcher-aetos-integration-realdata
|
||||||
|
parent: watcher-aetos-integration
|
||||||
|
vars: *realdata_vars
|
||||||
|
group-vars: *realdata_group_vars
|
||||||
|
|
||||||
|
- project:
|
||||||
|
queue: watcher
|
||||||
|
templates:
|
||||||
|
- check-requirements
|
||||||
|
- openstack-cover-jobs
|
||||||
|
- openstack-python3-jobs
|
||||||
|
- publish-openstack-docs-pti
|
||||||
|
- release-notes-jobs-python3
|
||||||
|
check:
|
||||||
|
jobs:
|
||||||
|
- openstack-tox-py312-threading
|
||||||
|
- watcher-tempest-functional
|
||||||
|
- watcher-grenade
|
||||||
|
- watcher-tempest-strategies
|
||||||
|
- watcher-tempest-actuator
|
||||||
|
- python-watcherclient-functional:
|
||||||
|
files:
|
||||||
|
- ^watcher/api/*
|
||||||
|
- watcher-tempest-functional-ipv6-only
|
||||||
|
- watcher-prometheus-integration
|
||||||
|
- watcher-prometheus-integration-threading
|
||||||
|
- watcher-aetos-integration
|
||||||
|
gate:
|
||||||
|
jobs:
|
||||||
|
- watcher-tempest-functional
|
||||||
|
- watcher-tempest-functional-ipv6-only
|
||||||
|
experimental:
|
||||||
|
jobs:
|
||||||
|
- watcher-prometheus-integration-realdata
|
||||||
|
- watcher-aetos-integration-realdata
|
||||||
|
periodic-weekly:
|
||||||
|
jobs:
|
||||||
|
- watcher-prometheus-integration-realdata
|
||||||
|
- watcher-aetos-integration-realdata
|
||||||
|
|||||||
10
README.rst
10
README.rst
@@ -1,6 +1,6 @@
|
|||||||
========================
|
=======
|
||||||
Team and repository tags
|
Watcher
|
||||||
========================
|
=======
|
||||||
|
|
||||||
.. image:: https://governance.openstack.org/tc/badges/watcher.svg
|
.. image:: https://governance.openstack.org/tc/badges/watcher.svg
|
||||||
:target: https://governance.openstack.org/tc/reference/tags/index.html
|
:target: https://governance.openstack.org/tc/reference/tags/index.html
|
||||||
@@ -13,10 +13,6 @@ Team and repository tags
|
|||||||
|
|
||||||
https://creativecommons.org/licenses/by/3.0/
|
https://creativecommons.org/licenses/by/3.0/
|
||||||
|
|
||||||
=======
|
|
||||||
Watcher
|
|
||||||
=======
|
|
||||||
|
|
||||||
OpenStack Watcher provides a flexible and scalable resource optimization
|
OpenStack Watcher provides a flexible and scalable resource optimization
|
||||||
service for multi-tenant OpenStack-based clouds.
|
service for multi-tenant OpenStack-based clouds.
|
||||||
Watcher provides a robust framework to realize a wide range of cloud
|
Watcher provides a robust framework to realize a wide range of cloud
|
||||||
|
|||||||
@@ -22,9 +22,6 @@
|
|||||||
# All configuration values have a default; values that are commented out
|
# All configuration values have a default; values that are commented out
|
||||||
# serve to show the default.
|
# serve to show the default.
|
||||||
|
|
||||||
from watcher import version as watcher_version
|
|
||||||
|
|
||||||
|
|
||||||
extensions = [
|
extensions = [
|
||||||
'openstackdocstheme',
|
'openstackdocstheme',
|
||||||
'os_api_ref',
|
'os_api_ref',
|
||||||
@@ -46,21 +43,13 @@ project = u'Infrastructure Optimization API Reference'
|
|||||||
copyright = u'2010-present, OpenStack Foundation'
|
copyright = u'2010-present, OpenStack Foundation'
|
||||||
|
|
||||||
# openstackdocstheme options
|
# openstackdocstheme options
|
||||||
repository_name = 'openstack/watcher'
|
openstackdocs_repo_name = 'openstack/watcher'
|
||||||
bug_project = 'watcher'
|
openstackdocs_auto_name = False
|
||||||
bug_tag = ''
|
openstackdocs_bug_project = 'watcher'
|
||||||
|
openstackdocs_bug_tag = ''
|
||||||
# The version info for the project you're documenting, acts as replacement for
|
|
||||||
# |version| and |release|, also used in various other places throughout the
|
|
||||||
# built documents.
|
|
||||||
#
|
|
||||||
# The full version, including alpha/beta/rc tags.
|
|
||||||
release = watcher_version.version_info.release_string()
|
|
||||||
# The short X.Y version.
|
|
||||||
version = watcher_version.version_string
|
|
||||||
|
|
||||||
# The name of the Pygments (syntax highlighting) style to use.
|
# The name of the Pygments (syntax highlighting) style to use.
|
||||||
pygments_style = 'sphinx'
|
pygments_style = 'native'
|
||||||
|
|
||||||
# -- Options for HTML output --------------------------------------------------
|
# -- Options for HTML output --------------------------------------------------
|
||||||
|
|
||||||
@@ -75,10 +64,6 @@ html_theme_options = {
|
|||||||
"sidebar_mode": "toc",
|
"sidebar_mode": "toc",
|
||||||
}
|
}
|
||||||
|
|
||||||
# If not '', a 'Last updated on:' timestamp is inserted at every page bottom,
|
|
||||||
# using the given strftime format.
|
|
||||||
html_last_updated_fmt = '%Y-%m-%d %H:%M'
|
|
||||||
|
|
||||||
# -- Options for LaTeX output -------------------------------------------------
|
# -- Options for LaTeX output -------------------------------------------------
|
||||||
|
|
||||||
# Grouping the document tree into LaTeX files. List of tuples
|
# Grouping the document tree into LaTeX files. List of tuples
|
||||||
|
|||||||
@@ -16,3 +16,4 @@ Watcher API
|
|||||||
.. include:: watcher-api-v1-services.inc
|
.. include:: watcher-api-v1-services.inc
|
||||||
.. include:: watcher-api-v1-scoring_engines.inc
|
.. include:: watcher-api-v1-scoring_engines.inc
|
||||||
.. include:: watcher-api-v1-datamodel.inc
|
.. include:: watcher-api-v1-datamodel.inc
|
||||||
|
.. include:: watcher-api-v1-webhooks.inc
|
||||||
|
|||||||
@@ -189,6 +189,16 @@ action_state:
|
|||||||
in: body
|
in: body
|
||||||
required: true
|
required: true
|
||||||
type: string
|
type: string
|
||||||
|
action_status_message:
|
||||||
|
description: |
|
||||||
|
Message with additional information about the Action state.
|
||||||
|
This field can be set when transitioning an action to SKIPPED state,
|
||||||
|
or updated for actions that are already in SKIPPED state to provide
|
||||||
|
more detailed explanations, fix typos, or expand on initial reasons.
|
||||||
|
in: body
|
||||||
|
required: false
|
||||||
|
type: string
|
||||||
|
min_version: 1.5
|
||||||
action_type:
|
action_type:
|
||||||
description: |
|
description: |
|
||||||
Action type based on specific API action. Actions in Watcher are
|
Action type based on specific API action. Actions in Watcher are
|
||||||
@@ -230,6 +240,13 @@ actionplan_state:
|
|||||||
in: body
|
in: body
|
||||||
required: false
|
required: false
|
||||||
type: string
|
type: string
|
||||||
|
actionplan_status_message:
|
||||||
|
description: |
|
||||||
|
Message with additional information about the Action Plan state.
|
||||||
|
in: body
|
||||||
|
required: false
|
||||||
|
type: string
|
||||||
|
min_version: 1.5
|
||||||
|
|
||||||
# Audit
|
# Audit
|
||||||
audit_autotrigger:
|
audit_autotrigger:
|
||||||
@@ -320,6 +337,13 @@ audit_state:
|
|||||||
in: body
|
in: body
|
||||||
required: true
|
required: true
|
||||||
type: string
|
type: string
|
||||||
|
audit_status_message:
|
||||||
|
description: |
|
||||||
|
Message with additional information about the Audit state.
|
||||||
|
in: body
|
||||||
|
required: false
|
||||||
|
type: string
|
||||||
|
min_version: 1.5
|
||||||
audit_strategy:
|
audit_strategy:
|
||||||
description: |
|
description: |
|
||||||
The UUID or name of the Strategy.
|
The UUID or name of the Strategy.
|
||||||
@@ -420,12 +444,24 @@ links:
|
|||||||
type: array
|
type: array
|
||||||
|
|
||||||
# Data Model Node
|
# Data Model Node
|
||||||
|
node_disabled_reason:
|
||||||
|
description: |
|
||||||
|
The Disabled Reason of the node.
|
||||||
|
in: body
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
node_disk:
|
node_disk:
|
||||||
description: |
|
description: |
|
||||||
The Disk of the node(in GiB).
|
The Disk of the node(in GiB).
|
||||||
in: body
|
in: body
|
||||||
required: true
|
required: true
|
||||||
type: integer
|
type: integer
|
||||||
|
node_disk_gb_reserved:
|
||||||
|
description: |
|
||||||
|
The Disk Reserved of the node (in GiB).
|
||||||
|
in: body
|
||||||
|
required: true
|
||||||
|
type: integer
|
||||||
node_disk_ratio:
|
node_disk_ratio:
|
||||||
description: |
|
description: |
|
||||||
The Disk Ratio of the node.
|
The Disk Ratio of the node.
|
||||||
@@ -444,6 +480,12 @@ node_memory:
|
|||||||
in: body
|
in: body
|
||||||
required: true
|
required: true
|
||||||
type: integer
|
type: integer
|
||||||
|
node_memory_mb_reserved:
|
||||||
|
description: |
|
||||||
|
The Memory Reserved of the node(in MiB).
|
||||||
|
in: body
|
||||||
|
required: true
|
||||||
|
type: integer
|
||||||
node_memory_ratio:
|
node_memory_ratio:
|
||||||
description: |
|
description: |
|
||||||
The Memory Ratio of the node.
|
The Memory Ratio of the node.
|
||||||
@@ -456,6 +498,12 @@ node_state:
|
|||||||
in: body
|
in: body
|
||||||
required: true
|
required: true
|
||||||
type: string
|
type: string
|
||||||
|
node_status:
|
||||||
|
description: |
|
||||||
|
The Status of the node.
|
||||||
|
in: body
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
node_uuid:
|
node_uuid:
|
||||||
description: |
|
description: |
|
||||||
The Unique UUID of the node.
|
The Unique UUID of the node.
|
||||||
@@ -468,13 +516,18 @@ node_vcpu_ratio:
|
|||||||
in: body
|
in: body
|
||||||
required: true
|
required: true
|
||||||
type: float
|
type: float
|
||||||
|
node_vcpu_reserved:
|
||||||
|
description: |
|
||||||
|
The Vcpu Reserved of the node.
|
||||||
|
in: body
|
||||||
|
required: true
|
||||||
|
type: integer
|
||||||
node_vcpus:
|
node_vcpus:
|
||||||
description: |
|
description: |
|
||||||
The Vcpu of the node.
|
The Vcpu of the node.
|
||||||
in: body
|
in: body
|
||||||
required: true
|
required: true
|
||||||
type: integer
|
type: integer
|
||||||
|
|
||||||
# Scoring Engine
|
# Scoring Engine
|
||||||
scoring_engine_description:
|
scoring_engine_description:
|
||||||
description: |
|
description: |
|
||||||
@@ -502,18 +555,50 @@ server_disk:
|
|||||||
in: body
|
in: body
|
||||||
required: true
|
required: true
|
||||||
type: integer
|
type: integer
|
||||||
|
server_flavor_extra_specs:
|
||||||
|
description: |
|
||||||
|
The flavor extra specs of the server.
|
||||||
|
in: body
|
||||||
|
required: true
|
||||||
|
type: JSON
|
||||||
|
min_version: 1.6
|
||||||
|
server_locked:
|
||||||
|
description: |
|
||||||
|
Whether the server is locked.
|
||||||
|
in: body
|
||||||
|
required: true
|
||||||
|
type: boolean
|
||||||
server_memory:
|
server_memory:
|
||||||
description: |
|
description: |
|
||||||
The Memory of server.
|
The Memory of server.
|
||||||
in: body
|
in: body
|
||||||
required: true
|
required: true
|
||||||
type: integer
|
type: integer
|
||||||
|
server_metadata:
|
||||||
|
description: |
|
||||||
|
The metadata associated with the server.
|
||||||
|
in: body
|
||||||
|
required: true
|
||||||
|
type: JSON
|
||||||
server_name:
|
server_name:
|
||||||
description: |
|
description: |
|
||||||
The Name of the server.
|
The Name of the server.
|
||||||
in: body
|
in: body
|
||||||
required: true
|
required: true
|
||||||
type: string
|
type: string
|
||||||
|
server_pinned_az:
|
||||||
|
description: |
|
||||||
|
The pinned availability zone of the server.
|
||||||
|
in: body
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
|
min_version: 1.6
|
||||||
|
server_project_id:
|
||||||
|
description: |
|
||||||
|
The project ID of the server.
|
||||||
|
in: body
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
server_state:
|
server_state:
|
||||||
description: |
|
description: |
|
||||||
The State of the server.
|
The State of the server.
|
||||||
@@ -532,6 +617,12 @@ server_vcpus:
|
|||||||
in: body
|
in: body
|
||||||
required: true
|
required: true
|
||||||
type: integer
|
type: integer
|
||||||
|
server_watcher_exclude:
|
||||||
|
description: |
|
||||||
|
Whether the server is excluded from the scope.
|
||||||
|
in: body
|
||||||
|
required: true
|
||||||
|
type: boolean
|
||||||
# Service
|
# Service
|
||||||
service_host:
|
service_host:
|
||||||
description: |
|
description: |
|
||||||
|
|||||||
12
api-ref/source/samples/action-skip-request-with-message.json
Normal file
12
api-ref/source/samples/action-skip-request-with-message.json
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
[
|
||||||
|
{
|
||||||
|
"op": "replace",
|
||||||
|
"value": "SKIPPED",
|
||||||
|
"path": "/state"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"op": "replace",
|
||||||
|
"value": "Skipping due to maintenance window",
|
||||||
|
"path": "/status_message"
|
||||||
|
}
|
||||||
|
]
|
||||||
7
api-ref/source/samples/action-skip-request.json
Normal file
7
api-ref/source/samples/action-skip-request.json
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
[
|
||||||
|
{
|
||||||
|
"op": "replace",
|
||||||
|
"value": "SKIPPED",
|
||||||
|
"path": "/state"
|
||||||
|
}
|
||||||
|
]
|
||||||
29
api-ref/source/samples/action-skip-response.json
Normal file
29
api-ref/source/samples/action-skip-response.json
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
{
|
||||||
|
"state": "SKIPPED",
|
||||||
|
"description": "Migrate instance to another compute node",
|
||||||
|
"parents": [
|
||||||
|
"b4529294-1de6-4302-b57a-9b5d5dc363c6"
|
||||||
|
],
|
||||||
|
"links": [
|
||||||
|
{
|
||||||
|
"rel": "self",
|
||||||
|
"href": "http://controller:9322/v1/actions/54acc7a0-91b0-46ea-a5f7-4ae2b9df0b0a"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"rel": "bookmark",
|
||||||
|
"href": "http://controller:9322/actions/54acc7a0-91b0-46ea-a5f7-4ae2b9df0b0a"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"action_plan_uuid": "4cbc4ede-0d25-481b-b86e-998dbbd4f8bf",
|
||||||
|
"uuid": "54acc7a0-91b0-46ea-a5f7-4ae2b9df0b0a",
|
||||||
|
"deleted_at": null,
|
||||||
|
"updated_at": "2018-04-10T12:15:44.026973+00:00",
|
||||||
|
"input_parameters": {
|
||||||
|
"migration_type": "live",
|
||||||
|
"destination_node": "compute-2",
|
||||||
|
"resource_id": "a1b2c3d4-e5f6-7890-1234-567890abcdef"
|
||||||
|
},
|
||||||
|
"action_type": "migrate",
|
||||||
|
"created_at": "2018-04-10T11:59:12.725147+00:00",
|
||||||
|
"status_message": "Action skipped by user. Reason:Skipping due to maintenance window"
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
[
|
||||||
|
{
|
||||||
|
"op": "replace",
|
||||||
|
"value": "Action skipped due to scheduled maintenance window",
|
||||||
|
"path": "/status_message"
|
||||||
|
}
|
||||||
|
]
|
||||||
@@ -0,0 +1,29 @@
|
|||||||
|
{
|
||||||
|
"state": "SKIPPED",
|
||||||
|
"description": "Migrate instance to another compute node",
|
||||||
|
"parents": [
|
||||||
|
"b4529294-1de6-4302-b57a-9b5d5dc363c6"
|
||||||
|
],
|
||||||
|
"links": [
|
||||||
|
{
|
||||||
|
"rel": "self",
|
||||||
|
"href": "http://controller:9322/v1/actions/54acc7a0-91b0-46ea-a5f7-4ae2b9df0b0a"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"rel": "bookmark",
|
||||||
|
"href": "http://controller:9322/actions/54acc7a0-91b0-46ea-a5f7-4ae2b9df0b0a"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"action_plan_uuid": "4cbc4ede-0d25-481b-b86e-998dbbd4f8bf",
|
||||||
|
"uuid": "54acc7a0-91b0-46ea-a5f7-4ae2b9df0b0a",
|
||||||
|
"deleted_at": null,
|
||||||
|
"updated_at": "2018-04-10T12:20:15.123456+00:00",
|
||||||
|
"input_parameters": {
|
||||||
|
"migration_type": "live",
|
||||||
|
"destination_node": "compute-2",
|
||||||
|
"resource_id": "a1b2c3d4-e5f6-7890-1234-567890abcdef"
|
||||||
|
},
|
||||||
|
"action_type": "migrate",
|
||||||
|
"created_at": "2018-04-10T11:59:12.725147+00:00",
|
||||||
|
"status_message": "Action skipped by user. Reason: Action skipped due to scheduled maintenance window"
|
||||||
|
}
|
||||||
@@ -21,7 +21,8 @@
|
|||||||
"uuid": "4cbc4ede-0d25-481b-b86e-998dbbd4f8bf",
|
"uuid": "4cbc4ede-0d25-481b-b86e-998dbbd4f8bf",
|
||||||
"audit_uuid": "7d100b05-0a86-491f-98a7-f93da19b272a",
|
"audit_uuid": "7d100b05-0a86-491f-98a7-f93da19b272a",
|
||||||
"created_at": "2018-04-10T11:59:52.640067+00:00",
|
"created_at": "2018-04-10T11:59:52.640067+00:00",
|
||||||
"hostname": "controller"
|
"hostname": "controller",
|
||||||
|
"status_message": null
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,5 +17,6 @@
|
|||||||
"strategy_name": "dummy_with_resize",
|
"strategy_name": "dummy_with_resize",
|
||||||
"uuid": "4cbc4ede-0d25-481b-b86e-998dbbd4f8bf",
|
"uuid": "4cbc4ede-0d25-481b-b86e-998dbbd4f8bf",
|
||||||
"audit_uuid": "7d100b05-0a86-491f-98a7-f93da19b272a",
|
"audit_uuid": "7d100b05-0a86-491f-98a7-f93da19b272a",
|
||||||
"hostname": "controller"
|
"hostname": "controller",
|
||||||
}
|
"status_message": null
|
||||||
|
}
|
||||||
|
|||||||
@@ -24,7 +24,8 @@
|
|||||||
"duration": 3.2
|
"duration": 3.2
|
||||||
},
|
},
|
||||||
"action_type": "sleep",
|
"action_type": "sleep",
|
||||||
"created_at": "2018-03-26T11:56:08.235226+00:00"
|
"created_at": "2018-03-26T11:56:08.235226+00:00",
|
||||||
|
"status_message": null
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -22,5 +22,6 @@
|
|||||||
"message": "Welcome"
|
"message": "Welcome"
|
||||||
},
|
},
|
||||||
"action_type": "nop",
|
"action_type": "nop",
|
||||||
"created_at": "2018-04-10T11:59:12.725147+00:00"
|
"created_at": "2018-04-10T11:59:12.725147+00:00",
|
||||||
}
|
"status_message": null
|
||||||
|
}
|
||||||
|
|||||||
@@ -51,5 +51,6 @@
|
|||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"hostname": null,
|
"hostname": null,
|
||||||
"start_time": null,
|
"start_time": null,
|
||||||
"end_time": null
|
"end_time": null,
|
||||||
|
"status_message": null
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -30,7 +30,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"auto_trigger": false,
|
"auto_trigger": false,
|
||||||
"force": false,
|
"force": false,
|
||||||
"uuid": "65a5da84-5819-4aea-8278-a28d2b489028",
|
"uuid": "65a5da84-5819-4aea-8278-a28d2b489028",
|
||||||
"goal_name": "workload_balancing",
|
"goal_name": "workload_balancing",
|
||||||
"scope": [],
|
"scope": [],
|
||||||
@@ -53,7 +53,8 @@
|
|||||||
"updated_at": "2018-04-06T09:44:01.604146+00:00",
|
"updated_at": "2018-04-06T09:44:01.604146+00:00",
|
||||||
"hostname": "controller",
|
"hostname": "controller",
|
||||||
"start_time": null,
|
"start_time": null,
|
||||||
"end_time": null
|
"end_time": null,
|
||||||
|
"status_message": null
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -51,5 +51,6 @@
|
|||||||
"updated_at": "2018-04-06T11:54:01.266447+00:00",
|
"updated_at": "2018-04-06T11:54:01.266447+00:00",
|
||||||
"hostname": "controller",
|
"hostname": "controller",
|
||||||
"start_time": null,
|
"start_time": null,
|
||||||
"end_time": null
|
"end_time": null,
|
||||||
|
"status_message": null
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,38 +1,62 @@
|
|||||||
{
|
{
|
||||||
"context": [
|
"context": [
|
||||||
{
|
{
|
||||||
"server_uuid": "1bf91464-9b41-428d-a11e-af691e5563bb",
|
"server_watcher_exclude": false,
|
||||||
"server_name": "chenke-test1",
|
"server_name": "chenke-test1",
|
||||||
"server_vcpus": "1",
|
"server_state": "active",
|
||||||
"server_memory": "512",
|
"server_memory": "512",
|
||||||
"server_disk": "1",
|
"server_disk": "1",
|
||||||
"server_state": "active",
|
"server_vcpus": "1",
|
||||||
"node_uuid": "253e5dd0-9384-41ab-af13-4f2c2ce26112",
|
"server_metadata": {},
|
||||||
|
"server_project_id": "baea342fc74b4a1785b4a40c69a8d958",
|
||||||
|
"server_locked":false,
|
||||||
|
"server_uuid": "1bf91464-9b41-428d-a11e-af691e5563bb",
|
||||||
|
"server_pinned_az": "nova",
|
||||||
|
"server_flavor_extra_specs": {
|
||||||
|
"hw_rng:allowed": true
|
||||||
|
},
|
||||||
"node_hostname": "localhost.localdomain",
|
"node_hostname": "localhost.localdomain",
|
||||||
"node_vcpus": "4",
|
"node_status": "enabled",
|
||||||
"node_vcpu_ratio": "16.0",
|
"node_disabled_reason": null,
|
||||||
"node_memory": "16383",
|
|
||||||
"node_memory_ratio": "1.5",
|
|
||||||
"node_disk": "37"
|
|
||||||
"node_disk_ratio": "1.0",
|
|
||||||
"node_state": "up",
|
"node_state": "up",
|
||||||
|
"node_memory": "16383",
|
||||||
|
"node_memory_mb_reserved": "512",
|
||||||
|
"node_disk": "37",
|
||||||
|
"node_disk_gb_reserved": "0",
|
||||||
|
"node_vcpus": "4",
|
||||||
|
"node_vcpu_reserved": "0",
|
||||||
|
"node_memory_ratio": "1.5",
|
||||||
|
"node_vcpu_ratio": "16.0",
|
||||||
|
"node_disk_ratio": "1.0",
|
||||||
|
"node_uuid": "253e5dd0-9384-41ab-af13-4f2c2ce26112"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"server_uuid": "e2cb5f6f-fa1d-4ba2-be1e-0bf02fa86ba4",
|
"server_watcher_exclude": false,
|
||||||
"server_name": "chenke-test2",
|
"server_name": "chenke-test2",
|
||||||
"server_vcpus": "1",
|
"server_state": "active",
|
||||||
"server_memory": "512",
|
"server_memory": "512",
|
||||||
"server_disk": "1",
|
"server_disk": "1",
|
||||||
"server_state": "active",
|
"server_vcpus": "1",
|
||||||
"node_uuid": "253e5dd0-9384-41ab-af13-4f2c2ce26112",
|
"server_metadata": {},
|
||||||
|
"server_project_id": "baea342fc74b4a1785b4a40c69a8d958",
|
||||||
|
"server_locked": false,
|
||||||
|
"server_uuid": "e2cb5f6f-fa1d-4ba2-be1e-0bf02fa86ba4",
|
||||||
|
"server_pinned_az": "nova",
|
||||||
|
"server_flavor_extra_specs": {},
|
||||||
"node_hostname": "localhost.localdomain",
|
"node_hostname": "localhost.localdomain",
|
||||||
"node_vcpus": "4",
|
"node_status": "enabled",
|
||||||
"node_vcpu_ratio": "16.0",
|
"node_disabled_reason": null,
|
||||||
"node_memory": "16383",
|
|
||||||
"node_memory_ratio": "1.5",
|
|
||||||
"node_disk": "37"
|
|
||||||
"node_disk_ratio": "1.0",
|
|
||||||
"node_state": "up",
|
"node_state": "up",
|
||||||
|
"node_memory": "16383",
|
||||||
|
"node_memory_mb_reserved": "512",
|
||||||
|
"node_disk": "37",
|
||||||
|
"node_disk_gb_reserved": "0",
|
||||||
|
"node_vcpus": "4",
|
||||||
|
"node_vcpu_reserved": "0",
|
||||||
|
"node_memory_ratio": "1.5",
|
||||||
|
"node_vcpu_ratio": "16.0",
|
||||||
|
"node_disk_ratio": "1.0",
|
||||||
|
"node_uuid": "253e5dd0-9384-41ab-af13-4f2c2ce26112"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -139,6 +139,7 @@ Response
|
|||||||
- global_efficacy: actionplan_global_efficacy
|
- global_efficacy: actionplan_global_efficacy
|
||||||
- links: links
|
- links: links
|
||||||
- hostname: actionplan_hostname
|
- hostname: actionplan_hostname
|
||||||
|
- status_message: actionplan_status_message
|
||||||
|
|
||||||
**Example JSON representation of an Action Plan:**
|
**Example JSON representation of an Action Plan:**
|
||||||
|
|
||||||
@@ -177,6 +178,7 @@ Response
|
|||||||
- global_efficacy: actionplan_global_efficacy
|
- global_efficacy: actionplan_global_efficacy
|
||||||
- links: links
|
- links: links
|
||||||
- hostname: actionplan_hostname
|
- hostname: actionplan_hostname
|
||||||
|
- status_message: actionplan_status_message
|
||||||
|
|
||||||
**Example JSON representation of an Audit:**
|
**Example JSON representation of an Audit:**
|
||||||
|
|
||||||
@@ -233,6 +235,7 @@ version 1:
|
|||||||
- global_efficacy: actionplan_global_efficacy
|
- global_efficacy: actionplan_global_efficacy
|
||||||
- links: links
|
- links: links
|
||||||
- hostname: actionplan_hostname
|
- hostname: actionplan_hostname
|
||||||
|
- status_message: actionplan_status_message
|
||||||
|
|
||||||
**Example JSON representation of an Action Plan:**
|
**Example JSON representation of an Action Plan:**
|
||||||
|
|
||||||
|
|||||||
@@ -23,6 +23,9 @@ following:
|
|||||||
|
|
||||||
- **PENDING** : the ``Action`` has not been executed yet by the
|
- **PENDING** : the ``Action`` has not been executed yet by the
|
||||||
``Watcher Applier``.
|
``Watcher Applier``.
|
||||||
|
- **SKIPPED** : the ``Action`` will not be executed because a predefined
|
||||||
|
skipping condition is found by ``Watcher Applier`` or is explicitly
|
||||||
|
skipped by the ``Administrator``.
|
||||||
- **ONGOING** : the ``Action`` is currently being processed by the
|
- **ONGOING** : the ``Action`` is currently being processed by the
|
||||||
``Watcher Applier``.
|
``Watcher Applier``.
|
||||||
- **SUCCEEDED** : the ``Action`` has been executed successfully
|
- **SUCCEEDED** : the ``Action`` has been executed successfully
|
||||||
@@ -111,6 +114,7 @@ Response
|
|||||||
- description: action_description
|
- description: action_description
|
||||||
- input_parameters: action_input_parameters
|
- input_parameters: action_input_parameters
|
||||||
- links: links
|
- links: links
|
||||||
|
- status_message: action_status_message
|
||||||
|
|
||||||
**Example JSON representation of an Action:**
|
**Example JSON representation of an Action:**
|
||||||
|
|
||||||
@@ -148,8 +152,111 @@ Response
|
|||||||
- description: action_description
|
- description: action_description
|
||||||
- input_parameters: action_input_parameters
|
- input_parameters: action_input_parameters
|
||||||
- links: links
|
- links: links
|
||||||
|
- status_message: action_status_message
|
||||||
|
|
||||||
**Example JSON representation of an Action:**
|
**Example JSON representation of an Action:**
|
||||||
|
|
||||||
.. literalinclude:: samples/actions-show-response.json
|
.. literalinclude:: samples/actions-show-response.json
|
||||||
|
:language: javascript
|
||||||
|
|
||||||
|
Skip Action
|
||||||
|
===========
|
||||||
|
|
||||||
|
.. rest_method:: PATCH /v1/actions/{action_ident}
|
||||||
|
|
||||||
|
Skips an Action resource by changing its state to SKIPPED.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
Only Actions in PENDING state can be skipped. The Action must belong to
|
||||||
|
an Action Plan in RECOMMENDED or PENDING state. This operation requires
|
||||||
|
API microversion 1.5 or later.
|
||||||
|
|
||||||
|
Normal response codes: 200
|
||||||
|
|
||||||
|
Error codes: 400,404,403,409
|
||||||
|
|
||||||
|
Request
|
||||||
|
-------
|
||||||
|
|
||||||
|
.. rest_parameters:: parameters.yaml
|
||||||
|
|
||||||
|
- action_ident: action_ident
|
||||||
|
|
||||||
|
**Example Action skip request:**
|
||||||
|
|
||||||
|
.. literalinclude:: samples/action-skip-request.json
|
||||||
|
:language: javascript
|
||||||
|
|
||||||
|
**Example Action skip request with custom status message:**
|
||||||
|
|
||||||
|
.. literalinclude:: samples/action-skip-request-with-message.json
|
||||||
|
:language: javascript
|
||||||
|
|
||||||
|
Response
|
||||||
|
--------
|
||||||
|
|
||||||
|
.. rest_parameters:: parameters.yaml
|
||||||
|
|
||||||
|
- uuid: uuid
|
||||||
|
- action_type: action_type
|
||||||
|
- state: action_state
|
||||||
|
- action_plan_uuid: action_action_plan_uuid
|
||||||
|
- parents: action_parents
|
||||||
|
- description: action_description
|
||||||
|
- input_parameters: action_input_parameters
|
||||||
|
- links: links
|
||||||
|
- status_message: action_status_message
|
||||||
|
|
||||||
|
**Example JSON representation of a skipped Action:**
|
||||||
|
|
||||||
|
.. literalinclude:: samples/action-skip-response.json
|
||||||
|
:language: javascript
|
||||||
|
|
||||||
|
Update Action Status Message
|
||||||
|
============================
|
||||||
|
|
||||||
|
.. rest_method:: PATCH /v1/actions/{action_ident}
|
||||||
|
|
||||||
|
Updates the status_message of an Action that is already in SKIPPED state.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
The status_message field can only be updated for Actions that are currently
|
||||||
|
in SKIPPED state. This allows administrators to fix typos, provide more
|
||||||
|
detailed explanations, or expand on reasons that were initially omitted.
|
||||||
|
This operation requires API microversion 1.5 or later.
|
||||||
|
|
||||||
|
Normal response codes: 200
|
||||||
|
|
||||||
|
Error codes: 400,404,403,409
|
||||||
|
|
||||||
|
Request
|
||||||
|
-------
|
||||||
|
|
||||||
|
.. rest_parameters:: parameters.yaml
|
||||||
|
|
||||||
|
- action_ident: action_ident
|
||||||
|
|
||||||
|
**Example status_message update request for a SKIPPED action:**
|
||||||
|
|
||||||
|
.. literalinclude:: samples/action-update-status-message-request.json
|
||||||
|
:language: javascript
|
||||||
|
|
||||||
|
Response
|
||||||
|
--------
|
||||||
|
|
||||||
|
.. rest_parameters:: parameters.yaml
|
||||||
|
|
||||||
|
- uuid: uuid
|
||||||
|
- action_type: action_type
|
||||||
|
- state: action_state
|
||||||
|
- action_plan_uuid: action_action_plan_uuid
|
||||||
|
- parents: action_parents
|
||||||
|
- description: action_description
|
||||||
|
- input_parameters: action_input_parameters
|
||||||
|
- links: links
|
||||||
|
- status_message: action_status_message
|
||||||
|
|
||||||
|
**Example JSON representation of an Action with updated status_message:**
|
||||||
|
|
||||||
|
.. literalinclude:: samples/action-update-status-message-response.json
|
||||||
:language: javascript
|
:language: javascript
|
||||||
@@ -85,6 +85,7 @@ version 1:
|
|||||||
- start_time: audit_starttime_resp
|
- start_time: audit_starttime_resp
|
||||||
- end_time: audit_endtime_resp
|
- end_time: audit_endtime_resp
|
||||||
- force: audit_force
|
- force: audit_force
|
||||||
|
- status_message: audit_status_message
|
||||||
|
|
||||||
**Example JSON representation of an Audit:**
|
**Example JSON representation of an Audit:**
|
||||||
|
|
||||||
@@ -184,6 +185,7 @@ Response
|
|||||||
- start_time: audit_starttime_resp
|
- start_time: audit_starttime_resp
|
||||||
- end_time: audit_endtime_resp
|
- end_time: audit_endtime_resp
|
||||||
- force: audit_force
|
- force: audit_force
|
||||||
|
- status_message: audit_status_message
|
||||||
|
|
||||||
**Example JSON representation of an Audit:**
|
**Example JSON representation of an Audit:**
|
||||||
|
|
||||||
@@ -231,6 +233,7 @@ Response
|
|||||||
- start_time: audit_starttime_resp
|
- start_time: audit_starttime_resp
|
||||||
- end_time: audit_endtime_resp
|
- end_time: audit_endtime_resp
|
||||||
- force: audit_force
|
- force: audit_force
|
||||||
|
- status_message: audit_status_message
|
||||||
|
|
||||||
**Example JSON representation of an Audit:**
|
**Example JSON representation of an Audit:**
|
||||||
|
|
||||||
@@ -286,6 +289,7 @@ version 1:
|
|||||||
- start_time: audit_starttime_resp
|
- start_time: audit_starttime_resp
|
||||||
- end_time: audit_endtime_resp
|
- end_time: audit_endtime_resp
|
||||||
- force: audit_force
|
- force: audit_force
|
||||||
|
- status_message: audit_status_message
|
||||||
|
|
||||||
**Example JSON representation of an Audit:**
|
**Example JSON representation of an Audit:**
|
||||||
|
|
||||||
@@ -341,6 +345,7 @@ Response
|
|||||||
- start_time: audit_starttime_resp
|
- start_time: audit_starttime_resp
|
||||||
- end_time: audit_endtime_resp
|
- end_time: audit_endtime_resp
|
||||||
- force: audit_force
|
- force: audit_force
|
||||||
|
- status_message: audit_status_message
|
||||||
|
|
||||||
**Example JSON representation of an Audit:**
|
**Example JSON representation of an Audit:**
|
||||||
|
|
||||||
|
|||||||
@@ -4,6 +4,8 @@
|
|||||||
Data Model
|
Data Model
|
||||||
==========
|
==========
|
||||||
|
|
||||||
|
.. versionadded:: 1.3
|
||||||
|
|
||||||
``Data Model`` is very important for Watcher to generate resource
|
``Data Model`` is very important for Watcher to generate resource
|
||||||
optimization solutions. Users can easily view the data model by the
|
optimization solutions. Users can easily view the data model by the
|
||||||
API.
|
API.
|
||||||
@@ -18,7 +20,7 @@ Returns the information about Data Model.
|
|||||||
|
|
||||||
Normal response codes: 200
|
Normal response codes: 200
|
||||||
|
|
||||||
Error codes: 400,401
|
Error codes: 400,401,406
|
||||||
|
|
||||||
Request
|
Request
|
||||||
-------
|
-------
|
||||||
@@ -33,21 +35,32 @@ Response
|
|||||||
|
|
||||||
.. rest_parameters:: parameters.yaml
|
.. rest_parameters:: parameters.yaml
|
||||||
|
|
||||||
- server_uuid: server_uuid
|
- server_watcher_exclude: server_watcher_exclude
|
||||||
- server_name: server_name
|
- server_name: server_name
|
||||||
- server_vcpus: server_vcpus
|
- server_state: server_state
|
||||||
- server_memory: server_memory
|
- server_memory: server_memory
|
||||||
- server_disk: server_disk
|
- server_disk: server_disk
|
||||||
- server_state: server_state
|
- server_vcpus: server_vcpus
|
||||||
- node_uuid: node_uuid
|
- server_metadata: server_metadata
|
||||||
|
- server_project_id: server_project_id
|
||||||
|
- server_locked: server_locked
|
||||||
|
- server_uuid: server_uuid
|
||||||
|
- server_pinned_az: server_pinned_az
|
||||||
|
- server_flavor_extra_specs: server_flavor_extra_specs
|
||||||
- node_hostname: node_hostname
|
- node_hostname: node_hostname
|
||||||
- node_vcpus: node_vcpus
|
- node_status: node_status
|
||||||
- node_vcpu_ratio: node_vcpu_ratio
|
- node_disabled_reason: node_disabled_reason
|
||||||
- node_memory: node_memory
|
|
||||||
- node_memory_ratio: node_memory_ratio
|
|
||||||
- node_disk: node_disk
|
|
||||||
- node_disk_ratio: node_disk_ratio
|
|
||||||
- node_state: node_state
|
- node_state: node_state
|
||||||
|
- node_memory: node_memory
|
||||||
|
- node_memory_mb_reserved: node_memory_mb_reserved
|
||||||
|
- node_disk: node_disk
|
||||||
|
- node_disk_gb_reserved: node_disk_gb_reserved
|
||||||
|
- node_vcpus: node_vcpus
|
||||||
|
- node_vcpu_reserved: node_vcpu_reserved
|
||||||
|
- node_memory_ratio: node_memory_ratio
|
||||||
|
- node_vcpu_ratio: node_vcpu_ratio
|
||||||
|
- node_disk_ratio: node_disk_ratio
|
||||||
|
- node_uuid: node_uuid
|
||||||
|
|
||||||
**Example JSON representation of a Data Model:**
|
**Example JSON representation of a Data Model:**
|
||||||
|
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ Here are some examples of ``Goals``:
|
|||||||
- minimize the energy consumption
|
- minimize the energy consumption
|
||||||
- minimize the number of compute nodes (consolidation)
|
- minimize the number of compute nodes (consolidation)
|
||||||
- balance the workload among compute nodes
|
- balance the workload among compute nodes
|
||||||
- minimize the license cost (some softwares have a licensing model which is
|
- minimize the license cost (some software have a licensing model which is
|
||||||
based on the number of sockets or cores where the software is deployed)
|
based on the number of sockets or cores where the software is deployed)
|
||||||
- find the most appropriate moment for a planned maintenance on a
|
- find the most appropriate moment for a planned maintenance on a
|
||||||
given group of host (which may be an entire availability zone):
|
given group of host (which may be an entire availability zone):
|
||||||
@@ -123,4 +123,4 @@ Response
|
|||||||
**Example JSON representation of a Goal:**
|
**Example JSON representation of a Goal:**
|
||||||
|
|
||||||
.. literalinclude:: samples/goal-show-response.json
|
.. literalinclude:: samples/goal-show-response.json
|
||||||
:language: javascript
|
:language: javascript
|
||||||
|
|||||||
26
api-ref/source/watcher-api-v1-webhooks.inc
Normal file
26
api-ref/source/watcher-api-v1-webhooks.inc
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
.. -*- rst -*-
|
||||||
|
|
||||||
|
========
|
||||||
|
Webhooks
|
||||||
|
========
|
||||||
|
|
||||||
|
.. versionadded:: 1.4
|
||||||
|
|
||||||
|
Triggers an event based Audit.
|
||||||
|
|
||||||
|
|
||||||
|
Trigger EVENT Audit
|
||||||
|
===================
|
||||||
|
|
||||||
|
.. rest_method:: POST /v1/webhooks/{audit_ident}
|
||||||
|
|
||||||
|
Normal response codes: 202
|
||||||
|
|
||||||
|
Error codes: 400,404
|
||||||
|
|
||||||
|
Request
|
||||||
|
-------
|
||||||
|
|
||||||
|
.. rest_parameters:: parameters.yaml
|
||||||
|
|
||||||
|
- audit_ident: audit_ident
|
||||||
23
bindep.txt
Normal file
23
bindep.txt
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
# This is a cross-platform list tracking distribution packages needed for install and tests;
|
||||||
|
# see https://docs.openstack.org/infra/bindep/ for additional information.
|
||||||
|
|
||||||
|
mysql [platform:rpm !platform:redhat test]
|
||||||
|
mysql-client [platform:dpkg !platform:debian test]
|
||||||
|
mysql-devel [platform:rpm !platform:redhat test]
|
||||||
|
mysql-server [!platform:redhat !platform:debian test]
|
||||||
|
mariadb-devel [platform:rpm platform:redhat test]
|
||||||
|
mariadb-server [platform:rpm platform:redhat platform:debian test]
|
||||||
|
python3-all [platform:dpkg test]
|
||||||
|
python3-all-dev [platform:dpkg test]
|
||||||
|
python3 [platform:rpm test]
|
||||||
|
python3-devel [platform:rpm test]
|
||||||
|
sqlite-devel [platform:rpm test]
|
||||||
|
# gettext and graphviz are needed by doc builds only.
|
||||||
|
gettext [doc]
|
||||||
|
graphviz [doc]
|
||||||
|
# fonts-freefont-otf is needed for pdf docs builds with the 'xelatex' engine
|
||||||
|
fonts-freefont-otf [pdf-docs]
|
||||||
|
texlive [pdf-docs]
|
||||||
|
texlive-latex-recommended [pdf-docs]
|
||||||
|
texlive-xetex [pdf-docs]
|
||||||
|
latexmk [pdf-docs]
|
||||||
@@ -1,42 +0,0 @@
|
|||||||
# 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.
|
|
||||||
|
|
||||||
# This is an example Apache2 configuration file for using the
|
|
||||||
# Watcher API through mod_wsgi. This version assumes you are
|
|
||||||
# running devstack to configure the software.
|
|
||||||
|
|
||||||
Listen %WATCHER_SERVICE_PORT%
|
|
||||||
|
|
||||||
<VirtualHost *:%WATCHER_SERVICE_PORT%>
|
|
||||||
WSGIDaemonProcess watcher-api user=%USER% processes=%APIWORKERS% threads=1 display-name=%{GROUP}
|
|
||||||
WSGIScriptAlias / %WATCHER_WSGI_DIR%/app.wsgi
|
|
||||||
WSGIApplicationGroup %{GLOBAL}
|
|
||||||
WSGIProcessGroup watcher-api
|
|
||||||
WSGIPassAuthorization On
|
|
||||||
|
|
||||||
ErrorLogFormat "%M"
|
|
||||||
ErrorLog /var/log/%APACHE_NAME%/watcher-api.log
|
|
||||||
CustomLog /var/log/%APACHE_NAME%/watcher-api-access.log combined
|
|
||||||
|
|
||||||
|
|
||||||
<Directory %WATCHER_WSGI_DIR%>
|
|
||||||
WSGIProcessGroup watcher-api
|
|
||||||
WSGIApplicationGroup %{GLOBAL}
|
|
||||||
<IfVersion >= 2.4>
|
|
||||||
Require all granted
|
|
||||||
</IfVersion>
|
|
||||||
<IfVersion < 2.4>
|
|
||||||
Order allow,deny
|
|
||||||
Allow from all
|
|
||||||
</IfVersion>
|
|
||||||
</Directory>
|
|
||||||
</VirtualHost>
|
|
||||||
@@ -1,5 +1,3 @@
|
|||||||
#!/bin/bash
|
|
||||||
#
|
|
||||||
# lib/watcher
|
# lib/watcher
|
||||||
# Functions to control the configuration and operation of the watcher services
|
# Functions to control the configuration and operation of the watcher services
|
||||||
|
|
||||||
@@ -38,7 +36,6 @@ GITBRANCH["python-watcherclient"]=${WATCHERCLIENT_BRANCH:-master}
|
|||||||
GITDIR["python-watcherclient"]=$DEST/python-watcherclient
|
GITDIR["python-watcherclient"]=$DEST/python-watcherclient
|
||||||
|
|
||||||
WATCHER_STATE_PATH=${WATCHER_STATE_PATH:=$DATA_DIR/watcher}
|
WATCHER_STATE_PATH=${WATCHER_STATE_PATH:=$DATA_DIR/watcher}
|
||||||
WATCHER_AUTH_CACHE_DIR=${WATCHER_AUTH_CACHE_DIR:-/var/cache/watcher}
|
|
||||||
|
|
||||||
WATCHER_CONF_DIR=/etc/watcher
|
WATCHER_CONF_DIR=/etc/watcher
|
||||||
WATCHER_CONF=$WATCHER_CONF_DIR/watcher.conf
|
WATCHER_CONF=$WATCHER_CONF_DIR/watcher.conf
|
||||||
@@ -58,29 +55,16 @@ else
|
|||||||
WATCHER_BIN_DIR=$(get_python_exec_prefix)
|
WATCHER_BIN_DIR=$(get_python_exec_prefix)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# There are 2 modes, which is "uwsgi" which runs with an apache
|
WATCHER_UWSGI=watcher.wsgi.api:application
|
||||||
# proxy uwsgi in front of it, or "mod_wsgi", which runs in
|
|
||||||
# apache. mod_wsgi is deprecated, don't use it.
|
|
||||||
WATCHER_USE_WSGI_MODE=${WATCHER_USE_WSGI_MODE:-$WSGI_MODE}
|
|
||||||
WATCHER_UWSGI=$WATCHER_BIN_DIR/watcher-api-wsgi
|
|
||||||
WATCHER_UWSGI_CONF=$WATCHER_CONF_DIR/watcher-uwsgi.ini
|
WATCHER_UWSGI_CONF=$WATCHER_CONF_DIR/watcher-uwsgi.ini
|
||||||
|
WATCHER_WSGI_DIR=${WATCHER_WSGI_DIR:-/var/www/watcher}
|
||||||
if is_suse; then
|
|
||||||
WATCHER_WSGI_DIR=${WATCHER_WSGI_DIR:-/srv/www/htdocs/watcher}
|
|
||||||
else
|
|
||||||
WATCHER_WSGI_DIR=${WATCHER_WSGI_DIR:-/var/www/watcher}
|
|
||||||
fi
|
|
||||||
# Public facing bits
|
# Public facing bits
|
||||||
WATCHER_SERVICE_HOST=${WATCHER_SERVICE_HOST:-$SERVICE_HOST}
|
WATCHER_SERVICE_HOST=${WATCHER_SERVICE_HOST:-$SERVICE_HOST}
|
||||||
WATCHER_SERVICE_PORT=${WATCHER_SERVICE_PORT:-9322}
|
WATCHER_SERVICE_PORT=${WATCHER_SERVICE_PORT:-9322}
|
||||||
WATCHER_SERVICE_PORT_INT=${WATCHER_SERVICE_PORT_INT:-19322}
|
WATCHER_SERVICE_PORT_INT=${WATCHER_SERVICE_PORT_INT:-19322}
|
||||||
WATCHER_SERVICE_PROTOCOL=${WATCHER_SERVICE_PROTOCOL:-$SERVICE_PROTOCOL}
|
WATCHER_SERVICE_PROTOCOL=${WATCHER_SERVICE_PROTOCOL:-$SERVICE_PROTOCOL}
|
||||||
|
|
||||||
if [[ "$WATCHER_USE_WSGI_MODE" == "uwsgi" ]]; then
|
WATCHER_API_URL="$WATCHER_SERVICE_PROTOCOL://$WATCHER_SERVICE_HOST/infra-optim"
|
||||||
WATCHER_API_URL="$WATCHER_SERVICE_PROTOCOL://$WATCHER_SERVICE_HOST/infra-optim"
|
|
||||||
else
|
|
||||||
WATCHER_API_URL="$WATCHER_SERVICE_PROTOCOL://$WATCHER_SERVICE_HOST:$WATCHER_SERVICE_PORT"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Entry Points
|
# Entry Points
|
||||||
# ------------
|
# ------------
|
||||||
@@ -103,12 +87,8 @@ function _cleanup_watcher_apache_wsgi {
|
|||||||
# cleanup_watcher() - Remove residual data files, anything left over from previous
|
# cleanup_watcher() - Remove residual data files, anything left over from previous
|
||||||
# runs that a clean run would need to clean up
|
# runs that a clean run would need to clean up
|
||||||
function cleanup_watcher {
|
function cleanup_watcher {
|
||||||
sudo rm -rf $WATCHER_STATE_PATH $WATCHER_AUTH_CACHE_DIR
|
sudo rm -rf $WATCHER_STATE_PATH
|
||||||
if [[ "$WATCHER_USE_WSGI_MODE" == "uwsgi" ]]; then
|
remove_uwsgi_config "$WATCHER_UWSGI_CONF" "$WATCHER_UWSGI"
|
||||||
remove_uwsgi_config "$WATCHER_UWSGI_CONF" "$WATCHER_UWSGI"
|
|
||||||
else
|
|
||||||
_cleanup_watcher_apache_wsgi
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# configure_watcher() - Set config files, create data dirs, etc
|
# configure_watcher() - Set config files, create data dirs, etc
|
||||||
@@ -157,31 +137,6 @@ function create_watcher_accounts {
|
|||||||
"$WATCHER_API_URL"
|
"$WATCHER_API_URL"
|
||||||
}
|
}
|
||||||
|
|
||||||
# _config_watcher_apache_wsgi() - Set WSGI config files of watcher
|
|
||||||
function _config_watcher_apache_wsgi {
|
|
||||||
local watcher_apache_conf
|
|
||||||
if [[ "$WATCHER_USE_WSGI_MODE" == "mod_wsgi" ]]; then
|
|
||||||
local service_port=$WATCHER_SERVICE_PORT
|
|
||||||
if is_service_enabled tls-proxy; then
|
|
||||||
service_port=$WATCHER_SERVICE_PORT_INT
|
|
||||||
service_protocol="http"
|
|
||||||
fi
|
|
||||||
sudo mkdir -p $WATCHER_WSGI_DIR
|
|
||||||
sudo cp $WATCHER_DIR/watcher/api/app.wsgi $WATCHER_WSGI_DIR/app.wsgi
|
|
||||||
watcher_apache_conf=$(apache_site_config_for watcher-api)
|
|
||||||
sudo cp $WATCHER_DEVSTACK_FILES_DIR/apache-watcher-api.template $watcher_apache_conf
|
|
||||||
sudo sed -e "
|
|
||||||
s|%WATCHER_SERVICE_PORT%|$service_port|g;
|
|
||||||
s|%WATCHER_WSGI_DIR%|$WATCHER_WSGI_DIR|g;
|
|
||||||
s|%USER%|$STACK_USER|g;
|
|
||||||
s|%APIWORKERS%|$API_WORKERS|g;
|
|
||||||
s|%APACHE_NAME%|$APACHE_NAME|g;
|
|
||||||
" -i $watcher_apache_conf
|
|
||||||
enable_apache_site watcher-api
|
|
||||||
fi
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
# create_watcher_conf() - Create a new watcher.conf file
|
# create_watcher_conf() - Create a new watcher.conf file
|
||||||
function create_watcher_conf {
|
function create_watcher_conf {
|
||||||
# (Re)create ``watcher.conf``
|
# (Re)create ``watcher.conf``
|
||||||
@@ -199,21 +154,16 @@ function create_watcher_conf {
|
|||||||
iniset $WATCHER_CONF api host "$(ipv6_unquote $WATCHER_SERVICE_HOST)"
|
iniset $WATCHER_CONF api host "$(ipv6_unquote $WATCHER_SERVICE_HOST)"
|
||||||
iniset $WATCHER_CONF api port "$WATCHER_SERVICE_PORT_INT"
|
iniset $WATCHER_CONF api port "$WATCHER_SERVICE_PORT_INT"
|
||||||
# iniset $WATCHER_CONF api enable_ssl_api "True"
|
# iniset $WATCHER_CONF api enable_ssl_api "True"
|
||||||
else
|
|
||||||
if [[ "$WATCHER_USE_WSGI_MODE" == "mod_wsgi" ]]; then
|
|
||||||
iniset $WATCHER_CONF api host "$(ipv6_unquote $WATCHER_SERVICE_HOST)"
|
|
||||||
iniset $WATCHER_CONF api port "$WATCHER_SERVICE_PORT"
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
iniset $WATCHER_CONF oslo_policy policy_file $WATCHER_POLICY_YAML
|
iniset $WATCHER_CONF oslo_policy policy_file $WATCHER_POLICY_YAML
|
||||||
|
|
||||||
iniset $WATCHER_CONF oslo_messaging_notifications driver "messagingv2"
|
iniset $WATCHER_CONF oslo_messaging_notifications driver "messagingv2"
|
||||||
|
|
||||||
configure_auth_token_middleware $WATCHER_CONF watcher $WATCHER_AUTH_CACHE_DIR
|
configure_keystone_authtoken_middleware $WATCHER_CONF watcher
|
||||||
configure_auth_token_middleware $WATCHER_CONF watcher $WATCHER_AUTH_CACHE_DIR "watcher_clients_auth"
|
configure_keystone_authtoken_middleware $WATCHER_CONF watcher "watcher_clients_auth"
|
||||||
|
|
||||||
if is_fedora || is_suse; then
|
if is_fedora; then
|
||||||
# watcher defaults to /usr/local/bin, but fedora and suse pip like to
|
# watcher defaults to /usr/local/bin, but fedora and suse pip like to
|
||||||
# install things in /usr/bin
|
# install things in /usr/bin
|
||||||
iniset $WATCHER_CONF DEFAULT bindir "/usr/bin"
|
iniset $WATCHER_CONF DEFAULT bindir "/usr/bin"
|
||||||
@@ -231,12 +181,8 @@ function create_watcher_conf {
|
|||||||
# Format logging
|
# Format logging
|
||||||
setup_logging $WATCHER_CONF
|
setup_logging $WATCHER_CONF
|
||||||
|
|
||||||
#config apache files
|
write_uwsgi_config "$WATCHER_UWSGI_CONF" "$WATCHER_UWSGI" "/infra-optim" "" "watcher-api"
|
||||||
if [[ "$WATCHER_USE_WSGI_MODE" == "uwsgi" ]]; then
|
|
||||||
write_uwsgi_config "$WATCHER_UWSGI_CONF" "$WATCHER_UWSGI" "/infra-optim"
|
|
||||||
else
|
|
||||||
_config_watcher_apache_wsgi
|
|
||||||
fi
|
|
||||||
# Register SSL certificates if provided
|
# Register SSL certificates if provided
|
||||||
if is_ssl_enabled_service watcher; then
|
if is_ssl_enabled_service watcher; then
|
||||||
ensure_certificates WATCHER
|
ensure_certificates WATCHER
|
||||||
@@ -248,13 +194,6 @@ function create_watcher_conf {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# create_watcher_cache_dir() - Part of the init_watcher() process
|
|
||||||
function create_watcher_cache_dir {
|
|
||||||
# Create cache dir
|
|
||||||
sudo install -d -o $STACK_USER $WATCHER_AUTH_CACHE_DIR
|
|
||||||
rm -rf $WATCHER_AUTH_CACHE_DIR/*
|
|
||||||
}
|
|
||||||
|
|
||||||
# init_watcher() - Initialize databases, etc.
|
# init_watcher() - Initialize databases, etc.
|
||||||
function init_watcher {
|
function init_watcher {
|
||||||
# clean up from previous (possibly aborted) runs
|
# clean up from previous (possibly aborted) runs
|
||||||
@@ -266,7 +205,6 @@ function init_watcher {
|
|||||||
# Create watcher schema
|
# Create watcher schema
|
||||||
$WATCHER_BIN_DIR/watcher-db-manage --config-file $WATCHER_CONF upgrade
|
$WATCHER_BIN_DIR/watcher-db-manage --config-file $WATCHER_CONF upgrade
|
||||||
fi
|
fi
|
||||||
create_watcher_cache_dir
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# install_watcherclient() - Collect source and prepare
|
# install_watcherclient() - Collect source and prepare
|
||||||
@@ -275,15 +213,15 @@ function install_watcherclient {
|
|||||||
git_clone_by_name "python-watcherclient"
|
git_clone_by_name "python-watcherclient"
|
||||||
setup_dev_lib "python-watcherclient"
|
setup_dev_lib "python-watcherclient"
|
||||||
fi
|
fi
|
||||||
|
if [[ "$GLOBAL_VENV" == "True" ]]; then
|
||||||
|
sudo ln -sf /opt/stack/data/venv/bin/watcher /usr/local/bin
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# install_watcher() - Collect source and prepare
|
# install_watcher() - Collect source and prepare
|
||||||
function install_watcher {
|
function install_watcher {
|
||||||
git_clone $WATCHER_REPO $WATCHER_DIR $WATCHER_BRANCH
|
git_clone $WATCHER_REPO $WATCHER_DIR $WATCHER_BRANCH
|
||||||
setup_develop $WATCHER_DIR
|
setup_develop $WATCHER_DIR
|
||||||
if [[ "$WATCHER_USE_WSGI_MODE" == "mod_wsgi" ]]; then
|
|
||||||
install_apache_wsgi
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# start_watcher_api() - Start the API process ahead of other things
|
# start_watcher_api() - Start the API process ahead of other things
|
||||||
@@ -297,19 +235,10 @@ function start_watcher_api {
|
|||||||
service_port=$WATCHER_SERVICE_PORT_INT
|
service_port=$WATCHER_SERVICE_PORT_INT
|
||||||
service_protocol="http"
|
service_protocol="http"
|
||||||
fi
|
fi
|
||||||
if [[ "$WATCHER_USE_WSGI_MODE" == "uwsgi" ]]; then
|
run_process "watcher-api" "$(which uwsgi) --procname-prefix watcher-api --ini $WATCHER_UWSGI_CONF"
|
||||||
run_process "watcher-api" "$WATCHER_BIN_DIR/uwsgi --ini $WATCHER_UWSGI_CONF"
|
watcher_url=$service_protocol://$SERVICE_HOST/infra-optim
|
||||||
watcher_url=$service_protocol://$SERVICE_HOST/infra-optim
|
# TODO(sean-k-mooney): we should probably check that we can hit
|
||||||
else
|
# the microversion endpoint and get a valid response.
|
||||||
watcher_url=$service_protocol://$SERVICE_HOST:$service_port
|
|
||||||
enable_apache_site watcher-api
|
|
||||||
restart_apache_server
|
|
||||||
# Start proxies if enabled
|
|
||||||
if is_service_enabled tls-proxy; then
|
|
||||||
start_tls_proxy watcher '*' $WATCHER_SERVICE_PORT $WATCHER_SERVICE_HOST $WATCHER_SERVICE_PORT_INT
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Waiting for watcher-api to start..."
|
echo "Waiting for watcher-api to start..."
|
||||||
if ! wait_for_service $SERVICE_TIMEOUT $watcher_url; then
|
if ! wait_for_service $SERVICE_TIMEOUT $watcher_url; then
|
||||||
die $LINENO "watcher-api did not start"
|
die $LINENO "watcher-api did not start"
|
||||||
@@ -327,17 +256,25 @@ function start_watcher {
|
|||||||
|
|
||||||
# stop_watcher() - Stop running processes (non-screen)
|
# stop_watcher() - Stop running processes (non-screen)
|
||||||
function stop_watcher {
|
function stop_watcher {
|
||||||
if [[ "$WATCHER_USE_WSGI_MODE" == "uwsgi" ]]; then
|
stop_process watcher-api
|
||||||
stop_process watcher-api
|
|
||||||
else
|
|
||||||
disable_apache_site watcher-api
|
|
||||||
restart_apache_server
|
|
||||||
fi
|
|
||||||
for serv in watcher-decision-engine watcher-applier; do
|
for serv in watcher-decision-engine watcher-applier; do
|
||||||
stop_process $serv
|
stop_process $serv
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# configure_tempest_for_watcher() - Configure Tempest for watcher
|
||||||
|
function configure_tempest_for_watcher {
|
||||||
|
# Set default microversion for watcher-tempest-plugin
|
||||||
|
# Please make sure to update this when the microversion is updated, otherwise
|
||||||
|
# new tests may be skipped.
|
||||||
|
TEMPEST_WATCHER_MIN_MICROVERSION=${TEMPEST_WATCHER_MIN_MICROVERSION:-"1.0"}
|
||||||
|
TEMPEST_WATCHER_MAX_MICROVERSION=${TEMPEST_WATCHER_MAX_MICROVERSION:-"1.6"}
|
||||||
|
|
||||||
|
# Set microversion options in tempest.conf
|
||||||
|
iniset $TEMPEST_CONFIG optimize min_microversion $TEMPEST_WATCHER_MIN_MICROVERSION
|
||||||
|
iniset $TEMPEST_CONFIG optimize max_microversion $TEMPEST_WATCHER_MAX_MICROVERSION
|
||||||
|
}
|
||||||
|
|
||||||
# Restore xtrace
|
# Restore xtrace
|
||||||
$_XTRACE_WATCHER
|
$_XTRACE_WATCHER
|
||||||
|
|
||||||
|
|||||||
@@ -26,7 +26,7 @@ GLANCE_HOSTPORT=${SERVICE_HOST}:9292
|
|||||||
DATABASE_TYPE=mysql
|
DATABASE_TYPE=mysql
|
||||||
|
|
||||||
# Enable services (including neutron)
|
# Enable services (including neutron)
|
||||||
ENABLED_SERVICES=n-cpu,n-api-meta,c-vol,q-agt,placement-client
|
ENABLED_SERVICES=n-cpu,n-api-meta,c-vol,q-agt,placement-client,node-exporter
|
||||||
|
|
||||||
NOVA_VNC_ENABLED=True
|
NOVA_VNC_ENABLED=True
|
||||||
NOVNCPROXY_URL="http://$SERVICE_HOST:6080/vnc_auto.html"
|
NOVNCPROXY_URL="http://$SERVICE_HOST:6080/vnc_auto.html"
|
||||||
@@ -42,6 +42,10 @@ disable_service ceilometer-acentral,ceilometer-collector,ceilometer-api
|
|||||||
LOGFILE=$DEST/logs/stack.sh.log
|
LOGFILE=$DEST/logs/stack.sh.log
|
||||||
LOGDAYS=2
|
LOGDAYS=2
|
||||||
|
|
||||||
|
CEILOMETER_BACKEND="none"
|
||||||
|
CEILOMETER_BACKENDS="none"
|
||||||
|
enable_plugin devstack-plugin-prometheus https://opendev.org/openstack/devstack-plugin-prometheus
|
||||||
|
|
||||||
[[post-config|$NOVA_CONF]]
|
[[post-config|$NOVA_CONF]]
|
||||||
[DEFAULT]
|
[DEFAULT]
|
||||||
compute_monitors=cpu.virt_driver
|
compute_monitors=cpu.virt_driver
|
||||||
|
|||||||
@@ -18,6 +18,10 @@ NETWORK_GATEWAY=10.254.1.1 # Change this for your network
|
|||||||
|
|
||||||
MULTI_HOST=1
|
MULTI_HOST=1
|
||||||
|
|
||||||
|
CEILOMETER_ALARM_THRESHOLD="6000000000"
|
||||||
|
CEILOMETER_BACKENDS="sg-core"
|
||||||
|
CEILOMETER_PIPELINE_INTERVAL="15"
|
||||||
|
|
||||||
|
|
||||||
#Set this to FALSE if do not want to run watcher-api behind mod-wsgi
|
#Set this to FALSE if do not want to run watcher-api behind mod-wsgi
|
||||||
#WATCHER_USE_MOD_WSGI=TRUE
|
#WATCHER_USE_MOD_WSGI=TRUE
|
||||||
@@ -40,8 +44,10 @@ disable_service ceilometer-acompute
|
|||||||
# Enable the ceilometer api explicitly(bug:1667678)
|
# Enable the ceilometer api explicitly(bug:1667678)
|
||||||
enable_service ceilometer-api
|
enable_service ceilometer-api
|
||||||
|
|
||||||
# Enable the Gnocchi plugin
|
enable_service prometheus
|
||||||
enable_plugin gnocchi https://github.com/gnocchixyz/gnocchi
|
enable_plugin aodh https://opendev.org/openstack/aodh
|
||||||
|
enable_plugin devstack-plugin-prometheus https://opendev.org/openstack/devstack-plugin-prometheus
|
||||||
|
enable_plugin sg-core https://github.com/openstack-k8s-operators/sg-core main
|
||||||
|
|
||||||
LOGFILE=$DEST/logs/stack.sh.log
|
LOGFILE=$DEST/logs/stack.sh.log
|
||||||
LOGDAYS=2
|
LOGDAYS=2
|
||||||
@@ -55,3 +61,42 @@ compute_monitors=cpu.virt_driver
|
|||||||
# can change this to just versioned when ceilometer handles versioned
|
# can change this to just versioned when ceilometer handles versioned
|
||||||
# notifications from nova: https://bugs.launchpad.net/ceilometer/+bug/1665449
|
# notifications from nova: https://bugs.launchpad.net/ceilometer/+bug/1665449
|
||||||
notification_format=both
|
notification_format=both
|
||||||
|
|
||||||
|
[[post-config|$WATCHER_CONF]]
|
||||||
|
[prometheus_client]
|
||||||
|
host = 127.0.0.1
|
||||||
|
port = 9090
|
||||||
|
|
||||||
|
[watcher_cluster_data_model_collectors.baremetal]
|
||||||
|
period = 120
|
||||||
|
|
||||||
|
[watcher_cluster_data_model_collectors.compute]
|
||||||
|
period = 120
|
||||||
|
|
||||||
|
[watcher_cluster_data_model_collectors.storage]
|
||||||
|
period = 120
|
||||||
|
|
||||||
|
[watcher_datasources]
|
||||||
|
datasources = prometheus
|
||||||
|
|
||||||
|
[[test-config|$TEMPEST_CONFIG]]
|
||||||
|
[optimize]
|
||||||
|
datasource = prometheus
|
||||||
|
|
||||||
|
[service_available]
|
||||||
|
sg_core = True
|
||||||
|
|
||||||
|
[telemetry]
|
||||||
|
ceilometer_polling_interval = 15
|
||||||
|
disable_ssl_certificate_validation = True
|
||||||
|
|
||||||
|
[telemetry_services]
|
||||||
|
metric_backends = prometheus
|
||||||
|
|
||||||
|
[compute]
|
||||||
|
min_compute_nodes = 2
|
||||||
|
min_microversion = 2.56
|
||||||
|
|
||||||
|
[compute-feature-enabled]
|
||||||
|
block_migration_for_live_migration = True
|
||||||
|
live_migration = True
|
||||||
|
|||||||
53
devstack/local_gnocchi.conf.compute
Normal file
53
devstack/local_gnocchi.conf.compute
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
# Sample ``local.conf`` for compute node for Watcher development
|
||||||
|
# NOTE: Copy this file to the root DevStack directory for it to work properly.
|
||||||
|
|
||||||
|
[[local|localrc]]
|
||||||
|
|
||||||
|
ADMIN_PASSWORD=nomoresecrete
|
||||||
|
DATABASE_PASSWORD=stackdb
|
||||||
|
RABBIT_PASSWORD=stackqueue
|
||||||
|
SERVICE_PASSWORD=$ADMIN_PASSWORD
|
||||||
|
SERVICE_TOKEN=azertytoken
|
||||||
|
|
||||||
|
HOST_IP=192.168.42.2 # Change this to this compute node's IP address
|
||||||
|
#HOST_IPV6=2001:db8::7
|
||||||
|
FLAT_INTERFACE=eth0
|
||||||
|
|
||||||
|
FIXED_RANGE=10.254.1.0/24 # Change this to whatever your network is
|
||||||
|
NETWORK_GATEWAY=10.254.1.1 # Change this for your network
|
||||||
|
|
||||||
|
MULTI_HOST=1
|
||||||
|
|
||||||
|
SERVICE_HOST=192.168.42.1 # Change this to the IP of your controller node
|
||||||
|
MYSQL_HOST=$SERVICE_HOST
|
||||||
|
RABBIT_HOST=$SERVICE_HOST
|
||||||
|
GLANCE_HOSTPORT=${SERVICE_HOST}:9292
|
||||||
|
|
||||||
|
DATABASE_TYPE=mysql
|
||||||
|
|
||||||
|
# Enable services (including neutron)
|
||||||
|
ENABLED_SERVICES=n-cpu,n-api-meta,c-vol,q-agt,placement-client
|
||||||
|
|
||||||
|
NOVA_VNC_ENABLED=True
|
||||||
|
NOVNCPROXY_URL="http://$SERVICE_HOST:6080/vnc_auto.html"
|
||||||
|
VNCSERVER_LISTEN=0.0.0.0
|
||||||
|
VNCSERVER_PROXYCLIENT_ADDRESS=$HOST_IP # or HOST_IPV6
|
||||||
|
|
||||||
|
NOVA_INSTANCES_PATH=/opt/stack/data/instances
|
||||||
|
|
||||||
|
# Enable the Ceilometer plugin for the compute agent
|
||||||
|
enable_plugin ceilometer https://opendev.org/openstack/ceilometer
|
||||||
|
disable_service ceilometer-acentral,ceilometer-collector,ceilometer-api
|
||||||
|
|
||||||
|
LOGFILE=$DEST/logs/stack.sh.log
|
||||||
|
LOGDAYS=2
|
||||||
|
|
||||||
|
[[post-config|$NOVA_CONF]]
|
||||||
|
[DEFAULT]
|
||||||
|
compute_monitors=cpu.virt_driver
|
||||||
|
[notifications]
|
||||||
|
# Enable both versioned and unversioned notifications. Watcher only
|
||||||
|
# uses versioned notifications but ceilometer uses unversioned. We
|
||||||
|
# can change this to just versioned when ceilometer handles versioned
|
||||||
|
# notifications from nova: https://bugs.launchpad.net/ceilometer/+bug/1665449
|
||||||
|
notification_format=both
|
||||||
57
devstack/local_gnocchi.conf.controller
Normal file
57
devstack/local_gnocchi.conf.controller
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
# Sample ``local.conf`` for controller node for Watcher development
|
||||||
|
# NOTE: Copy this file to the root DevStack directory for it to work properly.
|
||||||
|
|
||||||
|
[[local|localrc]]
|
||||||
|
|
||||||
|
ADMIN_PASSWORD=nomoresecrete
|
||||||
|
DATABASE_PASSWORD=stackdb
|
||||||
|
RABBIT_PASSWORD=stackqueue
|
||||||
|
SERVICE_PASSWORD=$ADMIN_PASSWORD
|
||||||
|
SERVICE_TOKEN=azertytoken
|
||||||
|
|
||||||
|
HOST_IP=192.168.42.1 # Change this to your controller node IP address
|
||||||
|
#HOST_IPV6=2001:db8::7
|
||||||
|
FLAT_INTERFACE=eth0
|
||||||
|
|
||||||
|
FIXED_RANGE=10.254.1.0/24 # Change this to whatever your network is
|
||||||
|
NETWORK_GATEWAY=10.254.1.1 # Change this for your network
|
||||||
|
|
||||||
|
MULTI_HOST=1
|
||||||
|
|
||||||
|
|
||||||
|
#Set this to FALSE if do not want to run watcher-api behind mod-wsgi
|
||||||
|
#WATCHER_USE_MOD_WSGI=TRUE
|
||||||
|
|
||||||
|
# This is the controller node, so disable nova-compute
|
||||||
|
disable_service n-cpu
|
||||||
|
|
||||||
|
# Enable the Watcher Dashboard plugin
|
||||||
|
enable_plugin watcher-dashboard https://opendev.org/openstack/watcher-dashboard
|
||||||
|
|
||||||
|
# Enable the Watcher plugin
|
||||||
|
enable_plugin watcher https://opendev.org/openstack/watcher
|
||||||
|
|
||||||
|
# Enable the Ceilometer plugin
|
||||||
|
enable_plugin ceilometer https://opendev.org/openstack/ceilometer
|
||||||
|
|
||||||
|
# This is the controller node, so disable the ceilometer compute agent
|
||||||
|
disable_service ceilometer-acompute
|
||||||
|
|
||||||
|
# Enable the ceilometer api explicitly(bug:1667678)
|
||||||
|
enable_service ceilometer-api
|
||||||
|
|
||||||
|
# Enable the Gnocchi plugin
|
||||||
|
enable_plugin gnocchi https://github.com/gnocchixyz/gnocchi
|
||||||
|
|
||||||
|
LOGFILE=$DEST/logs/stack.sh.log
|
||||||
|
LOGDAYS=2
|
||||||
|
|
||||||
|
[[post-config|$NOVA_CONF]]
|
||||||
|
[DEFAULT]
|
||||||
|
compute_monitors=cpu.virt_driver
|
||||||
|
[notifications]
|
||||||
|
# Enable both versioned and unversioned notifications. Watcher only
|
||||||
|
# uses versioned notifications but ceilometer uses unversioned. We
|
||||||
|
# can change this to just versioned when ceilometer handles versioned
|
||||||
|
# notifications from nova: https://bugs.launchpad.net/ceilometer/+bug/1665449
|
||||||
|
notification_format=both
|
||||||
@@ -1,5 +1,3 @@
|
|||||||
#!/bin/bash
|
|
||||||
#
|
|
||||||
# plugin.sh - DevStack plugin script to install watcher
|
# plugin.sh - DevStack plugin script to install watcher
|
||||||
|
|
||||||
# Save trace setting
|
# Save trace setting
|
||||||
@@ -38,6 +36,9 @@ if is_service_enabled watcher-api watcher-decision-engine watcher-applier; then
|
|||||||
# Start the watcher components
|
# Start the watcher components
|
||||||
echo_summary "Starting watcher"
|
echo_summary "Starting watcher"
|
||||||
start_watcher
|
start_watcher
|
||||||
|
elif [[ "$1" == "stack" && "$2" == "test-config" ]]; then
|
||||||
|
echo_summary "Configuring tempest for watcher"
|
||||||
|
configure_tempest_for_watcher
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "$1" == "unstack" ]]; then
|
if [[ "$1" == "unstack" ]]; then
|
||||||
|
|||||||
16
devstack/prometheus.yml
Normal file
16
devstack/prometheus.yml
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
global:
|
||||||
|
scrape_interval: 10s
|
||||||
|
scrape_configs:
|
||||||
|
- job_name: "node"
|
||||||
|
static_configs:
|
||||||
|
- targets: ["controller:3000"]
|
||||||
|
- targets: ["controller:9100"]
|
||||||
|
labels:
|
||||||
|
fqdn: "controller" # change the hostname here to your controller hostname
|
||||||
|
- targets: ["compute-1:9100"]
|
||||||
|
labels:
|
||||||
|
fqdn: "compute-1" # change the hostname here to your fist compute hostname
|
||||||
|
- targets: ["compute-2:9100"]
|
||||||
|
labels:
|
||||||
|
fqdn: "compute-2" # change the hostname her to your secondd compute hostname
|
||||||
|
# add as many blocks as compute nodes you have
|
||||||
@@ -1,5 +1,3 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
# ``upgrade-watcher``
|
# ``upgrade-watcher``
|
||||||
|
|
||||||
function configure_watcher_upgrade {
|
function configure_watcher_upgrade {
|
||||||
|
|||||||
@@ -70,7 +70,7 @@ then write_uwsgi_config "$WATCHER_UWSGI_CONF" "$WATCHER_UWSGI" "/infra-optim"
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Migrate the database
|
# Migrate the database
|
||||||
watcher-db-manage upgrade || die $LINO "DB migration error"
|
$WATCHER_BIN_DIR/watcher-db-manage upgrade || die $LINO "DB migration error"
|
||||||
|
|
||||||
start_watcher
|
start_watcher
|
||||||
|
|
||||||
|
|||||||
4
doc/dictionary.txt
Normal file
4
doc/dictionary.txt
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
thirdparty
|
||||||
|
assertin
|
||||||
|
notin
|
||||||
|
|
||||||
@@ -13,8 +13,6 @@
|
|||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
|
|
||||||
import importlib
|
import importlib
|
||||||
import inspect
|
import inspect
|
||||||
|
|
||||||
@@ -54,7 +52,7 @@ class BaseWatcherDirective(rst.Directive):
|
|||||||
obj_raw_docstring = obj.__init__.__doc__
|
obj_raw_docstring = obj.__init__.__doc__
|
||||||
|
|
||||||
if not obj_raw_docstring:
|
if not obj_raw_docstring:
|
||||||
# Raise a warning to make the tests fail wit doc8
|
# Raise a warning to make the tests fail with doc8
|
||||||
raise self.error("No docstring available for %s!" % obj)
|
raise self.error("No docstring available for %s!" % obj)
|
||||||
|
|
||||||
obj_docstring = inspect.cleandoc(obj_raw_docstring)
|
obj_docstring = inspect.cleandoc(obj_raw_docstring)
|
||||||
|
|||||||
@@ -14,6 +14,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "CANCELLED",
|
"state": "CANCELLED",
|
||||||
|
"status_message": null,
|
||||||
"action_plan": {
|
"action_plan": {
|
||||||
"watcher_object.namespace": "watcher",
|
"watcher_object.namespace": "watcher",
|
||||||
"watcher_object.version": "1.0",
|
"watcher_object.version": "1.0",
|
||||||
@@ -24,6 +25,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "CANCELLING",
|
"state": "CANCELLING",
|
||||||
|
"status_message": null,
|
||||||
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"deleted_at": null
|
"deleted_at": null
|
||||||
|
|||||||
@@ -24,6 +24,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "FAILED",
|
"state": "FAILED",
|
||||||
|
"status_message": null,
|
||||||
"action_plan": {
|
"action_plan": {
|
||||||
"watcher_object.namespace": "watcher",
|
"watcher_object.namespace": "watcher",
|
||||||
"watcher_object.version": "1.0",
|
"watcher_object.version": "1.0",
|
||||||
@@ -34,6 +35,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "CANCELLING",
|
"state": "CANCELLING",
|
||||||
|
"status_message": null,
|
||||||
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"deleted_at": null
|
"deleted_at": null
|
||||||
|
|||||||
@@ -14,6 +14,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "CANCELLING",
|
"state": "CANCELLING",
|
||||||
|
"status_message": null,
|
||||||
"action_plan": {
|
"action_plan": {
|
||||||
"watcher_object.namespace": "watcher",
|
"watcher_object.namespace": "watcher",
|
||||||
"watcher_object.version": "1.0",
|
"watcher_object.version": "1.0",
|
||||||
@@ -24,6 +25,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "CANCELLING",
|
"state": "CANCELLING",
|
||||||
|
"status_message": null,
|
||||||
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"deleted_at": null
|
"deleted_at": null
|
||||||
|
|||||||
@@ -13,6 +13,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "PENDING",
|
"state": "PENDING",
|
||||||
|
"status_message": null,
|
||||||
"action_plan": {
|
"action_plan": {
|
||||||
"watcher_object.namespace": "watcher",
|
"watcher_object.namespace": "watcher",
|
||||||
"watcher_object.version": "1.0",
|
"watcher_object.version": "1.0",
|
||||||
@@ -23,6 +24,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"deleted_at": null
|
"deleted_at": null
|
||||||
|
|||||||
@@ -13,6 +13,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "DELETED",
|
"state": "DELETED",
|
||||||
|
"status_message": null,
|
||||||
"action_plan": {
|
"action_plan": {
|
||||||
"watcher_object.namespace": "watcher",
|
"watcher_object.namespace": "watcher",
|
||||||
"watcher_object.version": "1.0",
|
"watcher_object.version": "1.0",
|
||||||
@@ -23,6 +24,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"deleted_at": null
|
"deleted_at": null
|
||||||
|
|||||||
@@ -14,6 +14,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "SUCCEEDED",
|
"state": "SUCCEEDED",
|
||||||
|
"status_message": null,
|
||||||
"action_plan": {
|
"action_plan": {
|
||||||
"watcher_object.namespace": "watcher",
|
"watcher_object.namespace": "watcher",
|
||||||
"watcher_object.version": "1.0",
|
"watcher_object.version": "1.0",
|
||||||
@@ -24,6 +25,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"deleted_at": null
|
"deleted_at": null
|
||||||
|
|||||||
@@ -24,6 +24,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "FAILED",
|
"state": "FAILED",
|
||||||
|
"status_message": "Action execution failed",
|
||||||
"action_plan": {
|
"action_plan": {
|
||||||
"watcher_object.namespace": "watcher",
|
"watcher_object.namespace": "watcher",
|
||||||
"watcher_object.version": "1.0",
|
"watcher_object.version": "1.0",
|
||||||
@@ -34,6 +35,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"deleted_at": null
|
"deleted_at": null
|
||||||
|
|||||||
@@ -14,6 +14,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"action_plan": {
|
"action_plan": {
|
||||||
"watcher_object.namespace": "watcher",
|
"watcher_object.namespace": "watcher",
|
||||||
"watcher_object.version": "1.0",
|
"watcher_object.version": "1.0",
|
||||||
@@ -24,6 +25,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"deleted_at": null
|
"deleted_at": null
|
||||||
|
|||||||
@@ -18,10 +18,12 @@
|
|||||||
"watcher_object.name": "ActionStateUpdatePayload",
|
"watcher_object.name": "ActionStateUpdatePayload",
|
||||||
"watcher_object.data": {
|
"watcher_object.data": {
|
||||||
"old_state": "PENDING",
|
"old_state": "PENDING",
|
||||||
"state": "ONGOING"
|
"state": "ONGOING",
|
||||||
|
"status_message": null
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"action_plan": {
|
"action_plan": {
|
||||||
"watcher_object.namespace": "watcher",
|
"watcher_object.namespace": "watcher",
|
||||||
"watcher_object.version": "1.0",
|
"watcher_object.version": "1.0",
|
||||||
@@ -32,6 +34,7 @@
|
|||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
"audit_uuid": "10a47dd1-4874-4298-91cf-eff046dbdb8d",
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"deleted_at": null
|
"deleted_at": null
|
||||||
|
|||||||
@@ -21,6 +21,7 @@
|
|||||||
"scope": [],
|
"scope": [],
|
||||||
"audit_type": "ONESHOT",
|
"audit_type": "ONESHOT",
|
||||||
"state": "SUCCEEDED",
|
"state": "SUCCEEDED",
|
||||||
|
"status_message": null,
|
||||||
"parameters": {},
|
"parameters": {},
|
||||||
"interval": null,
|
"interval": null,
|
||||||
"updated_at": null
|
"updated_at": null
|
||||||
@@ -29,6 +30,7 @@
|
|||||||
"uuid": "76be87bd-3422-43f9-93a0-e85a577e3061",
|
"uuid": "76be87bd-3422-43f9-93a0-e85a577e3061",
|
||||||
"fault": null,
|
"fault": null,
|
||||||
"state": "CANCELLED",
|
"state": "CANCELLED",
|
||||||
|
"status_message": null,
|
||||||
"global_efficacy": [],
|
"global_efficacy": [],
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"strategy": {
|
"strategy": {
|
||||||
|
|||||||
@@ -52,13 +52,15 @@
|
|||||||
"scope": [],
|
"scope": [],
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"audit_type": "ONESHOT",
|
"audit_type": "ONESHOT",
|
||||||
|
"status_message": null,
|
||||||
"interval": null,
|
"interval": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"state": "SUCCEEDED"
|
"state": "SUCCEEDED"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"global_efficacy": [],
|
"global_efficacy": [],
|
||||||
"state": "CANCELLING"
|
"state": "CANCELLING",
|
||||||
|
"status_message": null
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"timestamp": "2016-10-18 09:52:05.219414"
|
"timestamp": "2016-10-18 09:52:05.219414"
|
||||||
|
|||||||
@@ -21,6 +21,7 @@
|
|||||||
"scope": [],
|
"scope": [],
|
||||||
"audit_type": "ONESHOT",
|
"audit_type": "ONESHOT",
|
||||||
"state": "SUCCEEDED",
|
"state": "SUCCEEDED",
|
||||||
|
"status_message": null,
|
||||||
"parameters": {},
|
"parameters": {},
|
||||||
"interval": null,
|
"interval": null,
|
||||||
"updated_at": null
|
"updated_at": null
|
||||||
@@ -29,6 +30,7 @@
|
|||||||
"uuid": "76be87bd-3422-43f9-93a0-e85a577e3061",
|
"uuid": "76be87bd-3422-43f9-93a0-e85a577e3061",
|
||||||
"fault": null,
|
"fault": null,
|
||||||
"state": "CANCELLING",
|
"state": "CANCELLING",
|
||||||
|
"status_message": null,
|
||||||
"global_efficacy": [],
|
"global_efficacy": [],
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"strategy": {
|
"strategy": {
|
||||||
|
|||||||
@@ -33,6 +33,7 @@
|
|||||||
"interval": null,
|
"interval": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"state": "PENDING",
|
"state": "PENDING",
|
||||||
|
"status_message": null,
|
||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"updated_at": null
|
"updated_at": null
|
||||||
},
|
},
|
||||||
@@ -43,6 +44,7 @@
|
|||||||
"global_efficacy": {},
|
"global_efficacy": {},
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"state": "RECOMMENDED",
|
"state": "RECOMMENDED",
|
||||||
|
"status_message": null,
|
||||||
"updated_at": null
|
"updated_at": null
|
||||||
},
|
},
|
||||||
"watcher_object.namespace": "watcher",
|
"watcher_object.namespace": "watcher",
|
||||||
|
|||||||
@@ -18,6 +18,7 @@
|
|||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"state": "PENDING",
|
"state": "PENDING",
|
||||||
|
"status_message": null,
|
||||||
"created_at": "2016-10-18T09:52:05Z",
|
"created_at": "2016-10-18T09:52:05Z",
|
||||||
"parameters": {}
|
"parameters": {}
|
||||||
},
|
},
|
||||||
@@ -43,7 +44,8 @@
|
|||||||
"watcher_object.name": "StrategyPayload",
|
"watcher_object.name": "StrategyPayload",
|
||||||
"watcher_object.namespace": "watcher"
|
"watcher_object.namespace": "watcher"
|
||||||
},
|
},
|
||||||
"state": "DELETED"
|
"state": "DELETED",
|
||||||
|
"status_message": null
|
||||||
},
|
},
|
||||||
"watcher_object.version": "1.0",
|
"watcher_object.version": "1.0",
|
||||||
"watcher_object.name": "ActionPlanDeletePayload",
|
"watcher_object.name": "ActionPlanDeletePayload",
|
||||||
|
|||||||
@@ -22,6 +22,7 @@
|
|||||||
"scope": [],
|
"scope": [],
|
||||||
"audit_type": "ONESHOT",
|
"audit_type": "ONESHOT",
|
||||||
"state": "SUCCEEDED",
|
"state": "SUCCEEDED",
|
||||||
|
"status_message": null,
|
||||||
"parameters": {},
|
"parameters": {},
|
||||||
"interval": null,
|
"interval": null,
|
||||||
"updated_at": null
|
"updated_at": null
|
||||||
@@ -30,6 +31,7 @@
|
|||||||
"uuid": "76be87bd-3422-43f9-93a0-e85a577e3061",
|
"uuid": "76be87bd-3422-43f9-93a0-e85a577e3061",
|
||||||
"fault": null,
|
"fault": null,
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"global_efficacy": [],
|
"global_efficacy": [],
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"strategy": {
|
"strategy": {
|
||||||
|
|||||||
@@ -55,11 +55,13 @@
|
|||||||
"audit_type": "ONESHOT",
|
"audit_type": "ONESHOT",
|
||||||
"interval": null,
|
"interval": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"state": "PENDING"
|
"state": "PENDING",
|
||||||
|
"status_message": null
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"global_efficacy": [],
|
"global_efficacy": [],
|
||||||
"state": "ONGOING"
|
"state": "ONGOING",
|
||||||
|
"status_message": null
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"timestamp": "2016-10-18 09:52:05.219414"
|
"timestamp": "2016-10-18 09:52:05.219414"
|
||||||
|
|||||||
@@ -22,6 +22,7 @@
|
|||||||
"scope": [],
|
"scope": [],
|
||||||
"audit_type": "ONESHOT",
|
"audit_type": "ONESHOT",
|
||||||
"state": "PENDING",
|
"state": "PENDING",
|
||||||
|
"status_message": null,
|
||||||
"parameters": {},
|
"parameters": {},
|
||||||
"interval": null,
|
"interval": null,
|
||||||
"updated_at": null
|
"updated_at": null
|
||||||
@@ -30,6 +31,7 @@
|
|||||||
"uuid": "76be87bd-3422-43f9-93a0-e85a577e3061",
|
"uuid": "76be87bd-3422-43f9-93a0-e85a577e3061",
|
||||||
"fault": null,
|
"fault": null,
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"global_efficacy": [],
|
"global_efficacy": [],
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"strategy": {
|
"strategy": {
|
||||||
|
|||||||
@@ -16,6 +16,7 @@
|
|||||||
"interval": null,
|
"interval": null,
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "PENDING",
|
"state": "PENDING",
|
||||||
|
"status_message": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"parameters": {}
|
"parameters": {}
|
||||||
},
|
},
|
||||||
@@ -35,6 +36,7 @@
|
|||||||
"watcher_object.name": "ActionPlanStateUpdatePayload"
|
"watcher_object.name": "ActionPlanStateUpdatePayload"
|
||||||
},
|
},
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
"strategy_uuid": "cb3d0b58-4415-4d90-b75b-1e96878730e3",
|
||||||
"strategy": {
|
"strategy": {
|
||||||
|
|||||||
@@ -9,6 +9,7 @@
|
|||||||
"para1": 3.2
|
"para1": 3.2
|
||||||
},
|
},
|
||||||
"state": "PENDING",
|
"state": "PENDING",
|
||||||
|
"status_message": null,
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"goal_uuid": "bc830f84-8ae3-4fc6-8bc6-e3dd15e8b49a",
|
"goal_uuid": "bc830f84-8ae3-4fc6-8bc6-e3dd15e8b49a",
|
||||||
|
|||||||
@@ -9,6 +9,7 @@
|
|||||||
"para1": 3.2
|
"para1": 3.2
|
||||||
},
|
},
|
||||||
"state": "DELETED",
|
"state": "DELETED",
|
||||||
|
"status_message": null,
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"goal_uuid": "bc830f84-8ae3-4fc6-8bc6-e3dd15e8b49a",
|
"goal_uuid": "bc830f84-8ae3-4fc6-8bc6-e3dd15e8b49a",
|
||||||
|
|||||||
@@ -9,6 +9,7 @@
|
|||||||
"para1": 3.2
|
"para1": 3.2
|
||||||
},
|
},
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"fault": null,
|
"fault": null,
|
||||||
|
|||||||
@@ -9,6 +9,7 @@
|
|||||||
"para1": 3.2
|
"para1": 3.2
|
||||||
},
|
},
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"fault": {
|
"fault": {
|
||||||
|
|||||||
@@ -9,6 +9,7 @@
|
|||||||
"para1": 3.2
|
"para1": 3.2
|
||||||
},
|
},
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"fault": null,
|
"fault": null,
|
||||||
|
|||||||
@@ -9,6 +9,7 @@
|
|||||||
"para1": 3.2
|
"para1": 3.2
|
||||||
},
|
},
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"fault": null,
|
"fault": null,
|
||||||
|
|||||||
@@ -9,6 +9,7 @@
|
|||||||
"para1": 3.2
|
"para1": 3.2
|
||||||
},
|
},
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"fault": {
|
"fault": {
|
||||||
|
|||||||
@@ -9,6 +9,7 @@
|
|||||||
"para1": 3.2
|
"para1": 3.2
|
||||||
},
|
},
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"deleted_at": null,
|
"deleted_at": null,
|
||||||
"fault": null,
|
"fault": null,
|
||||||
|
|||||||
@@ -70,6 +70,7 @@
|
|||||||
"interval": null,
|
"interval": null,
|
||||||
"updated_at": null,
|
"updated_at": null,
|
||||||
"state": "ONGOING",
|
"state": "ONGOING",
|
||||||
|
"status_message": null,
|
||||||
"audit_type": "ONESHOT"
|
"audit_type": "ONESHOT"
|
||||||
},
|
},
|
||||||
"watcher_object.namespace": "watcher",
|
"watcher_object.namespace": "watcher",
|
||||||
|
|||||||
@@ -1,11 +1,10 @@
|
|||||||
# The order of packages is significant, because pip processes them in the order
|
sphinx>=2.1.1 # BSD
|
||||||
# of appearance. Changing the order has an impact on the overall integration
|
|
||||||
# process, which may cause wedges in the gate later.
|
|
||||||
openstackdocstheme>=1.20.0 # Apache-2.0
|
|
||||||
sphinx>=1.6.5,!=1.6.6,!=1.6.7,<2.0.0;python_version=='2.7' # BSD
|
|
||||||
sphinx>=1.6.5,!=1.6.6,!=1.6.7,!=2.1.0;python_version>='3.4' # BSD
|
|
||||||
sphinxcontrib-pecanwsme>=0.8.0 # Apache-2.0
|
|
||||||
sphinxcontrib-svg2pdfconverter>=0.1.0 # BSD
|
sphinxcontrib-svg2pdfconverter>=0.1.0 # BSD
|
||||||
reno>=2.7.0 # Apache-2.0
|
sphinxcontrib-pecanwsme>=0.8.0 # Apache-2.0
|
||||||
sphinxcontrib-apidoc>=0.2.0 # BSD
|
sphinxcontrib-apidoc>=0.2.0 # BSD
|
||||||
|
# openstack
|
||||||
os-api-ref>=1.4.0 # Apache-2.0
|
os-api-ref>=1.4.0 # Apache-2.0
|
||||||
|
openstackdocstheme>=2.2.1 # Apache-2.0
|
||||||
|
# releasenotes
|
||||||
|
reno>=3.1.0 # Apache-2.0
|
||||||
|
|
||||||
|
|||||||
@@ -34,7 +34,7 @@ own sections. However, the base *GMR* consists of several sections:
|
|||||||
|
|
||||||
Package
|
Package
|
||||||
Shows information about the package to which this process belongs, including
|
Shows information about the package to which this process belongs, including
|
||||||
version informations.
|
version information.
|
||||||
|
|
||||||
Threads
|
Threads
|
||||||
Shows stack traces and thread ids for each of the threads within this
|
Shows stack traces and thread ids for each of the threads within this
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ Administrator Guide
|
|||||||
apache-mod-wsgi
|
apache-mod-wsgi
|
||||||
gmr
|
gmr
|
||||||
policy
|
policy
|
||||||
ways-to-install
|
|
||||||
../strategies/index
|
../strategies/index
|
||||||
../datasources/index
|
../datasources/index
|
||||||
|
../contributor/notifications
|
||||||
|
../contributor/concurrency
|
||||||
|
|||||||
@@ -17,6 +17,14 @@
|
|||||||
Policies
|
Policies
|
||||||
========
|
========
|
||||||
|
|
||||||
|
.. warning::
|
||||||
|
|
||||||
|
JSON formatted policy file is deprecated since Watcher 6.0.0 (Wallaby).
|
||||||
|
This `oslopolicy-convert-json-to-yaml`__ tool will migrate your existing
|
||||||
|
JSON-formatted policy file to YAML in a backward-compatible way.
|
||||||
|
|
||||||
|
.. __: https://docs.openstack.org/oslo.policy/latest/cli/oslopolicy-convert-json-to-yaml.html
|
||||||
|
|
||||||
Watcher's public API calls may be restricted to certain sets of users using a
|
Watcher's public API calls may be restricted to certain sets of users using a
|
||||||
policy configuration file. This document explains exactly how policies are
|
policy configuration file. This document explains exactly how policies are
|
||||||
configured and what they apply to.
|
configured and what they apply to.
|
||||||
|
|||||||
@@ -281,11 +281,13 @@ previously created :ref:`Audit template <audit_template_definition>`:
|
|||||||
:width: 100%
|
:width: 100%
|
||||||
|
|
||||||
The :ref:`Administrator <administrator_definition>` also can specify type of
|
The :ref:`Administrator <administrator_definition>` also can specify type of
|
||||||
Audit and interval (in case of CONTINUOUS type). There is two types of Audit:
|
Audit and interval (in case of CONTINUOUS type). There is three types of Audit:
|
||||||
ONESHOT and CONTINUOUS. Oneshot Audit is launched once and if it succeeded
|
ONESHOT, CONTINUOUS and EVENT. ONESHOT Audit is launched once and if it
|
||||||
executed new action plan list will be provided. Continuous Audit creates
|
succeeded executed new action plan list will be provided; CONTINUOUS Audit
|
||||||
action plans with specified interval (in seconds); if action plan
|
creates action plans with specified interval (in seconds or cron format, cron
|
||||||
has been created, all previous action plans get CANCELLED state.
|
interval can be used like: ``*/5 * * * *``), if action plan
|
||||||
|
has been created, all previous action plans get CANCELLED state;
|
||||||
|
EVENT audit is launched when receiving webhooks API.
|
||||||
|
|
||||||
A message is sent on the :ref:`AMQP bus <amqp_bus_definition>` which triggers
|
A message is sent on the :ref:`AMQP bus <amqp_bus_definition>` which triggers
|
||||||
the Audit in the
|
the Audit in the
|
||||||
@@ -382,7 +384,9 @@ following methods of the :ref:`Action <action_definition>` handler:
|
|||||||
|
|
||||||
- **preconditions()**: this method will make sure that all conditions are met
|
- **preconditions()**: this method will make sure that all conditions are met
|
||||||
before executing the action (for example, it makes sure that an instance
|
before executing the action (for example, it makes sure that an instance
|
||||||
still exists before trying to migrate it).
|
still exists before trying to migrate it). If action specific preconditions
|
||||||
|
are not met in this phase, the Action is set to **SKIPPED** state and will
|
||||||
|
not be executed.
|
||||||
- **execute()**: this method is what triggers real commands on other
|
- **execute()**: this method is what triggers real commands on other
|
||||||
OpenStack services (such as Nova, ...) in order to change target resource
|
OpenStack services (such as Nova, ...) in order to change target resource
|
||||||
state. If the action is successfully executed, a notification message is
|
state. If the action is successfully executed, a notification message is
|
||||||
@@ -477,6 +481,39 @@ change to a new value:
|
|||||||
.. image:: ./images/action_plan_state_machine.png
|
.. image:: ./images/action_plan_state_machine.png
|
||||||
:width: 100%
|
:width: 100%
|
||||||
|
|
||||||
|
.. _action_state_machine:
|
||||||
|
|
||||||
|
Action State Machine
|
||||||
|
-------------------------
|
||||||
|
|
||||||
|
An :ref:`Action <action_definition>` has a life-cycle and its current state may
|
||||||
|
be one of the following:
|
||||||
|
|
||||||
|
- **PENDING** : the :ref:`Action <action_definition>` has not been executed
|
||||||
|
yet by the :ref:`Watcher Applier <watcher_applier_definition>`
|
||||||
|
- **SKIPPED** : the :ref:`Action <action_definition>` will not be executed
|
||||||
|
because a predefined skipping condition is found by
|
||||||
|
:ref:`Watcher Applier <watcher_applier_definition>` or is explicitly
|
||||||
|
skipped by the :ref:`Administrator <administrator_definition>`.
|
||||||
|
- **ONGOING** : the :ref:`Action <action_definition>` is currently being
|
||||||
|
processed by the :ref:`Watcher Applier <watcher_applier_definition>`
|
||||||
|
- **SUCCEEDED** : the :ref:`Action <action_definition>` has been executed
|
||||||
|
successfully
|
||||||
|
- **FAILED** : an error occurred while trying to execute the
|
||||||
|
:ref:`Action <action_definition>`
|
||||||
|
- **DELETED** : the :ref:`Action <action_definition>` is still stored in the
|
||||||
|
:ref:`Watcher database <watcher_database_definition>` but is not returned
|
||||||
|
any more through the Watcher APIs.
|
||||||
|
- **CANCELLED** : the :ref:`Action <action_definition>` was in **PENDING** or
|
||||||
|
**ONGOING** state and was cancelled by the
|
||||||
|
:ref:`Administrator <administrator_definition>`
|
||||||
|
|
||||||
|
The following diagram shows the different possible states of an
|
||||||
|
:ref:`Action <action_definition>` and what event makes the state change
|
||||||
|
change to a new value:
|
||||||
|
|
||||||
|
.. image:: ./images/action_state_machine.png
|
||||||
|
:width: 100%
|
||||||
|
|
||||||
|
|
||||||
.. _Watcher API: https://docs.openstack.org/api-ref/resource-optimization/
|
.. _Watcher API: https://docs.openstack.org/api-ref/resource-optimization/
|
||||||
|
|||||||
45
doc/source/conf.py
Executable file → Normal file
45
doc/source/conf.py
Executable file → Normal file
@@ -14,7 +14,6 @@
|
|||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
from watcher import version as watcher_version
|
|
||||||
from watcher import objects
|
from watcher import objects
|
||||||
|
|
||||||
objects.register_all()
|
objects.register_all()
|
||||||
@@ -36,7 +35,6 @@ extensions = [
|
|||||||
'sphinxcontrib.httpdomain',
|
'sphinxcontrib.httpdomain',
|
||||||
'sphinxcontrib.pecanwsme.rest',
|
'sphinxcontrib.pecanwsme.rest',
|
||||||
'stevedore.sphinxext',
|
'stevedore.sphinxext',
|
||||||
'wsmeext.sphinxext',
|
|
||||||
'ext.term',
|
'ext.term',
|
||||||
'ext.versioned_notifications',
|
'ext.versioned_notifications',
|
||||||
'oslo_config.sphinxconfiggen',
|
'oslo_config.sphinxconfiggen',
|
||||||
@@ -58,18 +56,8 @@ source_suffix = '.rst'
|
|||||||
master_doc = 'index'
|
master_doc = 'index'
|
||||||
|
|
||||||
# General information about the project.
|
# General information about the project.
|
||||||
project = u'Watcher'
|
project = 'Watcher'
|
||||||
copyright = u'OpenStack Foundation'
|
copyright = 'OpenStack Foundation'
|
||||||
|
|
||||||
# The version info for the project you're documenting, acts as replacement for
|
|
||||||
# |version| and |release|, also used in various other places throughout the
|
|
||||||
# built documents.
|
|
||||||
#
|
|
||||||
# The short X.Y version.
|
|
||||||
# The full version, including alpha/beta/rc tags.
|
|
||||||
release = watcher_version.version_info.release_string()
|
|
||||||
# The short X.Y version.
|
|
||||||
version = watcher_version.version_string
|
|
||||||
|
|
||||||
# A list of ignored prefixes for module index sorting.
|
# A list of ignored prefixes for module index sorting.
|
||||||
modindex_common_prefix = ['watcher.']
|
modindex_common_prefix = ['watcher.']
|
||||||
@@ -95,7 +83,7 @@ add_module_names = True
|
|||||||
suppress_warnings = ['app.add_directive']
|
suppress_warnings = ['app.add_directive']
|
||||||
|
|
||||||
# The name of the Pygments (syntax highlighting) style to use.
|
# The name of the Pygments (syntax highlighting) style to use.
|
||||||
pygments_style = 'sphinx'
|
pygments_style = 'native'
|
||||||
|
|
||||||
# -- Options for man page output --------------------------------------------
|
# -- Options for man page output --------------------------------------------
|
||||||
|
|
||||||
@@ -103,14 +91,14 @@ pygments_style = 'sphinx'
|
|||||||
# List of tuples 'sourcefile', 'target', u'title', u'Authors name', 'manual'
|
# List of tuples 'sourcefile', 'target', u'title', u'Authors name', 'manual'
|
||||||
|
|
||||||
man_pages = [
|
man_pages = [
|
||||||
('man/watcher-api', 'watcher-api', u'Watcher API Server',
|
('man/watcher-api', 'watcher-api', 'Watcher API Server',
|
||||||
[u'OpenStack'], 1),
|
['OpenStack'], 1),
|
||||||
('man/watcher-applier', 'watcher-applier', u'Watcher Applier',
|
('man/watcher-applier', 'watcher-applier', 'Watcher Applier',
|
||||||
[u'OpenStack'], 1),
|
['OpenStack'], 1),
|
||||||
('man/watcher-db-manage', 'watcher-db-manage',
|
('man/watcher-db-manage', 'watcher-db-manage',
|
||||||
u'Watcher Db Management Utility', [u'OpenStack'], 1),
|
'Watcher Db Management Utility', ['OpenStack'], 1),
|
||||||
('man/watcher-decision-engine', 'watcher-decision-engine',
|
('man/watcher-decision-engine', 'watcher-decision-engine',
|
||||||
u'Watcher Decision Engine', [u'OpenStack'], 1),
|
'Watcher Decision Engine', ['OpenStack'], 1),
|
||||||
]
|
]
|
||||||
|
|
||||||
# -- Options for HTML output --------------------------------------------------
|
# -- Options for HTML output --------------------------------------------------
|
||||||
@@ -126,12 +114,13 @@ html_theme = 'openstackdocs'
|
|||||||
# Output file base name for HTML help builder.
|
# Output file base name for HTML help builder.
|
||||||
htmlhelp_basename = '%sdoc' % project
|
htmlhelp_basename = '%sdoc' % project
|
||||||
|
|
||||||
html_last_updated_fmt = '%Y-%m-%d %H:%M'
|
|
||||||
|
|
||||||
#openstackdocstheme options
|
# openstackdocstheme options
|
||||||
repository_name = 'openstack/watcher'
|
openstackdocs_repo_name = 'openstack/watcher'
|
||||||
bug_project = 'watcher'
|
openstackdocs_pdf_link = True
|
||||||
bug_tag = ''
|
openstackdocs_auto_name = False
|
||||||
|
openstackdocs_bug_project = 'watcher'
|
||||||
|
openstackdocs_bug_tag = ''
|
||||||
|
|
||||||
# Grouping the document tree into LaTeX files. List of tuples
|
# Grouping the document tree into LaTeX files. List of tuples
|
||||||
# (source start file, target name, title, author, documentclass
|
# (source start file, target name, title, author, documentclass
|
||||||
@@ -139,8 +128,8 @@ bug_tag = ''
|
|||||||
latex_documents = [
|
latex_documents = [
|
||||||
('index',
|
('index',
|
||||||
'doc-watcher.tex',
|
'doc-watcher.tex',
|
||||||
u'%s Documentation' % project,
|
'Watcher Documentation',
|
||||||
u'OpenStack Foundation', 'manual'),
|
'OpenStack Foundation', 'manual'),
|
||||||
]
|
]
|
||||||
|
|
||||||
# If false, no module index is generated.
|
# If false, no module index is generated.
|
||||||
|
|||||||
@@ -194,11 +194,14 @@ The configuration file is organized into the following sections:
|
|||||||
* ``[watcher_applier]`` - Watcher Applier module configuration
|
* ``[watcher_applier]`` - Watcher Applier module configuration
|
||||||
* ``[watcher_decision_engine]`` - Watcher Decision Engine module configuration
|
* ``[watcher_decision_engine]`` - Watcher Decision Engine module configuration
|
||||||
* ``[oslo_messaging_rabbit]`` - Oslo Messaging RabbitMQ driver configuration
|
* ``[oslo_messaging_rabbit]`` - Oslo Messaging RabbitMQ driver configuration
|
||||||
* ``[ceilometer_client]`` - Ceilometer client configuration
|
|
||||||
* ``[cinder_client]`` - Cinder client configuration
|
* ``[cinder_client]`` - Cinder client configuration
|
||||||
* ``[glance_client]`` - Glance client configuration
|
* ``[glance_client]`` - Glance client configuration
|
||||||
|
* ``[gnocchi_client]`` - Gnocchi client configuration
|
||||||
|
* ``[ironic_client]`` - Ironic client configuration
|
||||||
|
* ``[keystone_client]`` - Keystone client configuration
|
||||||
* ``[nova_client]`` - Nova client configuration
|
* ``[nova_client]`` - Nova client configuration
|
||||||
* ``[neutron_client]`` - Neutron client configuration
|
* ``[neutron_client]`` - Neutron client configuration
|
||||||
|
* ``[placement_client]`` - Placement client configuration
|
||||||
|
|
||||||
The Watcher configuration file is expected to be named
|
The Watcher configuration file is expected to be named
|
||||||
``watcher.conf``. When starting Watcher, you can specify a different
|
``watcher.conf``. When starting Watcher, you can specify a different
|
||||||
@@ -372,7 +375,7 @@ You can configure and install Ceilometer by following the documentation below :
|
|||||||
#. https://docs.openstack.org/ceilometer/latest
|
#. https://docs.openstack.org/ceilometer/latest
|
||||||
|
|
||||||
The built-in strategy 'basic_consolidation' provided by watcher requires
|
The built-in strategy 'basic_consolidation' provided by watcher requires
|
||||||
"**compute.node.cpu.percent**" and "**cpu_util**" measurements to be collected
|
"**compute.node.cpu.percent**" and "**cpu**" measurements to be collected
|
||||||
by Ceilometer.
|
by Ceilometer.
|
||||||
The measurements available depend on the hypervisors that OpenStack manages on
|
The measurements available depend on the hypervisors that OpenStack manages on
|
||||||
the specific implementation.
|
the specific implementation.
|
||||||
@@ -426,20 +429,38 @@ Configure Cinder Notifications
|
|||||||
|
|
||||||
Watcher can also consume notifications generated by the Cinder services, in
|
Watcher can also consume notifications generated by the Cinder services, in
|
||||||
order to build or update, in real time, its cluster data model related to
|
order to build or update, in real time, its cluster data model related to
|
||||||
storage resources. To do so, you have to update the Cinder configuration
|
storage resources.
|
||||||
file on controller and volume nodes, in order to let Watcher receive Cinder
|
|
||||||
notifications in a dedicated ``watcher_notifications`` channel.
|
|
||||||
|
|
||||||
* In the file ``/etc/cinder/cinder.conf``, update the section
|
Cinder emits notifications on the ``notifications`` topic, in the openstack
|
||||||
``[oslo_messaging_notifications]``, by redefining the list of topics
|
control exchange (as it can be seen in the `Cinder conf`_).
|
||||||
into which Cinder services will publish events ::
|
|
||||||
|
* In the file ``/etc/cinder/cinder.conf``, the value of driver in the section
|
||||||
|
``[oslo_messaging_notifications]`` can't be noop.
|
||||||
|
|
||||||
[oslo_messaging_notifications]
|
[oslo_messaging_notifications]
|
||||||
driver = messagingv2
|
driver = messagingv2
|
||||||
topics = notifications,watcher_notifications
|
|
||||||
|
|
||||||
* Restart the Cinder services.
|
.. _`Cinder conf`: https://docs.openstack.org/cinder/latest/configuration/block-storage/samples/cinder.conf.html
|
||||||
|
|
||||||
|
Configure Watcher listening to the Notifications
|
||||||
|
================================================
|
||||||
|
|
||||||
|
To consume either Cinder or Nova notifications, (or both), Watcher must be
|
||||||
|
configured to listen to the notifications topics that Cinder and Nova emit.
|
||||||
|
|
||||||
|
Use the `notification_topics`_ config option to indicate to Watcher that it
|
||||||
|
should listen to the correct topics. By default, Cinder emits notifications
|
||||||
|
on ``openstack.notifications``, while Nova emits notifications on
|
||||||
|
``nova.versioned_notifications``. The Watcher conf should have the topics for
|
||||||
|
the desired notifications, below is an example for both Cinder and Nova::
|
||||||
|
|
||||||
|
[watcher_decision_engine]
|
||||||
|
|
||||||
|
...
|
||||||
|
|
||||||
|
notification_topics = nova.versioned_notifications,openstack.notifications
|
||||||
|
|
||||||
|
.. _`notification_topics`: https://docs.openstack.org/watcher/latest/configuration/watcher.html#watcher_decision_engine.notification_topics
|
||||||
|
|
||||||
Workers
|
Workers
|
||||||
=======
|
=======
|
||||||
|
|||||||
273
doc/source/contributor/concurrency.rst
Normal file
273
doc/source/contributor/concurrency.rst
Normal file
@@ -0,0 +1,273 @@
|
|||||||
|
===========
|
||||||
|
Concurrency
|
||||||
|
===========
|
||||||
|
|
||||||
|
Introduction
|
||||||
|
************
|
||||||
|
|
||||||
|
Modern processors typically contain multiple cores all capable of executing
|
||||||
|
instructions in parallel. Ensuring applications can fully utilize modern
|
||||||
|
underlying hardware requires developing with these concepts in mind. The
|
||||||
|
OpenStack foundation maintains a number of libraries to facilitate this
|
||||||
|
utilization, combined with constructs like CPython's GIL_ the proper use of
|
||||||
|
these concepts becomes more straightforward compared to other programming
|
||||||
|
languages.
|
||||||
|
|
||||||
|
The primary libraries maintained by OpenStack to facilitate concurrency are
|
||||||
|
futurist_ and taskflow_. Here futurist is a more straightforward and
|
||||||
|
lightweight library while taskflow is more advanced supporting features like
|
||||||
|
rollback mechanisms. Within Watcher both libraries are used to facilitate
|
||||||
|
concurrency.
|
||||||
|
|
||||||
|
.. _GIL: https://wiki.python.org/moin/GlobalInterpreterLock
|
||||||
|
.. _futurist: https://docs.openstack.org/futurist/latest/
|
||||||
|
.. _taskflow: https://docs.openstack.org/taskflow/latest/
|
||||||
|
|
||||||
|
Threadpool
|
||||||
|
**********
|
||||||
|
|
||||||
|
A threadpool is a collection of one or more threads typically called *workers*
|
||||||
|
to which tasks can be submitted. These submitted tasks will be scheduled by a
|
||||||
|
threadpool and subsequently executed. In the case of Python tasks typically are
|
||||||
|
bounded or unbounded methods while other programming languages like Java
|
||||||
|
require implementing an interface.
|
||||||
|
|
||||||
|
The order and amount of concurrency with which these tasks are executed is up
|
||||||
|
to the threadpool to decide. Some libraries like taskflow allow for either
|
||||||
|
strong or loose ordering of tasks while others like futurist might only support
|
||||||
|
loose ordering. Taskflow supports building tree-based hierarchies of dependent
|
||||||
|
tasks for example.
|
||||||
|
|
||||||
|
Upon submission of a task to a threadpool a so called future_ is returned.
|
||||||
|
These objects allow to determine information about the task such as if it is
|
||||||
|
currently being executed or if it has finished execution. When the task has
|
||||||
|
finished execution the future can also be used to retrieve what was returned by
|
||||||
|
the method.
|
||||||
|
|
||||||
|
Some libraries like futurist provide synchronization primitives for collections
|
||||||
|
of futures such as wait_for_any_. The following sections will cover different
|
||||||
|
types of concurrency used in various services of Watcher.
|
||||||
|
|
||||||
|
.. _future: https://docs.python.org/3/library/concurrent.futures.html
|
||||||
|
.. _wait_for_any: https://docs.openstack.org/futurist/latest/reference/index.html#waiters
|
||||||
|
|
||||||
|
|
||||||
|
Concurrency modes
|
||||||
|
#################
|
||||||
|
|
||||||
|
Evenlet has been the main concurrency library within the OpenStack community
|
||||||
|
for the last 10 years since the removal of twisted. Over the last few years,
|
||||||
|
the maintenance of eventlet has decreased and the efforts to remove the GIL
|
||||||
|
from Python (PEP 703), have fundamentally changed how concurrency is making
|
||||||
|
eventlet no longer viable. While transitioning to a new native thread
|
||||||
|
solution, Watcher services will be supporting both modes, with the usage of
|
||||||
|
native threading mode initially classified as ``experimental``.
|
||||||
|
|
||||||
|
It is possible to enable the new native threading mode by setting the following
|
||||||
|
environment variable in the corresponding service configuration:
|
||||||
|
|
||||||
|
.. code:: bash
|
||||||
|
|
||||||
|
OS_WATCHER_DISABLE_EVENTLET_PATCHING=true
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
The only service that supports two different concurrency modes is the
|
||||||
|
``decision engine``.
|
||||||
|
|
||||||
|
Decision engine concurrency
|
||||||
|
***************************
|
||||||
|
|
||||||
|
The concurrency in the decision engine is governed by two independent
|
||||||
|
threadpools. These threadpools can be configured as GreenThreadPoolExecutor_
|
||||||
|
or ThreadPoolExecutor_, both from the futurist_ library, depending on the
|
||||||
|
service configuration. One of these is used automatically and most contributors
|
||||||
|
will not interact with it while developing new features. The other threadpool
|
||||||
|
can frequently be used while developing new features or updating existing ones.
|
||||||
|
It is known as the DecisionEngineThreadpool and allows to achieve performance
|
||||||
|
improvements in network or I/O bound operations.
|
||||||
|
|
||||||
|
.. _GreenThreadPoolExecutor: https://docs.openstack.org/futurist/latest/reference/index.html#futurist.GreenThreadPoolExecutor
|
||||||
|
.. _ThreadPoolExecutor: https://docs.openstack.org/futurist/latest/reference/index.html#futurist.ThreadPoolExecutor
|
||||||
|
|
||||||
|
AuditEndpoint
|
||||||
|
#############
|
||||||
|
|
||||||
|
The first threadpool is used to allow multiple audits to be run in parallel.
|
||||||
|
In practice, however, only one audit can be run in parallel. This is due to
|
||||||
|
the data model used by audits being a singleton. To prevent audits destroying
|
||||||
|
each others data model one must wait for the other to complete before being
|
||||||
|
allowed to access this data model. A performance improvement could be achieved
|
||||||
|
by being more intelligent in the use, caching and construction of these
|
||||||
|
data models.
|
||||||
|
|
||||||
|
DecisionEngineThreadPool
|
||||||
|
########################
|
||||||
|
|
||||||
|
The second threadpool is used for generic tasks, typically networking and I/O
|
||||||
|
could benefit the most of this threadpool. Upon execution of an audit this
|
||||||
|
threadpool can be utilized to retrieve information from the Nova compute
|
||||||
|
service for instance. This second threadpool is a singleton and is shared
|
||||||
|
amongst concurrently running audits as a result the amount of workers is static
|
||||||
|
and independent from the amount of workers in the first threadpool. The use of
|
||||||
|
the :class:`~.DecisionEngineThreadpool` while building the Nova compute data
|
||||||
|
model is demonstrated to show how it can effectively be used.
|
||||||
|
|
||||||
|
In the following example a reference to the
|
||||||
|
:class:`~.DecisionEngineThreadpool` is stored in ``self.executor``. Here two
|
||||||
|
tasks are submitted one with function ``self._collect_aggregates`` and the
|
||||||
|
other function ``self._collect_zones``. With both ``self.executor.submit``
|
||||||
|
calls subsequent arguments are passed to the function. All subsequent arguments
|
||||||
|
are passed to the function being submitted as task following the common
|
||||||
|
``(fn, *args, **kwargs)`` signature. One of the original signatures would be
|
||||||
|
``def _collect_aggregates(host_aggregates, compute_nodes)`` for example.
|
||||||
|
|
||||||
|
.. code-block:: python
|
||||||
|
|
||||||
|
zone_aggregate_futures = {
|
||||||
|
self.executor.submit(
|
||||||
|
self._collect_aggregates, host_aggregates, compute_nodes),
|
||||||
|
self.executor.submit(
|
||||||
|
self._collect_zones, availability_zones, compute_nodes)
|
||||||
|
}
|
||||||
|
waiters.wait_for_all(zone_aggregate_futures)
|
||||||
|
|
||||||
|
The last statement of the example above waits on all futures to complete.
|
||||||
|
Similarly, ``waiters.wait_for_any`` will wait for any future of the specified
|
||||||
|
collection to complete. To simplify the usage of ``wait_for_any`` the
|
||||||
|
:class:`~.DecisiongEngineThreadpool` defines a ``do_while_futures`` method.
|
||||||
|
This method will iterate in a do_while loop over a collection of futures until
|
||||||
|
all of them have completed. The advantage of ``do_while_futures`` is that it
|
||||||
|
allows to immediately call a method as soon as a future finishes. The arguments
|
||||||
|
for this callback method can be supplied when calling ``do_while_futures``,
|
||||||
|
however, the first argument to the callback is always the future itself! If
|
||||||
|
the collection of futures can safely be modified ``do_while_futures_modify``
|
||||||
|
can be used and should have slightly better performance. The following example
|
||||||
|
will show how ``do_while_futures`` is used in the decision engine.
|
||||||
|
|
||||||
|
.. code-block:: python
|
||||||
|
|
||||||
|
# For every compute node from compute_nodes submit a task to gather the node it's information.
|
||||||
|
# List comprehension is used to store all the futures of the submitted tasks in node_futures.
|
||||||
|
node_futures = [self.executor.submit(
|
||||||
|
self.nova_helper.get_compute_node_by_name,
|
||||||
|
node, servers=True, detailed=True)
|
||||||
|
for node in compute_nodes]
|
||||||
|
LOG.debug("submitted {0} jobs".format(len(compute_nodes)))
|
||||||
|
|
||||||
|
future_instances = []
|
||||||
|
# do_while iterate over node_futures and upon completion of a future call
|
||||||
|
# self._compute_node_future with the future and future_instances as arguments.
|
||||||
|
self.executor.do_while_futures_modify(
|
||||||
|
node_futures, self._compute_node_future, future_instances)
|
||||||
|
|
||||||
|
# Wait for all instance jobs to finish
|
||||||
|
waiters.wait_for_all(future_instances)
|
||||||
|
|
||||||
|
Finally, let's demonstrate how powerful this ``do_while_futures`` can be by
|
||||||
|
showing what the ``compute_node_future`` callback does. First, it retrieves the
|
||||||
|
result from the future and adds the compute node to the data model. Afterwards,
|
||||||
|
it checks if the compute node has any associated instances and if so it submits
|
||||||
|
an additional task to the :class:`~.DecisionEngineThreadpool`. The future is
|
||||||
|
appended to the ``future_instances`` so ``waiters.wait_for_all`` can be called
|
||||||
|
on this list. This is important as otherwise the building of the data model
|
||||||
|
might return before all tasks for instances have finished.
|
||||||
|
|
||||||
|
.. code-block:: python
|
||||||
|
|
||||||
|
# Get the result from the future.
|
||||||
|
node_info = future.result()[0]
|
||||||
|
|
||||||
|
# Filter out baremetal nodes.
|
||||||
|
if node_info.hypervisor_type == 'ironic':
|
||||||
|
LOG.debug("filtering out baremetal node: %s", node_info)
|
||||||
|
return
|
||||||
|
|
||||||
|
# Add the compute node to the data model.
|
||||||
|
self.add_compute_node(node_info)
|
||||||
|
# Get the instances from the compute node.
|
||||||
|
instances = getattr(node_info, "servers", None)
|
||||||
|
# Do not submit job if there are no instances on compute node.
|
||||||
|
if instances is None:
|
||||||
|
LOG.info("No instances on compute_node: {0}".format(node_info))
|
||||||
|
return
|
||||||
|
# Submit a job to retrieve detailed information about the instances.
|
||||||
|
future_instances.append(
|
||||||
|
self.executor.submit(
|
||||||
|
self.add_instance_node, node_info, instances)
|
||||||
|
)
|
||||||
|
|
||||||
|
Without ``do_while_futures`` an additional ``waiters.wait_for_all`` would be
|
||||||
|
required in between the compute node tasks and the instance tasks. This would
|
||||||
|
cause the progress of the decision engine to stall as less and less tasks
|
||||||
|
remain active before the instance tasks could be submitted. This demonstrates
|
||||||
|
how ``do_while_futures`` can be used to achieve more constant utilization of
|
||||||
|
the underlying hardware.
|
||||||
|
|
||||||
|
Applier concurrency
|
||||||
|
*******************
|
||||||
|
|
||||||
|
The applier does not use the futurist_ GreenThreadPoolExecutor_ directly but
|
||||||
|
instead uses taskflow_. However, taskflow still utilizes a greenthreadpool.
|
||||||
|
This threadpool is initialized in the workflow engine called
|
||||||
|
:class:`~.DefaultWorkFlowEngine`. Currently Watcher supports one workflow
|
||||||
|
engine but the base class allows contributors to develop other workflow engines
|
||||||
|
as well. In taskflow tasks are created using different types of flows such as a
|
||||||
|
linear, unordered or a graph flow. The linear and graph flow allow for strong
|
||||||
|
ordering between individual tasks and it is for this reason that the workflow
|
||||||
|
engine utilizes a graph flow. The creation of tasks, subsequently linking them
|
||||||
|
into a graph like structure and submitting them is shown below.
|
||||||
|
|
||||||
|
.. code-block:: python
|
||||||
|
|
||||||
|
self.execution_rule = self.get_execution_rule(actions)
|
||||||
|
flow = gf.Flow("watcher_flow")
|
||||||
|
actions_uuid = {}
|
||||||
|
for a in actions:
|
||||||
|
task = TaskFlowActionContainer(a, self)
|
||||||
|
flow.add(task)
|
||||||
|
actions_uuid[a.uuid] = task
|
||||||
|
|
||||||
|
for a in actions:
|
||||||
|
for parent_id in a.parents:
|
||||||
|
flow.link(actions_uuid[parent_id], actions_uuid[a.uuid],
|
||||||
|
decider=self.decider)
|
||||||
|
|
||||||
|
e = engines.load(
|
||||||
|
flow, executor='greenthreaded', engine='parallel',
|
||||||
|
max_workers=self.config.max_workers)
|
||||||
|
e.run()
|
||||||
|
|
||||||
|
return flow
|
||||||
|
|
||||||
|
In the applier tasks are contained in a :class:`~.TaskFlowActionContainer`
|
||||||
|
which allows them to trigger events in the workflow engine. This way the
|
||||||
|
workflow engine can halt or take other actions while the action plan is being
|
||||||
|
executed based on the success or failure of individual actions. However, the
|
||||||
|
base workflow engine simply uses these notifies to store the result of
|
||||||
|
individual actions in the database. Additionally, since taskflow uses a graph
|
||||||
|
flow if any of the tasks would fail all children of this tasks not be executed
|
||||||
|
while ``do_revert`` will be triggered for all parents.
|
||||||
|
|
||||||
|
.. code-block:: python
|
||||||
|
|
||||||
|
class TaskFlowActionContainer(...):
|
||||||
|
...
|
||||||
|
def do_execute(self, *args, **kwargs):
|
||||||
|
...
|
||||||
|
result = self.action.execute()
|
||||||
|
if result is True:
|
||||||
|
return self.engine.notify(self._db_action,
|
||||||
|
objects.action.State.SUCCEEDED)
|
||||||
|
else:
|
||||||
|
self.engine.notify(self._db_action,
|
||||||
|
objects.action.State.FAILED)
|
||||||
|
|
||||||
|
class BaseWorkFlowEngine(...):
|
||||||
|
...
|
||||||
|
def notify(self, action, state):
|
||||||
|
db_action = objects.Action.get_by_uuid(self.context, action.uuid,
|
||||||
|
eager=True)
|
||||||
|
db_action.state = state
|
||||||
|
db_action.save()
|
||||||
|
return db_action
|
||||||
@@ -1,71 +1,111 @@
|
|||||||
..
|
============================
|
||||||
Except where otherwise noted, this document is licensed under Creative
|
So You Want to Contribute...
|
||||||
Commons Attribution 3.0 License. You can view the license at:
|
============================
|
||||||
|
|
||||||
https://creativecommons.org/licenses/by/3.0/
|
For general information on contributing to OpenStack, please check out the
|
||||||
|
`contributor guide <https://docs.openstack.org/contributors/>`_ to get started.
|
||||||
|
It covers all the basics that are common to all OpenStack projects:
|
||||||
|
the accounts you need, the basics of interacting with our Gerrit review system,
|
||||||
|
how we communicate as a community, etc.
|
||||||
|
|
||||||
.. _contributing:
|
Below will cover the more project specific information you need to get started
|
||||||
|
with Watcher.
|
||||||
|
|
||||||
=======================
|
Communication
|
||||||
Contributing to Watcher
|
~~~~~~~~~~~~~~
|
||||||
=======================
|
.. This would be a good place to put the channel you chat in as a project; when/
|
||||||
|
where your meeting is, the tags you prepend to your ML threads, etc.
|
||||||
If you're interested in contributing to the Watcher project,
|
|
||||||
the following will help get you started.
|
|
||||||
|
|
||||||
Contributor License Agreement
|
|
||||||
-----------------------------
|
|
||||||
|
|
||||||
.. index::
|
|
||||||
single: license; agreement
|
|
||||||
|
|
||||||
In order to contribute to the Watcher project, you need to have
|
|
||||||
signed OpenStack's contributor's agreement.
|
|
||||||
|
|
||||||
.. seealso::
|
|
||||||
|
|
||||||
* https://docs.openstack.org/infra/manual/developers.html
|
|
||||||
* https://wiki.openstack.org/CLA
|
|
||||||
|
|
||||||
LaunchPad Project
|
|
||||||
-----------------
|
|
||||||
|
|
||||||
Most of the tools used for OpenStack depend on a launchpad.net ID for
|
|
||||||
authentication. After signing up for a launchpad account, join the
|
|
||||||
"openstack" team to have access to the mailing list and receive
|
|
||||||
notifications of important events.
|
|
||||||
|
|
||||||
.. seealso::
|
|
||||||
|
|
||||||
* https://launchpad.net
|
|
||||||
* https://launchpad.net/watcher
|
|
||||||
* https://launchpad.net/openstack
|
|
||||||
|
|
||||||
|
|
||||||
Project Hosting Details
|
|
||||||
-----------------------
|
|
||||||
|
|
||||||
Bug tracker
|
|
||||||
https://launchpad.net/watcher
|
|
||||||
|
|
||||||
Mailing list (prefix subjects with ``[watcher]`` for faster responses)
|
|
||||||
http://lists.openstack.org/pipermail/openstack-discuss/
|
|
||||||
|
|
||||||
Wiki
|
|
||||||
https://wiki.openstack.org/Watcher
|
|
||||||
|
|
||||||
Code Hosting
|
|
||||||
https://opendev.org/openstack/watcher
|
|
||||||
|
|
||||||
Code Review
|
|
||||||
https://review.opendev.org/#/q/status:open+project:openstack/watcher,n,z
|
|
||||||
|
|
||||||
IRC Channel
|
IRC Channel
|
||||||
``#openstack-watcher`` (changelog_)
|
``#openstack-watcher`` (changelog_)
|
||||||
|
|
||||||
|
Mailing list(prefix subjects with ``[watcher]``)
|
||||||
|
http://lists.openstack.org/pipermail/openstack-discuss/
|
||||||
|
|
||||||
Weekly Meetings
|
Weekly Meetings
|
||||||
Bi-weekly, on Wednesdays at 08:00 UTC on odd weeks in the
|
Bi-weekly, on Wednesdays at 08:00 UTC on odd weeks in the
|
||||||
``#openstack-meeting-alt`` IRC channel (`meetings logs`_)
|
``#openstack-meeting-alt`` IRC channel (`meetings logs`_)
|
||||||
|
|
||||||
|
Meeting Agenda
|
||||||
|
https://wiki.openstack.org/wiki/Watcher_Meeting_Agenda
|
||||||
|
|
||||||
.. _changelog: http://eavesdrop.openstack.org/irclogs/%23openstack-watcher/
|
.. _changelog: http://eavesdrop.openstack.org/irclogs/%23openstack-watcher/
|
||||||
.. _meetings logs: http://eavesdrop.openstack.org/meetings/watcher/
|
.. _meetings logs: http://eavesdrop.openstack.org/meetings/watcher/
|
||||||
|
|
||||||
|
Contacting the Core Team
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
.. This section should list the core team, their irc nicks, emails, timezones etc.
|
||||||
|
If all this info is maintained elsewhere (i.e. a wiki), you can link to that
|
||||||
|
instead of enumerating everyone here.
|
||||||
|
|
||||||
|
+--------------------+---------------+------------------------------------+
|
||||||
|
| Name | IRC | Email |
|
||||||
|
+====================+===============+====================================+
|
||||||
|
| `Li Canwei`_ | licanwei | li.canwei2@zte.com.cn |
|
||||||
|
+--------------------+---------------+------------------------------------+
|
||||||
|
| `chen ke`_ | chenke | chen.ke14@zte.com.cn |
|
||||||
|
+--------------------+---------------+------------------------------------+
|
||||||
|
| `Corne Lukken`_ | dantalion | info@dantalion.nl |
|
||||||
|
+--------------------+---------------+------------------------------------+
|
||||||
|
| `su zhengwei`_ | suzhengwei | sugar-2008@163.com |
|
||||||
|
+--------------------+---------------+------------------------------------+
|
||||||
|
| `Yumeng Bao`_ | Yumeng | yumeng_bao@yahoo.com |
|
||||||
|
+--------------------+---------------+------------------------------------+
|
||||||
|
|
||||||
|
.. _Corne Lukken: https://launchpad.net/~dantalion
|
||||||
|
.. _Li Canwei: https://launchpad.net/~li-canwei2
|
||||||
|
.. _su zhengwei: https://launchpad.net/~sue.sam
|
||||||
|
.. _Yumeng Bao: https://launchpad.net/~yumeng-bao
|
||||||
|
.. _chen ke: https://launchpad.net/~chenker
|
||||||
|
|
||||||
|
New Feature Planning
|
||||||
|
~~~~~~~~~~~~~~~~~~~~
|
||||||
|
.. This section is for talking about the process to get a new feature in. Some
|
||||||
|
projects use blueprints, some want specs, some want both! Some projects
|
||||||
|
stick to a strict schedule when selecting what new features will be reviewed
|
||||||
|
for a release.
|
||||||
|
|
||||||
|
New feature will be discussed via IRC or ML (with [Watcher] prefix).
|
||||||
|
Watcher team uses blueprints in `Launchpad`_ to manage the new features.
|
||||||
|
|
||||||
|
.. _Launchpad: https://launchpad.net/watcher
|
||||||
|
|
||||||
|
Task Tracking
|
||||||
|
~~~~~~~~~~~~~~
|
||||||
|
.. This section is about where you track tasks- launchpad? storyboard?
|
||||||
|
is there more than one launchpad project? what's the name of the project
|
||||||
|
group in storyboard?
|
||||||
|
|
||||||
|
We track our tasks in Launchpad.
|
||||||
|
If you're looking for some smaller, easier work item to pick up and get started
|
||||||
|
on, search for the 'low-hanging-fruit' tag.
|
||||||
|
|
||||||
|
.. NOTE: If your tag is not 'low-hanging-fruit' please change the text above.
|
||||||
|
|
||||||
|
Reporting a Bug
|
||||||
|
~~~~~~~~~~~~~~~
|
||||||
|
.. Pretty self explanatory section, link directly to where people should report bugs for
|
||||||
|
your project.
|
||||||
|
|
||||||
|
You found an issue and want to make sure we are aware of it? You can do so
|
||||||
|
`HERE`_.
|
||||||
|
|
||||||
|
.. _HERE: https://bugs.launchpad.net/watcher
|
||||||
|
|
||||||
|
Getting Your Patch Merged
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
.. This section should have info about what it takes to get something merged.
|
||||||
|
Do you require one or two +2's before +W? Do some of your repos require
|
||||||
|
unit test changes with all patches? etc.
|
||||||
|
|
||||||
|
Due to the small number of core reviewers of the Watcher project,
|
||||||
|
we only need one +2 before +W (merge). All patches excepting for documentation
|
||||||
|
or typos fixes must have unit test.
|
||||||
|
|
||||||
|
Project Team Lead Duties
|
||||||
|
------------------------
|
||||||
|
.. this section is where you can put PTL specific duties not already listed in
|
||||||
|
the common PTL guide (linked below) or if you already have them written
|
||||||
|
up elsewhere, you can link to that doc here.
|
||||||
|
|
||||||
|
All common PTL duties are enumerated here in the `PTL guide <https://docs.openstack.org/project-team-guide/ptl.html>`_.
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ multinode environment to use.
|
|||||||
You can set up the Watcher services quickly and easily using a Watcher
|
You can set up the Watcher services quickly and easily using a Watcher
|
||||||
DevStack plugin. See `PluginModelDocs`_ for information on DevStack's plugin
|
DevStack plugin. See `PluginModelDocs`_ for information on DevStack's plugin
|
||||||
model. To enable the Watcher plugin with DevStack, add the following to the
|
model. To enable the Watcher plugin with DevStack, add the following to the
|
||||||
`[[local|localrc]]` section of your controller's `local.conf` to enable the
|
``[[local|localrc]]`` section of your controller's ``local.conf`` to enable the
|
||||||
Watcher plugin::
|
Watcher plugin::
|
||||||
|
|
||||||
enable_plugin watcher https://opendev.org/openstack/watcher
|
enable_plugin watcher https://opendev.org/openstack/watcher
|
||||||
@@ -31,64 +31,104 @@ Quick Devstack Instructions with Datasources
|
|||||||
============================================
|
============================================
|
||||||
|
|
||||||
Watcher requires a datasource to collect metrics from compute nodes and
|
Watcher requires a datasource to collect metrics from compute nodes and
|
||||||
instances in order to execute most strategies. To enable this a
|
instances in order to execute most strategies. To enable this two possible
|
||||||
`[[local|localrc]]` to setup DevStack for some of the supported datasources
|
examples of ``[[local|localrc]]`` to setup DevStack for some of the
|
||||||
is provided. These examples specify the minimal configuration parameters to
|
supported datasources is provided. These examples specify the minimal
|
||||||
get both Watcher and the datasource working but can be expanded is desired.
|
configuration parameters to get both Watcher and the datasource working
|
||||||
|
but can be expanded is desired.
|
||||||
|
The first example configures watcher to user prometheus as a datasource, while
|
||||||
|
the second example show how to use gnocchi as the datasource. The procedure is
|
||||||
|
equivalent, it just requires using the ``local.conf.controller`` and
|
||||||
|
``local.conf.compute`` in the first example and
|
||||||
|
``local_gnocchi.conf.controller`` and ``local_gnocchi.conf.compute`` in the
|
||||||
|
second.
|
||||||
|
|
||||||
|
Prometheus
|
||||||
|
----------
|
||||||
|
|
||||||
|
With the Prometheus datasource most of the metrics for compute nodes and
|
||||||
|
instances will work with the provided configuration but metrics that
|
||||||
|
require Ironic such as ``host_airflow and`` ``host_power`` will still be
|
||||||
|
unavailable as well as ``instance_l3_cpu_cache``
|
||||||
|
|
||||||
|
.. code-block:: ini
|
||||||
|
|
||||||
|
[[local|localrc]]
|
||||||
|
|
||||||
|
enable_plugin watcher https://opendev.org/openstack/watcher
|
||||||
|
enable_plugin watcher-dashboard https://opendev.org/openstack/watcher-dashboard
|
||||||
|
enable_plugin ceilometer https://opendev.org/openstack/ceilometer.git
|
||||||
|
enable_plugin aodh https://opendev.org/openstack/aodh
|
||||||
|
enable_plugin devstack-plugin-prometheus https://opendev.org/openstack/devstack-plugin-prometheus
|
||||||
|
enable_plugin sg-core https://github.com/openstack-k8s-operators/sg-core main
|
||||||
|
|
||||||
|
|
||||||
|
CEILOMETER_BACKEND=sg-core
|
||||||
|
[[post-config|$NOVA_CONF]]
|
||||||
|
[DEFAULT]
|
||||||
|
compute_monitors=cpu.virt_driver
|
||||||
|
|
||||||
Gnocchi
|
Gnocchi
|
||||||
-------
|
-------
|
||||||
|
|
||||||
With the Gnocchi datasource most of the metrics for compute nodes and
|
With the Gnocchi datasource most of the metrics for compute nodes and
|
||||||
instances will work with the provided configuration but metrics that
|
instances will work with the provided configuration but metrics that
|
||||||
require Ironic such as `host_airflow and` `host_power` will still be
|
require Ironic such as ``host_airflow and`` ``host_power`` will still be
|
||||||
unavailable as well as `instance_l3_cpu_cache`::
|
unavailable as well as ``instance_l3_cpu_cache``
|
||||||
|
|
||||||
[[local|localrc]]
|
.. code-block:: ini
|
||||||
enable_plugin watcher https://opendev.org/openstack/watcher
|
|
||||||
|
|
||||||
enable_plugin ceilometer https://opendev.org/openstack/ceilometer.git
|
[[local|localrc]]
|
||||||
CEILOMETER_BACKEND=gnocchi
|
|
||||||
|
|
||||||
enable_plugin aodh https://opendev.org/openstack/aodh
|
enable_plugin watcher https://opendev.org/openstack/watcher
|
||||||
enable_plugin panko https://opendev.org/openstack/panko
|
enable_plugin watcher-dashboard https://opendev.org/openstack/watcher-dashboard
|
||||||
|
enable_plugin ceilometer https://opendev.org/openstack/ceilometer.git
|
||||||
|
enable_plugin aodh https://opendev.org/openstack/aodh
|
||||||
|
enable_plugin panko https://opendev.org/openstack/panko
|
||||||
|
|
||||||
[[post-config|$NOVA_CONF]]
|
CEILOMETER_BACKEND=gnocchi
|
||||||
[DEFAULT]
|
[[post-config|$NOVA_CONF]]
|
||||||
compute_monitors=cpu.virt_driver
|
[DEFAULT]
|
||||||
|
compute_monitors=cpu.virt_driver
|
||||||
|
|
||||||
Detailed DevStack Instructions
|
Detailed DevStack Instructions
|
||||||
==============================
|
==============================
|
||||||
|
|
||||||
#. Obtain N (where N >= 1) servers (virtual machines preferred for DevStack).
|
#. Obtain N (where N >= 1) servers (virtual machines preferred for DevStack).
|
||||||
One of these servers will be the controller node while the others will be
|
One of these servers will be the controller node while the others will be
|
||||||
compute nodes. N is preferably >= 3 so that you have at least 2 compute
|
compute nodes. N is preferably >= 3 so that you have at least 2 compute
|
||||||
nodes, but in order to stand up the Watcher services only 1 server is
|
nodes, but in order to stand up the Watcher services only 1 server is
|
||||||
needed (i.e., no computes are needed if you want to just experiment with
|
needed (i.e., no computes are needed if you want to just experiment with
|
||||||
the Watcher services). These servers can be VMs running on your local
|
the Watcher services). These servers can be VMs running on your local
|
||||||
machine via VirtualBox if you prefer. DevStack currently recommends that
|
machine via VirtualBox if you prefer. DevStack currently recommends that
|
||||||
you use Ubuntu 16.04 LTS. The servers should also have connections to the
|
you use Ubuntu 16.04 LTS. The servers should also have connections to the
|
||||||
same network such that they are all able to communicate with one another.
|
same network such that they are all able to communicate with one another.
|
||||||
|
|
||||||
#. For each server, clone the DevStack repository and create the stack user::
|
#. For each server, clone the DevStack repository and create the stack user
|
||||||
|
|
||||||
sudo apt-get update
|
.. code-block:: bash
|
||||||
sudo apt-get install git
|
|
||||||
git clone https://opendev.org/openstack/devstack.git
|
sudo apt-get update
|
||||||
sudo ./devstack/tools/create-stack-user.sh
|
sudo apt-get install git
|
||||||
|
git clone https://opendev.org/openstack/devstack.git
|
||||||
|
sudo ./devstack/tools/create-stack-user.sh
|
||||||
|
|
||||||
Now you have a stack user that is used to run the DevStack processes. You
|
Now you have a stack user that is used to run the DevStack processes. You
|
||||||
may want to give your stack user a password to allow SSH via a password::
|
may want to give your stack user a password to allow SSH via a password
|
||||||
|
|
||||||
sudo passwd stack
|
.. code-block:: bash
|
||||||
|
|
||||||
#. Switch to the stack user and clone the DevStack repo again::
|
sudo passwd stack
|
||||||
|
|
||||||
sudo su stack
|
#. Switch to the stack user and clone the DevStack repo again
|
||||||
cd ~
|
|
||||||
git clone https://opendev.org/openstack/devstack.git
|
|
||||||
|
|
||||||
#. For each compute node, copy the provided `local.conf.compute`_ example file
|
.. code-block:: bash
|
||||||
|
|
||||||
|
sudo su stack
|
||||||
|
cd ~
|
||||||
|
git clone https://opendev.org/openstack/devstack.git
|
||||||
|
|
||||||
|
#. For each compute node, copy the provided `local.conf.compute`_
|
||||||
|
(`local_gnocchi.conf.compute`_ if deploying with gnocchi) example file
|
||||||
to the compute node's system at ~/devstack/local.conf. Make sure the
|
to the compute node's system at ~/devstack/local.conf. Make sure the
|
||||||
HOST_IP and SERVICE_HOST values are changed appropriately - i.e., HOST_IP
|
HOST_IP and SERVICE_HOST values are changed appropriately - i.e., HOST_IP
|
||||||
is set to the IP address of the compute node and SERVICE_HOST is set to the
|
is set to the IP address of the compute node and SERVICE_HOST is set to the
|
||||||
@@ -104,29 +144,47 @@ Detailed DevStack Instructions
|
|||||||
to configure similar configuration options for the projects providing those
|
to configure similar configuration options for the projects providing those
|
||||||
metrics.
|
metrics.
|
||||||
|
|
||||||
#. For the controller node, copy the provided `local.conf.controller`_ example
|
#. For the controller node, copy the provided `local.conf.controller`_
|
||||||
|
(`local_gnocchi.conf.controller`_ if deploying with gnocchi) example
|
||||||
file to the controller node's system at ~/devstack/local.conf. Make sure
|
file to the controller node's system at ~/devstack/local.conf. Make sure
|
||||||
the HOST_IP value is changed appropriately - i.e., HOST_IP is set to the IP
|
the HOST_IP value is changed appropriately - i.e., HOST_IP is set to the IP
|
||||||
address of the controller node.
|
address of the controller node.
|
||||||
|
|
||||||
Note: if you want to use another Watcher git repository (such as a local
|
.. NOTE::
|
||||||
one), then change the enable plugin line::
|
if you want to use another Watcher git repository (such as a local
|
||||||
|
one), then change the enable plugin line
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
enable_plugin watcher <your_local_git_repo> [optional_branch]
|
||||||
|
|
||||||
enable_plugin watcher <your_local_git_repo> [optional_branch]
|
|
||||||
|
|
||||||
If you do this, then the Watcher DevStack plugin will try to pull the
|
If you do this, then the Watcher DevStack plugin will try to pull the
|
||||||
python-watcherclient repo from <your_local_git_repo>/../, so either make
|
python-watcherclient repo from ``<your_local_git_repo>/../``, so either make
|
||||||
sure that is also available or specify WATCHERCLIENT_REPO in the local.conf
|
sure that is also available or specify WATCHERCLIENT_REPO in the ``local.conf``
|
||||||
file.
|
file.
|
||||||
|
|
||||||
Note: if you want to use a specific branch, specify WATCHER_BRANCH in the
|
.. NOTE::
|
||||||
local.conf file. By default it will use the master branch.
|
if you want to use a specific branch, specify WATCHER_BRANCH in the
|
||||||
|
local.conf file. By default it will use the master branch.
|
||||||
|
|
||||||
Note: watcher-api will default run under apache/httpd, set the variable
|
.. Note::
|
||||||
WATCHER_USE_MOD_WSGI=FALSE if you do not wish to run under apache/httpd.
|
watcher-api will default run under apache/httpd, set the variable
|
||||||
For development environment it is suggested to set WATHCER_USE_MOD_WSGI
|
WATCHER_USE_MOD_WSGI=FALSE if you do not wish to run under apache/httpd.
|
||||||
to FALSE. For Production environment it is suggested to keep it at the
|
For development environment it is suggested to set WATHCER_USE_MOD_WSGI
|
||||||
default TRUE value.
|
to FALSE. For Production environment it is suggested to keep it at the
|
||||||
|
default TRUE value.
|
||||||
|
|
||||||
|
#. If you want to use prometheus as a datasource, you need to provide a
|
||||||
|
Prometheus configuration with the compute nodes set as targets, so
|
||||||
|
it can consume their node-exporter metrics (if you are deploying watcher
|
||||||
|
with gnocchi as datasource you can skip this step altogether). Copy the
|
||||||
|
provided `prometheus.yml`_ example file and set the appropriate hostnames
|
||||||
|
for all the compute nodes (the example configures 2 of them plus the
|
||||||
|
controller, but you should add all of them if using more than 2 compute
|
||||||
|
nodes). Set the value of ``PROMETHEUS_CONFIG_FILE`` to the path of the
|
||||||
|
file you created in the local.conf file (the sample local.conf file uses
|
||||||
|
``$DEST`` as the default value for the prometheus config path).
|
||||||
|
|
||||||
#. Start stacking from the controller node::
|
#. Start stacking from the controller node::
|
||||||
|
|
||||||
@@ -134,11 +192,15 @@ Detailed DevStack Instructions
|
|||||||
|
|
||||||
#. Start stacking on each of the compute nodes using the same command.
|
#. Start stacking on each of the compute nodes using the same command.
|
||||||
|
|
||||||
#. Configure the environment for live migration via NFS. See the
|
.. seealso::
|
||||||
`Multi-Node DevStack Environment`_ section for more details.
|
Configure the environment for live migration via NFS. See the
|
||||||
|
`Multi-Node DevStack Environment`_ section for more details.
|
||||||
|
|
||||||
.. _local.conf.controller: https://github.com/openstack/watcher/tree/master/devstack/local.conf.controller
|
.. _local.conf.controller: https://github.com/openstack/watcher/tree/master/devstack/local.conf.controller
|
||||||
.. _local.conf.compute: https://github.com/openstack/watcher/tree/master/devstack/local.conf.compute
|
.. _local.conf.compute: https://github.com/openstack/watcher/tree/master/devstack/local.conf.compute
|
||||||
|
.. _local_gnocchi.conf.controller: https://github.com/openstack/watcher/tree/master/devstack/local_gnocchi.conf.controller
|
||||||
|
.. _local_gnocchi.conf.compute: https://github.com/openstack/watcher/tree/master/devstack/local_gnocchi.conf.compute
|
||||||
|
.. _prometheus.yml: https://github.com/openstack/watcher/tree/master/devstack/prometheus.yml
|
||||||
|
|
||||||
Multi-Node DevStack Environment
|
Multi-Node DevStack Environment
|
||||||
===============================
|
===============================
|
||||||
@@ -147,60 +209,19 @@ Since deploying Watcher with only a single compute node is not very useful, a
|
|||||||
few tips are given here for enabling a multi-node environment with live
|
few tips are given here for enabling a multi-node environment with live
|
||||||
migration.
|
migration.
|
||||||
|
|
||||||
Configuring NFS Server
|
.. NOTE::
|
||||||
----------------------
|
|
||||||
|
|
||||||
If you would like to use live migration for shared storage, then the controller
|
Nova supports live migration with local block storage so by default NFS
|
||||||
can serve as the NFS server if needed::
|
is not required and is considered an advance configuration.
|
||||||
|
The minimum requirements for live migration are:
|
||||||
|
|
||||||
sudo apt-get install nfs-kernel-server
|
- all hostnames are resolvable on each host
|
||||||
sudo mkdir -p /nfs/instances
|
- all hosts have a passwordless ssh key that is trusted by the other hosts
|
||||||
sudo chown stack:stack /nfs/instances
|
- all hosts have a known_hosts file that lists each hosts
|
||||||
|
|
||||||
Add an entry to `/etc/exports` with the appropriate gateway and netmask
|
If these requirements are met live migration will be possible.
|
||||||
information::
|
Shared storage such as ceph, booting form cinder volume or nfs are recommend
|
||||||
|
when testing evacuate if you want to preserve vm data.
|
||||||
/nfs/instances <gateway>/<netmask>(rw,fsid=0,insecure,no_subtree_check,async,no_root_squash)
|
|
||||||
|
|
||||||
Export the NFS directories::
|
|
||||||
|
|
||||||
sudo exportfs -ra
|
|
||||||
|
|
||||||
Make sure the NFS server is running::
|
|
||||||
|
|
||||||
sudo service nfs-kernel-server status
|
|
||||||
|
|
||||||
If the server is not running, then start it::
|
|
||||||
|
|
||||||
sudo service nfs-kernel-server start
|
|
||||||
|
|
||||||
Configuring NFS on Compute Node
|
|
||||||
-------------------------------
|
|
||||||
|
|
||||||
Each compute node needs to use the NFS server to hold the instance data::
|
|
||||||
|
|
||||||
sudo apt-get install rpcbind nfs-common
|
|
||||||
mkdir -p /opt/stack/data/instances
|
|
||||||
sudo mount <nfs-server-ip>:/nfs/instances /opt/stack/data/instances
|
|
||||||
|
|
||||||
If you would like to have the NFS directory automatically mounted on reboot,
|
|
||||||
then add the following to `/etc/fstab`::
|
|
||||||
|
|
||||||
<nfs-server-ip>:/nfs/instances /opt/stack/data/instances nfs auto 0 0
|
|
||||||
|
|
||||||
Edit `/etc/libvirt/libvirtd.conf` to make sure the following values are set::
|
|
||||||
|
|
||||||
listen_tls = 0
|
|
||||||
listen_tcp = 1
|
|
||||||
auth_tcp = "none"
|
|
||||||
|
|
||||||
Edit `/etc/default/libvirt-bin`::
|
|
||||||
|
|
||||||
libvirtd_opts="-d -l"
|
|
||||||
|
|
||||||
Restart the libvirt service::
|
|
||||||
|
|
||||||
sudo service libvirt-bin restart
|
|
||||||
|
|
||||||
Setting up SSH keys between compute nodes to enable live migration
|
Setting up SSH keys between compute nodes to enable live migration
|
||||||
------------------------------------------------------------------
|
------------------------------------------------------------------
|
||||||
@@ -229,22 +250,91 @@ must exist in every other compute node's stack user's authorized_keys file and
|
|||||||
every compute node's public ECDSA key needs to be in every other compute
|
every compute node's public ECDSA key needs to be in every other compute
|
||||||
node's root user's known_hosts file.
|
node's root user's known_hosts file.
|
||||||
|
|
||||||
Disable serial console
|
Configuring NFS Server (ADVANCED)
|
||||||
----------------------
|
---------------------------------
|
||||||
|
|
||||||
Serial console needs to be disabled for live migration to work.
|
If you would like to use live migration for shared storage, then the controller
|
||||||
|
can serve as the NFS server if needed
|
||||||
|
|
||||||
On both the controller and compute node, in /etc/nova/nova.conf
|
.. code-block:: bash
|
||||||
|
|
||||||
[serial_console]
|
sudo apt-get install nfs-kernel-server
|
||||||
enabled = False
|
sudo mkdir -p /nfs/instances
|
||||||
|
sudo chown stack:stack /nfs/instances
|
||||||
|
|
||||||
Alternatively, in devstack's local.conf:
|
Add an entry to ``/etc/exports`` with the appropriate gateway and netmask
|
||||||
|
information
|
||||||
|
|
||||||
[[post-config|$NOVA_CONF]]
|
|
||||||
[serial_console]
|
|
||||||
#enabled=false
|
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
/nfs/instances <gateway>/<netmask>(rw,fsid=0,insecure,no_subtree_check,async,no_root_squash)
|
||||||
|
|
||||||
|
Export the NFS directories
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
sudo exportfs -ra
|
||||||
|
|
||||||
|
Make sure the NFS server is running
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
sudo service nfs-kernel-server status
|
||||||
|
|
||||||
|
If the server is not running, then start it
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
sudo service nfs-kernel-server start
|
||||||
|
|
||||||
|
Configuring NFS on Compute Node (ADVANCED)
|
||||||
|
------------------------------------------
|
||||||
|
|
||||||
|
Each compute node needs to use the NFS server to hold the instance data
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
sudo apt-get install rpcbind nfs-common
|
||||||
|
mkdir -p /opt/stack/data/instances
|
||||||
|
sudo mount <nfs-server-ip>:/nfs/instances /opt/stack/data/instances
|
||||||
|
|
||||||
|
If you would like to have the NFS directory automatically mounted on reboot,
|
||||||
|
then add the following to ``/etc/fstab``
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
<nfs-server-ip>:/nfs/instances /opt/stack/data/instances nfs auto 0 0
|
||||||
|
|
||||||
|
Configuring libvirt to listen on tcp (ADVANCED)
|
||||||
|
-----------------------------------------------
|
||||||
|
|
||||||
|
.. NOTE::
|
||||||
|
|
||||||
|
By default nova will use ssh as a transport for live migration
|
||||||
|
if you have a low bandwidth connection you can use tcp instead
|
||||||
|
however this is generally not recommended.
|
||||||
|
|
||||||
|
|
||||||
|
Edit ``/etc/libvirt/libvirtd.conf`` to make sure the following values are set
|
||||||
|
|
||||||
|
.. code-block:: ini
|
||||||
|
|
||||||
|
listen_tls = 0
|
||||||
|
listen_tcp = 1
|
||||||
|
auth_tcp = "none"
|
||||||
|
|
||||||
|
Edit ``/etc/default/libvirt-bin``
|
||||||
|
|
||||||
|
.. code-block:: ini
|
||||||
|
|
||||||
|
libvirtd_opts="-d -l"
|
||||||
|
|
||||||
|
Restart the libvirt service
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
sudo service libvirt-bin restart
|
||||||
|
|
||||||
VNC server configuration
|
VNC server configuration
|
||||||
------------------------
|
------------------------
|
||||||
@@ -252,13 +342,18 @@ VNC server configuration
|
|||||||
The VNC server listening parameter needs to be set to any address so
|
The VNC server listening parameter needs to be set to any address so
|
||||||
that the server can accept connections from all of the compute nodes.
|
that the server can accept connections from all of the compute nodes.
|
||||||
|
|
||||||
On both the controller and compute node, in /etc/nova/nova.conf
|
On both the controller and compute node, in ``/etc/nova/nova.conf``
|
||||||
|
|
||||||
vncserver_listen = 0.0.0.0
|
.. code-block:: ini
|
||||||
|
|
||||||
Alternatively, in devstack's local.conf:
|
[vnc]
|
||||||
|
server_listen = "0.0.0.0"
|
||||||
|
|
||||||
VNCSERVER_LISTEN=0.0.0.0
|
Alternatively, in devstack's ``local.conf``:
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
VNCSERVER_LISTEN="0.0.0.0"
|
||||||
|
|
||||||
|
|
||||||
Environment final checkup
|
Environment final checkup
|
||||||
|
|||||||
@@ -43,7 +43,7 @@ different version of the above, please document your configuration here!
|
|||||||
Getting the latest code
|
Getting the latest code
|
||||||
=======================
|
=======================
|
||||||
|
|
||||||
Make a clone of the code from our `Git repository`:
|
Make a clone of the code from our ``Git repository``:
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
||||||
@@ -72,9 +72,9 @@ These dependencies can be installed from PyPi_ using the Python tool pip_.
|
|||||||
.. _PyPi: https://pypi.org/
|
.. _PyPi: https://pypi.org/
|
||||||
.. _pip: https://pypi.org/project/pip
|
.. _pip: https://pypi.org/project/pip
|
||||||
|
|
||||||
However, your system *may* need additional dependencies that `pip` (and by
|
However, your system *may* need additional dependencies that ``pip`` (and by
|
||||||
extension, PyPi) cannot satisfy. These dependencies should be installed
|
extension, PyPi) cannot satisfy. These dependencies should be installed
|
||||||
prior to using `pip`, and the installation method may vary depending on
|
prior to using ``pip``, and the installation method may vary depending on
|
||||||
your platform.
|
your platform.
|
||||||
|
|
||||||
* Ubuntu 16.04::
|
* Ubuntu 16.04::
|
||||||
@@ -141,7 +141,7 @@ forget to activate it:
|
|||||||
|
|
||||||
$ workon watcher
|
$ workon watcher
|
||||||
|
|
||||||
You should then be able to `import watcher` using Python without issue:
|
You should then be able to ``import watcher`` using Python without issue:
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
||||||
|
|||||||
@@ -1,8 +1,13 @@
|
|||||||
.. toctree::
|
==================
|
||||||
:maxdepth: 1
|
Contribution Guide
|
||||||
|
==================
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 2
|
||||||
|
|
||||||
|
contributing
|
||||||
environment
|
environment
|
||||||
devstack
|
devstack
|
||||||
notifications
|
|
||||||
testing
|
testing
|
||||||
rally_link
|
rally_link
|
||||||
|
release-guide
|
||||||
|
|||||||
@@ -1,3 +1,7 @@
|
|||||||
|
============
|
||||||
|
Plugin Guide
|
||||||
|
============
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: 1
|
:maxdepth: 1
|
||||||
|
|
||||||
|
|||||||
@@ -56,9 +56,6 @@ Here is an example showing how you can write a plugin called ``NewStrategy``:
|
|||||||
# filepath: thirdparty/new.py
|
# filepath: thirdparty/new.py
|
||||||
# import path: thirdparty.new
|
# import path: thirdparty.new
|
||||||
import abc
|
import abc
|
||||||
|
|
||||||
import six
|
|
||||||
|
|
||||||
from watcher._i18n import _
|
from watcher._i18n import _
|
||||||
from watcher.decision_engine.strategy.strategies import base
|
from watcher.decision_engine.strategy.strategies import base
|
||||||
|
|
||||||
@@ -303,6 +300,6 @@ Using that you can now query the values for that specific metric:
|
|||||||
.. code-block:: py
|
.. code-block:: py
|
||||||
|
|
||||||
avg_meter = self.datasource_backend.statistic_aggregation(
|
avg_meter = self.datasource_backend.statistic_aggregation(
|
||||||
instance.uuid, 'cpu_util', self.periods['instance'],
|
instance.uuid, 'instance_cpu_usage', self.periods['instance'],
|
||||||
self.granularity,
|
self.granularity,
|
||||||
aggregation=self.aggregation_method['instance'])
|
aggregation=self.aggregation_method['instance'])
|
||||||
|
|||||||
462
doc/source/contributor/release-guide.rst
Normal file
462
doc/source/contributor/release-guide.rst
Normal file
@@ -0,0 +1,462 @@
|
|||||||
|
..
|
||||||
|
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.
|
||||||
|
|
||||||
|
Chronological Release Liaison Guide
|
||||||
|
====================================
|
||||||
|
|
||||||
|
This is a reference guide that a release liaison may use as an aid, if
|
||||||
|
they choose.
|
||||||
|
|
||||||
|
Watcher uses the `Distributed Project Leadership (DPL)`__ model where
|
||||||
|
traditional release liaison responsibilities are distributed among various
|
||||||
|
liaisons. The release liaison is responsible for requesting releases,
|
||||||
|
reviewing Feature Freeze Exception (FFE) requests, and coordinating
|
||||||
|
release-related activities with the team.
|
||||||
|
|
||||||
|
.. __: https://governance.openstack.org/tc/reference/distributed-project-leadership.html
|
||||||
|
|
||||||
|
How to Use This Guide
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
This guide is organized chronologically to follow the OpenStack release
|
||||||
|
cycle from PTG planning through post-release activities. You can use it
|
||||||
|
in two ways:
|
||||||
|
|
||||||
|
**For New Release Liaisons**
|
||||||
|
Read through the entire guide to understand the full release cycle,
|
||||||
|
then bookmark it for reference during your term.
|
||||||
|
|
||||||
|
**For Experienced Release Liaisons**
|
||||||
|
Jump directly to the relevant section for your current phase in the
|
||||||
|
release cycle. Each major section corresponds to a specific time period.
|
||||||
|
|
||||||
|
**Key Navigation Tips**
|
||||||
|
* The :ref:`glossary` defines all acronyms and terminology used
|
||||||
|
* Time-sensitive activities are clearly marked by milestone phases
|
||||||
|
* DPL coordination notes indicate when team collaboration is required
|
||||||
|
|
||||||
|
DPL Liaison Coordination
|
||||||
|
-------------------------
|
||||||
|
|
||||||
|
Under the DPL model, the release liaison coordinates with other project
|
||||||
|
liaisons and the broader team for effective release management. The release
|
||||||
|
liaison has authority for release-specific decisions (FFE approvals, release
|
||||||
|
timing, etc.) while major process changes and strategic decisions require
|
||||||
|
team consensus.
|
||||||
|
|
||||||
|
This coordination approach ensures that:
|
||||||
|
|
||||||
|
* Release activities are properly managed by a dedicated liaison
|
||||||
|
* Team input is gathered for significant decisions
|
||||||
|
* Other liaisons are informed of release-related developments that may
|
||||||
|
affect their areas
|
||||||
|
* Release processes remain responsive while maintaining team alignment
|
||||||
|
|
||||||
|
Project Context
|
||||||
|
---------------
|
||||||
|
|
||||||
|
* Coordinate with the watcher meeting (chair rotates each meeting, with
|
||||||
|
volunteers requested at the end of each meeting)
|
||||||
|
|
||||||
|
* Meeting etherpad: https://etherpad.opendev.org/p/openstack-watcher-irc-meeting
|
||||||
|
* IRC channel: #openstack-watcher
|
||||||
|
|
||||||
|
* Get acquainted with the release schedule
|
||||||
|
|
||||||
|
* Example: https://releases.openstack.org/<current-release>/schedule.html
|
||||||
|
|
||||||
|
* Familiarize with Watcher project repositories and tracking:
|
||||||
|
|
||||||
|
Watcher Main Repository
|
||||||
|
`Primary codebase for the Watcher service <https://opendev.org/openstack/watcher>`__
|
||||||
|
|
||||||
|
Watcher Dashboard
|
||||||
|
`Horizon plugin for Watcher UI <https://opendev.org/openstack/watcher-dashboard>`__
|
||||||
|
|
||||||
|
Watcher Tempest Plugin
|
||||||
|
`Integration tests <https://opendev.org/openstack/watcher-tempest-plugin>`__ (follows tempest cycle)
|
||||||
|
|
||||||
|
Python Watcher Client
|
||||||
|
`Command-line client and Python library <https://opendev.org/openstack/python-watcherclient>`__
|
||||||
|
|
||||||
|
Watcher Specifications
|
||||||
|
`Design specifications <https://opendev.org/openstack/watcher-specs>`__ (not released)
|
||||||
|
|
||||||
|
Watcher Launchpad (Main)
|
||||||
|
`Primary bug and feature tracking <https://launchpad.net/watcher>`__
|
||||||
|
|
||||||
|
Watcher Dashboard Launchpad
|
||||||
|
`Dashboard-specific tracking <https://launchpad.net/watcher-dashboard/>`__
|
||||||
|
|
||||||
|
Watcher Tempest Plugin Launchpad
|
||||||
|
`Test plugin tracking <https://launchpad.net/watcher-tempest-plugin>`__
|
||||||
|
|
||||||
|
Python Watcher Client Launchpad
|
||||||
|
`Client library tracking <https://launchpad.net/python-watcherclient>`__
|
||||||
|
|
||||||
|
Project Team Gathering
|
||||||
|
----------------------
|
||||||
|
|
||||||
|
Event Liaison Coordination
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
* Work with the project team to select an event liaison for PTG coordination.
|
||||||
|
The event liaison is responsible for:
|
||||||
|
|
||||||
|
* Reserving sufficient space at PTG for the project team's meetings
|
||||||
|
* Putting out an agenda for team meetings
|
||||||
|
* Ensuring meetings are organized and facilitated
|
||||||
|
* Documenting meeting results
|
||||||
|
|
||||||
|
* If no event liaison is selected, these duties revert to the release liaison.
|
||||||
|
|
||||||
|
* Monitor for OpenStack Events team queries on the mailing list requesting
|
||||||
|
event liaison volunteers - teams not responding may lose event
|
||||||
|
representation.
|
||||||
|
|
||||||
|
PTG Planning and Execution
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
* Create PTG planning etherpad, retrospective etherpad and alert about it in
|
||||||
|
watcher meeting and dev mailing list
|
||||||
|
|
||||||
|
* Example: https://etherpad.opendev.org/p/apr2025-ptg-watcher
|
||||||
|
|
||||||
|
* Run sessions at the PTG (if no event liaison is selected)
|
||||||
|
|
||||||
|
* Do a retro of the previous cycle
|
||||||
|
|
||||||
|
* Coordinate with team to establish agreement on the agenda for this release:
|
||||||
|
|
||||||
|
Review Days Planning
|
||||||
|
Determine number of review days allocated for specs and implementation work
|
||||||
|
|
||||||
|
Freeze Dates Coordination
|
||||||
|
Define Spec approval and Feature freeze dates through team collaboration
|
||||||
|
|
||||||
|
Release Schedule Modifications
|
||||||
|
Modify the OpenStack release schedule if needed by proposing new dates
|
||||||
|
(Example: https://review.opendev.org/c/openstack/releases/+/877094)
|
||||||
|
|
||||||
|
* Discuss the implications of the `SLURP or non-SLURP`__ current release
|
||||||
|
|
||||||
|
.. __: https://governance.openstack.org/tc/resolutions/20220210-release-cadence-adjustment.html
|
||||||
|
|
||||||
|
* Sign up for group photo at the PTG (if applicable)
|
||||||
|
|
||||||
|
|
||||||
|
After PTG
|
||||||
|
---------
|
||||||
|
|
||||||
|
* Send PTG session summaries to the dev mailing list
|
||||||
|
|
||||||
|
* Add `RFE bugs`__ if you have action items that are simple to do but
|
||||||
|
without a owner yet.
|
||||||
|
|
||||||
|
* Update IRC #openstack-watcher channel topic to point to new
|
||||||
|
development-planning etherpad.
|
||||||
|
|
||||||
|
.. __: https://bugs.launchpad.net/watcher/+bugs?field.tag=rfe
|
||||||
|
|
||||||
|
A few weeks before milestone 1
|
||||||
|
------------------------------
|
||||||
|
|
||||||
|
* Plan a spec review day
|
||||||
|
|
||||||
|
* Periodically check the series goals others have proposed in the “Set series
|
||||||
|
goals” link:
|
||||||
|
|
||||||
|
* Example: https://blueprints.launchpad.net/watcher/<current-release>/+setgoals
|
||||||
|
|
||||||
|
Milestone 1
|
||||||
|
-----------
|
||||||
|
|
||||||
|
* Release watcher and python-watcherclient via the openstack/releases repo.
|
||||||
|
Watcher follows the `cycle-with-intermediary`__ release model:
|
||||||
|
|
||||||
|
.. __: https://releases.openstack.org/reference/release_models.html#cycle-with-intermediary
|
||||||
|
|
||||||
|
* Create actual releases (not just launchpad bookkeeping) at milestone points
|
||||||
|
* No launchpad milestone releases are created for intermediary releases
|
||||||
|
* When releasing the first version of a library for the cycle,
|
||||||
|
bump
|
||||||
|
the minor version to leave room for future stable branch
|
||||||
|
releases
|
||||||
|
|
||||||
|
* Release stable branches of watcher
|
||||||
|
|
||||||
|
Stable Branch Release Process
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Prepare the stable branch for evaluation:
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
git checkout <stable branch>
|
||||||
|
git log --no-merges <last tag>..
|
||||||
|
|
||||||
|
Analyze commits to determine version bump according to semantic versioning.
|
||||||
|
|
||||||
|
Semantic Versioning Guidelines
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Choose version bump based on changes since last release:
|
||||||
|
|
||||||
|
Major Version (X)
|
||||||
|
Backward-incompatible changes that break existing APIs
|
||||||
|
|
||||||
|
Minor Version (Y)
|
||||||
|
New features that maintain backward compatibility
|
||||||
|
|
||||||
|
Patch Version (Z)
|
||||||
|
Bug fixes that maintain backward compatibility
|
||||||
|
|
||||||
|
Release Command Usage
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Generate the release using OpenStack tooling:
|
||||||
|
|
||||||
|
* Use the `new-release command
|
||||||
|
<https://releases.openstack.org/reference/using.html#using-new-release-command>`__
|
||||||
|
* Propose the release with version according to chosen semver format
|
||||||
|
(x.y.z)
|
||||||
|
|
||||||
|
Summit
|
||||||
|
------
|
||||||
|
|
||||||
|
``Responsibility Precedence for Summit Activities:``
|
||||||
|
|
||||||
|
1. ``Project Update/Onboarding Liaisons`` (if appointed):
|
||||||
|
|
||||||
|
* ``Project Update Liaison``: responsible for giving the project update
|
||||||
|
showcasing team's achievements for the cycle to the community
|
||||||
|
* ``Project Onboarding Liaison``: responsible for giving/facilitating
|
||||||
|
onboarding sessions during events for the project's community
|
||||||
|
|
||||||
|
2. ``Event Liaison`` (if no Project Update/Onboarding liaisons exist):
|
||||||
|
|
||||||
|
* Coordinates all Summit activities including project updates and onboarding
|
||||||
|
|
||||||
|
3. ``Release Liaison`` (if no Event Liaison is appointed):
|
||||||
|
|
||||||
|
* Work with the team to ensure Summit activities are properly handled:
|
||||||
|
|
||||||
|
* Prepare the project update presentation
|
||||||
|
* Prepare the on-boarding session materials
|
||||||
|
* Prepare the operator meet-and-greet session
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
The team can choose to not have a Summit presence if desired.
|
||||||
|
|
||||||
|
A few weeks before milestone 2
|
||||||
|
------------------------------
|
||||||
|
|
||||||
|
* Plan a spec review day (optional)
|
||||||
|
|
||||||
|
Milestone 2
|
||||||
|
-----------
|
||||||
|
|
||||||
|
* Spec freeze (unless changed by team agreement at PTG)
|
||||||
|
|
||||||
|
* Release watcher and python-watcherclient (if needed)
|
||||||
|
|
||||||
|
* Stable branch releases of watcher
|
||||||
|
|
||||||
|
|
||||||
|
Shortly after spec freeze
|
||||||
|
-------------------------
|
||||||
|
|
||||||
|
* Create a blueprint status etherpad to help track, especially non-priority
|
||||||
|
blueprint work, to help things get done by Feature Freeze (FF). Example:
|
||||||
|
|
||||||
|
* https://etherpad.opendev.org/p/watcher-<release>-blueprint-status
|
||||||
|
|
||||||
|
* Create or review a patch to add the next release’s specs directory so people
|
||||||
|
can propose specs for next release after spec freeze for current release
|
||||||
|
|
||||||
|
Milestone 3
|
||||||
|
-----------
|
||||||
|
|
||||||
|
* Feature freeze day
|
||||||
|
|
||||||
|
* Client library freeze, release python-watcherclient
|
||||||
|
|
||||||
|
* Close out all blueprints, including “catch all” blueprints like mox,
|
||||||
|
versioned notifications
|
||||||
|
|
||||||
|
* Stable branch releases of watcher
|
||||||
|
|
||||||
|
* Start writing the `cycle highlights
|
||||||
|
<https://docs.openstack.org/project-team-guide/release-management.html#cycle-highlights>`__
|
||||||
|
|
||||||
|
Week following milestone 3
|
||||||
|
--------------------------
|
||||||
|
|
||||||
|
* If warranted, announce the FFE (feature freeze exception process) to
|
||||||
|
have people propose FFE requests to a special etherpad where they will
|
||||||
|
be reviewed.
|
||||||
|
FFE requests should first be discussed in the IRC meeting with the
|
||||||
|
requester present.
|
||||||
|
The release liaison has final decision on granting exceptions.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
if there is only a short time between FF and RC1 (lately it’s been 2
|
||||||
|
weeks), then the only likely candidates will be low-risk things that are
|
||||||
|
almost done. In general Feature Freeze exceptions should not be granted,
|
||||||
|
instead features should be deferred and reproposed for the next
|
||||||
|
development
|
||||||
|
cycle. FFE never extend beyond RC1.
|
||||||
|
|
||||||
|
* Mark the max microversion for the release in the
|
||||||
|
:doc:`/contributor/api_microversion_history`
|
||||||
|
|
||||||
|
A few weeks before RC
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
* Update the release status etherpad with RC1 todos and keep track
|
||||||
|
of them in meetings
|
||||||
|
|
||||||
|
* Go through the bug list and identify any rc-potential bugs and tag them
|
||||||
|
|
||||||
|
RC
|
||||||
|
--
|
||||||
|
|
||||||
|
* Follow the standard OpenStack release checklist process
|
||||||
|
|
||||||
|
* If we want to drop backward-compat RPC code, we have to do a major RPC
|
||||||
|
version bump and coordinate it just before the major release:
|
||||||
|
|
||||||
|
* https://wiki.openstack.org/wiki/RpcMajorVersionUpdates
|
||||||
|
|
||||||
|
* Example: https://review.opendev.org/541035
|
||||||
|
|
||||||
|
* “Merge latest translations" means translation patches
|
||||||
|
|
||||||
|
* Check for translations with:
|
||||||
|
|
||||||
|
* https://review.opendev.org/#/q/status:open+project:openstack/watcher+branch:master+topic:zanata/translations
|
||||||
|
|
||||||
|
* Should NOT plan to have more than one RC if possible. RC2 should only happen
|
||||||
|
if there was a mistake and something was missed for RC, or a new regression
|
||||||
|
was discovered
|
||||||
|
|
||||||
|
* Write the reno prelude for the release GA
|
||||||
|
|
||||||
|
* Example: https://review.opendev.org/644412
|
||||||
|
|
||||||
|
* Push the cycle-highlights in marketing-friendly sentences and propose to the
|
||||||
|
openstack/releases repo. Usually based on reno prelude but made more readable
|
||||||
|
and friendly
|
||||||
|
|
||||||
|
* Example: https://review.opendev.org/644697
|
||||||
|
|
||||||
|
Immediately after RC
|
||||||
|
--------------------
|
||||||
|
|
||||||
|
* Look for bot proposed changes to reno and stable/<cycle>
|
||||||
|
|
||||||
|
* Create the launchpad series for the next cycle
|
||||||
|
|
||||||
|
* Set the development focus of the project to the new cycle series
|
||||||
|
|
||||||
|
* Set the status of the new series to “active development”
|
||||||
|
|
||||||
|
* Set the last series status to “current stable branch release”
|
||||||
|
|
||||||
|
* Set the previous to last series status to “supported”
|
||||||
|
|
||||||
|
* Repeat launchpad steps ^ for all watcher deliverables.
|
||||||
|
|
||||||
|
* Make sure the specs directory for the next cycle gets created so people can
|
||||||
|
start proposing new specs
|
||||||
|
|
||||||
|
* Make sure to move implemented specs from the previous release
|
||||||
|
|
||||||
|
* Move implemented specs manually (TODO: add tox command in future)
|
||||||
|
|
||||||
|
* Remove template files:
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
rm doc/source/specs/<release>/index.rst
|
||||||
|
rm doc/source/specs/<release>/template.rst
|
||||||
|
|
||||||
|
* Ensure liaison handoff: either transition to new release liaison or confirm
|
||||||
|
reappointment for next cycle
|
||||||
|
|
||||||
|
.. _glossary:
|
||||||
|
|
||||||
|
Glossary
|
||||||
|
--------
|
||||||
|
|
||||||
|
DPL
|
||||||
|
Distributed Project Leadership - A governance model where traditional PTL
|
||||||
|
responsibilities are distributed among various specialized liaisons.
|
||||||
|
|
||||||
|
FFE
|
||||||
|
Feature Freeze Exception - A request to add a feature after the feature
|
||||||
|
freeze deadline. Should be used sparingly for low-risk, nearly
|
||||||
|
complete features.
|
||||||
|
|
||||||
|
GA
|
||||||
|
General Availability - The final release of a software version for
|
||||||
|
production use.
|
||||||
|
|
||||||
|
PTG
|
||||||
|
Project Team Gathering - A collaborative event where OpenStack project
|
||||||
|
teams meet to plan and coordinate development activities.
|
||||||
|
|
||||||
|
RC
|
||||||
|
Release Candidate - A pre-release version that is potentially the final
|
||||||
|
version, pending testing and bug fixes.
|
||||||
|
|
||||||
|
RFE
|
||||||
|
Request for Enhancement - A type of bug report requesting a new feature
|
||||||
|
or enhancement to existing functionality.
|
||||||
|
|
||||||
|
SLURP
|
||||||
|
Skip Level Upgrade Release Process - An extended maintenance release
|
||||||
|
that allows skipping intermediate versions during upgrades.
|
||||||
|
|
||||||
|
Summit
|
||||||
|
OpenStack Summit - A conference where the OpenStack community gathers
|
||||||
|
for presentations, discussions, and project updates.
|
||||||
|
|
||||||
|
Miscellaneous Notes
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
How to track launchpad blueprint approvals
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Core team approves blueprints through team consensus. The release liaison
|
||||||
|
ensures launchpad status is updated correctly after core team approval:
|
||||||
|
|
||||||
|
* Set the approver as the core team member who approved the spec
|
||||||
|
|
||||||
|
* Set the Direction => Approved and Definition => Approved and make sure the
|
||||||
|
Series goal is set to the current release. If code is already proposed, set
|
||||||
|
Implementation => Needs Code Review
|
||||||
|
|
||||||
|
* Optional: add a comment to the Whiteboard explaining the approval,
|
||||||
|
with a date
|
||||||
|
(launchpad does not record approval dates). For example: “We discussed this
|
||||||
|
in the team meeting and agreed to approve this for <release>. -- <nick>
|
||||||
|
<YYYYMMDD>”
|
||||||
|
|
||||||
|
How to complete a launchpad blueprint
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
* Set Implementation => Implemented. The completion date will be recorded by
|
||||||
|
launchpad
|
||||||
@@ -4,9 +4,9 @@
|
|||||||
|
|
||||||
https://creativecommons.org/licenses/by/3.0/
|
https://creativecommons.org/licenses/by/3.0/
|
||||||
|
|
||||||
=======
|
=================
|
||||||
Testing
|
Developer Testing
|
||||||
=======
|
=================
|
||||||
|
|
||||||
.. _unit_tests:
|
.. _unit_tests:
|
||||||
|
|
||||||
@@ -15,7 +15,7 @@ Unit tests
|
|||||||
|
|
||||||
All unit tests should be run using `tox`_. Before running the unit tests, you
|
All unit tests should be run using `tox`_. Before running the unit tests, you
|
||||||
should download the latest `watcher`_ from the github. To run the same unit
|
should download the latest `watcher`_ from the github. To run the same unit
|
||||||
tests that are executing onto `Gerrit`_ which includes ``py35``, ``py27`` and
|
tests that are executing onto `Gerrit`_ which includes ``py36``, ``py37`` and
|
||||||
``pep8``, you can issue the following command::
|
``pep8``, you can issue the following command::
|
||||||
|
|
||||||
$ git clone https://opendev.org/openstack/watcher
|
$ git clone https://opendev.org/openstack/watcher
|
||||||
@@ -26,8 +26,8 @@ tests that are executing onto `Gerrit`_ which includes ``py35``, ``py27`` and
|
|||||||
If you only want to run one of the aforementioned, you can then issue one of
|
If you only want to run one of the aforementioned, you can then issue one of
|
||||||
the following::
|
the following::
|
||||||
|
|
||||||
$ tox -e py35
|
$ tox -e py36
|
||||||
$ tox -e py27
|
$ tox -e py37
|
||||||
$ tox -e pep8
|
$ tox -e pep8
|
||||||
|
|
||||||
.. _tox: https://tox.readthedocs.org/
|
.. _tox: https://tox.readthedocs.org/
|
||||||
@@ -38,7 +38,7 @@ If you only want to run specific unit test code and don't like to waste time
|
|||||||
waiting for all unit tests to execute, you can add parameters ``--`` followed
|
waiting for all unit tests to execute, you can add parameters ``--`` followed
|
||||||
by a regex string::
|
by a regex string::
|
||||||
|
|
||||||
$ tox -e py27 -- watcher.tests.api
|
$ tox -e py37 -- watcher.tests.api
|
||||||
|
|
||||||
.. _tempest_tests:
|
.. _tempest_tests:
|
||||||
|
|
||||||
|
|||||||
157
doc/source/datasources/aetos.rst
Normal file
157
doc/source/datasources/aetos.rst
Normal file
@@ -0,0 +1,157 @@
|
|||||||
|
================
|
||||||
|
Aetos datasource
|
||||||
|
================
|
||||||
|
|
||||||
|
Synopsis
|
||||||
|
--------
|
||||||
|
The Aetos datasource allows Watcher to use an Aetos reverse proxy server as the
|
||||||
|
source for collected metrics used by the Watcher decision engine. Aetos is a
|
||||||
|
multi-tenant aware reverse proxy that sits in front of a Prometheus server and
|
||||||
|
provides Keystone authentication and role-based access control. The Aetos
|
||||||
|
datasource uses Keystone service discovery to locate the Aetos endpoint and
|
||||||
|
requires authentication via Keystone tokens.
|
||||||
|
|
||||||
|
Requirements
|
||||||
|
-------------
|
||||||
|
The Aetos datasource has the following requirements:
|
||||||
|
|
||||||
|
* An Aetos reverse proxy server deployed in front of Prometheus
|
||||||
|
* Aetos service registered in Keystone with service type 'metric-storage'
|
||||||
|
* Valid Keystone credentials for Watcher with admin or service role
|
||||||
|
* Prometheus metrics with appropriate labels (same as direct Prometheus access)
|
||||||
|
|
||||||
|
Like the Prometheus datasource, it is required that Prometheus metrics contain
|
||||||
|
a label to identify the hostname of the exporter from which the metric was
|
||||||
|
collected. This is used to match against the Watcher cluster model
|
||||||
|
``ComputeNode.hostname``. The default for this label is ``fqdn`` and in the
|
||||||
|
prometheus scrape configs would look like:
|
||||||
|
|
||||||
|
.. code-block::
|
||||||
|
|
||||||
|
scrape_configs:
|
||||||
|
- job_name: node
|
||||||
|
static_configs:
|
||||||
|
- targets: ['10.1.2.3:9100']
|
||||||
|
labels:
|
||||||
|
fqdn: "testbox.controlplane.domain"
|
||||||
|
|
||||||
|
This default can be overridden when a deployer uses a different label to
|
||||||
|
identify the exporter host (for example ``hostname`` or ``host``, or any other
|
||||||
|
label, as long as it identifies the host).
|
||||||
|
|
||||||
|
Internally this label is used in creating ``fqdn_instance_labels``, containing
|
||||||
|
the list of values assigned to the label in the Prometheus targets.
|
||||||
|
The elements of the resulting fqdn_instance_labels are expected to match the
|
||||||
|
``ComputeNode.hostname`` used in the Watcher decision engine cluster model.
|
||||||
|
An example ``fqdn_instance_labels`` is the following:
|
||||||
|
|
||||||
|
.. code-block::
|
||||||
|
|
||||||
|
[
|
||||||
|
'ena.controlplane.domain',
|
||||||
|
'dio.controlplane.domain',
|
||||||
|
'tria.controlplane.domain',
|
||||||
|
]
|
||||||
|
|
||||||
|
For instance metrics, it is required that Prometheus contains a label
|
||||||
|
with the uuid of the OpenStack instance in each relevant metric. By default,
|
||||||
|
the datasource will look for the label ``resource``. The
|
||||||
|
``instance_uuid_label`` config option in watcher.conf allows deployers to
|
||||||
|
override this default to any other label name that stores the ``uuid``.
|
||||||
|
|
||||||
|
Limitations
|
||||||
|
-----------
|
||||||
|
The Aetos datasource shares the same limitations as the Prometheus datasource:
|
||||||
|
|
||||||
|
The current implementation doesn't support the ``statistic_series`` function of
|
||||||
|
the Watcher ``class DataSourceBase``. It is expected that the
|
||||||
|
``statistic_aggregation`` function (which is implemented) is sufficient in
|
||||||
|
providing the **current** state of the managed resources in the cluster.
|
||||||
|
The ``statistic_aggregation`` function defaults to querying back 300 seconds,
|
||||||
|
starting from the present time (the time period is a function parameter and
|
||||||
|
can be set to a value as required). Implementing the ``statistic_series`` can
|
||||||
|
always be re-visited if the requisite interest and work cycles are volunteered
|
||||||
|
by the interested parties.
|
||||||
|
|
||||||
|
One further note about a limitation in the implemented
|
||||||
|
``statistic_aggregation`` function. This function is defined with a
|
||||||
|
``granularity`` parameter, to be used when querying whichever of the Watcher
|
||||||
|
``DataSourceBase`` metrics providers. In the case of Aetos (like Prometheus),
|
||||||
|
we do not fetch and then process individual metrics across the specified time
|
||||||
|
period. Instead we use the PromQL querying operators and functions, so that the
|
||||||
|
server itself will process the request across the specified parameters and
|
||||||
|
then return the result. So ``granularity`` parameter is redundant and remains
|
||||||
|
unused for the Aetos implementation of ``statistic_aggregation``. The
|
||||||
|
granularity of the data fetched by Prometheus server is specified in
|
||||||
|
configuration as the server ``scrape_interval`` (current default 15 seconds).
|
||||||
|
|
||||||
|
Additionally, there is a slight performance impact compared to direct
|
||||||
|
Prometheus access. Since Aetos acts as a reverse proxy in front of Prometheus,
|
||||||
|
there is an additional step for each request, resulting in slightly longer
|
||||||
|
delays.
|
||||||
|
|
||||||
|
Configuration
|
||||||
|
-------------
|
||||||
|
A deployer must set the ``datasources`` parameter to include ``aetos``
|
||||||
|
under the watcher_datasources section of watcher.conf (or add ``aetos`` in
|
||||||
|
datasources for a specific strategy if preferred eg. under the
|
||||||
|
``[watcher_strategies.workload_stabilization]`` section).
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
Having both Prometheus and Aetos datasources configured at the same time
|
||||||
|
is not supported and will result in a configuration error. Allowing this
|
||||||
|
can be investigated in the future if a need or a proper use case is
|
||||||
|
identified.
|
||||||
|
|
||||||
|
The watcher.conf configuration file is also used to set the parameter values
|
||||||
|
required by the Watcher Aetos data source. The configuration can be
|
||||||
|
added under the ``[aetos_client]`` section and the available options are
|
||||||
|
duplicated below from the code as they are self documenting:
|
||||||
|
|
||||||
|
.. code-block::
|
||||||
|
|
||||||
|
cfg.StrOpt('interface',
|
||||||
|
default='public',
|
||||||
|
choices=['internal', 'public', 'admin'],
|
||||||
|
help="Type of endpoint to use in keystoneclient."),
|
||||||
|
cfg.StrOpt('region_name',
|
||||||
|
help="Region in Identity service catalog to use for "
|
||||||
|
"communication with the OpenStack service."),
|
||||||
|
cfg.StrOpt('fqdn_label',
|
||||||
|
default='fqdn',
|
||||||
|
help="The label that Prometheus uses to store the fqdn of "
|
||||||
|
"exporters. Defaults to 'fqdn'."),
|
||||||
|
cfg.StrOpt('instance_uuid_label',
|
||||||
|
default='resource',
|
||||||
|
help="The label that Prometheus uses to store the uuid of "
|
||||||
|
"OpenStack instances. Defaults to 'resource'."),
|
||||||
|
|
||||||
|
|
||||||
|
Authentication and Service Discovery
|
||||||
|
------------------------------------
|
||||||
|
Unlike the Prometheus datasource which requires explicit host and port
|
||||||
|
configuration, the Aetos datasource uses Keystone service discovery to
|
||||||
|
automatically locate the Aetos endpoint. The datasource:
|
||||||
|
|
||||||
|
1. Uses the configured Keystone credentials to authenticate
|
||||||
|
2. Searches the service catalog for a service with type 'metric-storage'
|
||||||
|
3. Uses the discovered endpoint URL to connect to Aetos
|
||||||
|
4. Attaches a Keystone token to each request for authentication
|
||||||
|
|
||||||
|
If the Aetos service is not registered in Keystone, the datasource will
|
||||||
|
fail to initialize and prevent the decision engine from starting.
|
||||||
|
|
||||||
|
So a sample watcher.conf configured to use the Aetos datasource would look
|
||||||
|
like the following:
|
||||||
|
|
||||||
|
.. code-block::
|
||||||
|
|
||||||
|
[watcher_datasources]
|
||||||
|
|
||||||
|
datasources = aetos
|
||||||
|
|
||||||
|
[aetos_client]
|
||||||
|
|
||||||
|
interface = public
|
||||||
|
region_name = RegionOne
|
||||||
|
fqdn_label = fqdn
|
||||||
@@ -90,15 +90,15 @@ parameter will need to specify the type of http protocol and the use of
|
|||||||
plain text http is strongly discouraged due to the transmission of the access
|
plain text http is strongly discouraged due to the transmission of the access
|
||||||
token. Additionally the path to the proxy interface needs to be supplied as
|
token. Additionally the path to the proxy interface needs to be supplied as
|
||||||
well in case Grafana is placed in a sub directory of the web server. An example
|
well in case Grafana is placed in a sub directory of the web server. An example
|
||||||
would be: `https://mygrafana.org/api/datasource/proxy/` were
|
would be: ``https://mygrafana.org/api/datasource/proxy/`` were
|
||||||
`/api/datasource/proxy` is the default path without any subdirectories.
|
``/api/datasource/proxy`` is the default path without any subdirectories.
|
||||||
Likewise, this parameter can not be placed in the yaml.
|
Likewise, this parameter can not be placed in the yaml.
|
||||||
|
|
||||||
To prevent many errors from occurring and potentially filing the logs files it
|
To prevent many errors from occurring and potentially filing the logs files it
|
||||||
is advised to specify the desired datasource in the configuration as it would
|
is advised to specify the desired datasource in the configuration as it would
|
||||||
prevent the datasource manager from having to iterate and try possible
|
prevent the datasource manager from having to iterate and try possible
|
||||||
datasources with the launch of each audit. To do this specify `datasources` in
|
datasources with the launch of each audit. To do this specify
|
||||||
the `[watcher_datasources]` group.
|
``datasources`` in the ``[watcher_datasources]`` group.
|
||||||
|
|
||||||
The current configuration that is required to be placed in the traditional
|
The current configuration that is required to be placed in the traditional
|
||||||
configuration file would look like the following:
|
configuration file would look like the following:
|
||||||
@@ -120,7 +120,7 @@ traditional configuration file or in the yaml, however, it is not advised to
|
|||||||
mix and match but in the case it does occur the yaml would override the
|
mix and match but in the case it does occur the yaml would override the
|
||||||
settings from the traditional configuration file. All five of these parameters
|
settings from the traditional configuration file. All five of these parameters
|
||||||
are dictionaries mapping specific metrics to a configuration parameter. For
|
are dictionaries mapping specific metrics to a configuration parameter. For
|
||||||
instance the `project_id_map` will specify the specific project id in Grafana
|
instance the ``project_id_map`` will specify the specific project id in Grafana
|
||||||
to be used. The parameters are named as follow:
|
to be used. The parameters are named as follow:
|
||||||
|
|
||||||
* project_id_map
|
* project_id_map
|
||||||
@@ -149,10 +149,10 @@ project_id
|
|||||||
|
|
||||||
The project id's can only be determined by someone with the admin role in
|
The project id's can only be determined by someone with the admin role in
|
||||||
Grafana as that role is required to open the list of projects. The list of
|
Grafana as that role is required to open the list of projects. The list of
|
||||||
projects can be found on `/datasources` in the web interface but
|
projects can be found on ``/datasources`` in the web interface but
|
||||||
unfortunately it does not immediately display the project id. To display
|
unfortunately it does not immediately display the project id. To display
|
||||||
the id one can best hover the mouse over the projects and the url will show the
|
the id one can best hover the mouse over the projects and the url will show the
|
||||||
project id's for example `/datasources/edit/7563`. Alternatively the entire
|
project id's for example ``/datasources/edit/7563``. Alternatively the entire
|
||||||
list of projects can be retrieved using the `REST api`_. To easily make
|
list of projects can be retrieved using the `REST api`_. To easily make
|
||||||
requests to the REST api a tool such as Postman can be used.
|
requests to the REST api a tool such as Postman can be used.
|
||||||
|
|
||||||
@@ -239,18 +239,24 @@ conversion from bytes to megabytes.
|
|||||||
|
|
||||||
SELECT value/1000000 FROM memory...
|
SELECT value/1000000 FROM memory...
|
||||||
|
|
||||||
Queries will be formatted using the .format string method within Python. This
|
Queries will be formatted using the .format string method within Python.
|
||||||
format will currently have give attributes exposed to it labeled `{0}` to
|
This format will currently have give attributes exposed to it labeled
|
||||||
`{4}`. Every occurrence of these characters within the string will be replaced
|
``{0}`` through ``{4}``.
|
||||||
|
Every occurrence of these characters within the string will be replaced
|
||||||
with the specific attribute.
|
with the specific attribute.
|
||||||
|
|
||||||
- {0} is the aggregate typically `mean`, `min`, `max` but `count` is also
|
{0}
|
||||||
supported.
|
is the aggregate typically ``mean``, ``min``, ``max`` but ``count``
|
||||||
- {1} is the attribute as specified in the attribute parameter.
|
is also supported.
|
||||||
- {2} is the period of time to aggregate data over in seconds.
|
{1}
|
||||||
- {3} is the granularity or the interval between data points in seconds.
|
is the attribute as specified in the attribute parameter.
|
||||||
- {4} is translator specific and in the case of InfluxDB it will be used for
|
{2}
|
||||||
retention_periods.
|
is the period of time to aggregate data over in seconds.
|
||||||
|
{3}
|
||||||
|
is the granularity or the interval between data points in seconds.
|
||||||
|
{4}
|
||||||
|
is translator specific and in the case of InfluxDB it will be used for
|
||||||
|
retention_periods.
|
||||||
|
|
||||||
**InfluxDB**
|
**InfluxDB**
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,11 @@
|
|||||||
Datasources
|
Datasources
|
||||||
===========
|
===========
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
The Monasca datasource is deprecated for removal and optional. To use it, install the optional extra:
|
||||||
|
``pip install watcher[monasca]``. If Monasca is configured without installing the extra, Watcher will raise
|
||||||
|
an error guiding you to install the client.
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
:glob:
|
:glob:
|
||||||
:maxdepth: 1
|
:maxdepth: 1
|
||||||
|
|||||||
140
doc/source/datasources/prometheus.rst
Normal file
140
doc/source/datasources/prometheus.rst
Normal file
@@ -0,0 +1,140 @@
|
|||||||
|
=====================
|
||||||
|
Prometheus datasource
|
||||||
|
=====================
|
||||||
|
|
||||||
|
Synopsis
|
||||||
|
--------
|
||||||
|
The Prometheus datasource allows Watcher to use a Prometheus server as the
|
||||||
|
source for collected metrics used by the Watcher decision engine. At minimum
|
||||||
|
deployers must configure the ``host`` and ``port`` at which the Prometheus
|
||||||
|
server is listening.
|
||||||
|
|
||||||
|
Requirements
|
||||||
|
-------------
|
||||||
|
It is required that Prometheus metrics contain a label to identify the hostname
|
||||||
|
of the exporter from which the metric was collected. This is used to match
|
||||||
|
against the Watcher cluster model ``ComputeNode.hostname``. The default for
|
||||||
|
this label is ``fqdn`` and in the prometheus scrape configs would look like:
|
||||||
|
|
||||||
|
.. code-block::
|
||||||
|
|
||||||
|
scrape_configs:
|
||||||
|
- job_name: node
|
||||||
|
static_configs:
|
||||||
|
- targets: ['10.1.2.3:9100']
|
||||||
|
labels:
|
||||||
|
fqdn: "testbox.controlplane.domain"
|
||||||
|
|
||||||
|
This default can be overridden when a deployer uses a different label to
|
||||||
|
identify the exporter host (for example ``hostname`` or ``host``, or any other
|
||||||
|
label, as long as it identifies the host).
|
||||||
|
|
||||||
|
Internally this label is used in creating ``fqdn_instance_labels``, containing
|
||||||
|
the list of values assigned to the label in the Prometheus targets.
|
||||||
|
The elements of the resulting fqdn_instance_labels are expected to match the
|
||||||
|
``ComputeNode.hostname`` used in the Watcher decision engine cluster model.
|
||||||
|
An example ``fqdn_instance_labels`` is the following:
|
||||||
|
|
||||||
|
.. code-block::
|
||||||
|
|
||||||
|
[
|
||||||
|
'ena.controlplane.domain',
|
||||||
|
'dio.controlplane.domain',
|
||||||
|
'tria.controlplane.domain',
|
||||||
|
]
|
||||||
|
|
||||||
|
For instance metrics, it is required that Prometheus contains a label
|
||||||
|
with the uuid of the OpenStack instance in each relevant metric. By default,
|
||||||
|
the datasource will look for the label ``resource``. The
|
||||||
|
``instance_uuid_label`` config option in watcher.conf allows deployers to
|
||||||
|
override this default to any other label name that stores the ``uuid``.
|
||||||
|
|
||||||
|
Limitations
|
||||||
|
-----------
|
||||||
|
The current implementation doesn't support the ``statistic_series`` function of
|
||||||
|
the Watcher ``class DataSourceBase``. It is expected that the
|
||||||
|
``statistic_aggregation`` function (which is implemented) is sufficient in
|
||||||
|
providing the **current** state of the managed resources in the cluster.
|
||||||
|
The ``statistic_aggregation`` function defaults to querying back 300 seconds,
|
||||||
|
starting from the present time (the time period is a function parameter and
|
||||||
|
can be set to a value as required). Implementing the ``statistic_series`` can
|
||||||
|
always be re-visited if the requisite interest and work cycles are volunteered
|
||||||
|
by the interested parties.
|
||||||
|
|
||||||
|
One further note about a limitation in the implemented
|
||||||
|
``statistic_aggregation`` function. This function is defined with a
|
||||||
|
``granularity`` parameter, to be used when querying whichever of the Watcher
|
||||||
|
``DataSourceBase`` metrics providers. In the case of Prometheus, we do not
|
||||||
|
fetch and then process individual metrics across the specified time period.
|
||||||
|
Instead we use the PromQL querying operators and functions, so that the
|
||||||
|
server itself will process the request across the specified parameters and
|
||||||
|
then return the result. So ``granularity`` parameter is redundant and remains
|
||||||
|
unused for the Prometheus implementation of ``statistic_aggregation``. The
|
||||||
|
granularity of the data fetched by Prometheus server is specified in
|
||||||
|
configuration as the server ``scrape_interval`` (current default 15 seconds).
|
||||||
|
|
||||||
|
Configuration
|
||||||
|
-------------
|
||||||
|
A deployer must set the ``datasources`` parameter to include ``prometheus``
|
||||||
|
under the watcher_datasources section of watcher.conf (or add ``prometheus`` in
|
||||||
|
datasources for a specific strategy if preferred eg. under the
|
||||||
|
``[watcher_strategies.workload_stabilization]`` section).
|
||||||
|
|
||||||
|
The watcher.conf configuration file is also used to set the parameter values
|
||||||
|
required by the Watcher Prometheus data source. The configuration can be
|
||||||
|
added under the ``[prometheus_client]`` section and the available options are
|
||||||
|
duplicated below from the code as they are self documenting:
|
||||||
|
|
||||||
|
.. code-block::
|
||||||
|
|
||||||
|
cfg.StrOpt('host',
|
||||||
|
help="The hostname or IP address for the prometheus server."),
|
||||||
|
cfg.StrOpt('port',
|
||||||
|
help="The port number used by the prometheus server."),
|
||||||
|
cfg.StrOpt('fqdn_label',
|
||||||
|
default="fqdn",
|
||||||
|
help="The label that Prometheus uses to store the fqdn of "
|
||||||
|
"exporters. Defaults to 'fqdn'."),
|
||||||
|
cfg.StrOpt('instance_uuid_label',
|
||||||
|
default="resource",
|
||||||
|
help="The label that Prometheus uses to store the uuid of "
|
||||||
|
"OpenStack instances. Defaults to 'resource'."),
|
||||||
|
cfg.StrOpt('username',
|
||||||
|
help="The basic_auth username to use to authenticate with the "
|
||||||
|
"Prometheus server."),
|
||||||
|
cfg.StrOpt('password',
|
||||||
|
secret=True,
|
||||||
|
help="The basic_auth password to use to authenticate with the "
|
||||||
|
"Prometheus server."),
|
||||||
|
cfg.StrOpt('cafile',
|
||||||
|
help="Path to the CA certificate for establishing a TLS "
|
||||||
|
"connection with the Prometheus server."),
|
||||||
|
cfg.StrOpt('certfile',
|
||||||
|
help="Path to the client certificate for establishing a TLS "
|
||||||
|
"connection with the Prometheus server."),
|
||||||
|
cfg.StrOpt('keyfile',
|
||||||
|
help="Path to the client key for establishing a TLS "
|
||||||
|
"connection with the Prometheus server."),
|
||||||
|
|
||||||
|
The ``host`` and ``port`` are **required** configuration options which have
|
||||||
|
no set default. These specify the hostname (or IP) and port for at which
|
||||||
|
the Prometheus server is listening. The ``fqdn_label`` allows deployers to
|
||||||
|
override the required metric label used to match Prometheus node exporters
|
||||||
|
against the Watcher ComputeNodes in the Watcher decision engine cluster data
|
||||||
|
model. The default is ``fqdn`` and deployers can specify any other value
|
||||||
|
(e.g. if they have an equivalent but different label such as ``host``).
|
||||||
|
|
||||||
|
So a sample watcher.conf configured to use the Prometheus server at
|
||||||
|
``10.2.3.4:9090`` would look like the following:
|
||||||
|
|
||||||
|
.. code-block::
|
||||||
|
|
||||||
|
[watcher_datasources]
|
||||||
|
|
||||||
|
datasources = prometheus
|
||||||
|
|
||||||
|
[prometheus_client]
|
||||||
|
|
||||||
|
host = 10.2.3.4
|
||||||
|
port = 9090
|
||||||
|
fqdn_label = fqdn
|
||||||
23
doc/source/image_src/plantuml/action_state_machine.txt
Normal file
23
doc/source/image_src/plantuml/action_state_machine.txt
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
@startuml
|
||||||
|
|
||||||
|
skinparam ArrowColor DarkRed
|
||||||
|
skinparam StateBorderColor DarkRed
|
||||||
|
skinparam StateBackgroundColor LightYellow
|
||||||
|
skinparam Shadowing true
|
||||||
|
|
||||||
|
[*] --> PENDING: The Watcher Planner\ncreates the Action
|
||||||
|
PENDING --> SKIPPED: The Action detects skipping condition\n in pre_condition or was\n skipped by cloud Admin.
|
||||||
|
PENDING --> FAILED: The Action fails unexpectedly\n in pre_condition.
|
||||||
|
PENDING --> ONGOING: The Watcher Applier starts executing/n the action.
|
||||||
|
ONGOING --> FAILED: Something failed while executing\nthe Action in the Watcher Applier
|
||||||
|
ONGOING --> SUCCEEDED: The Watcher Applier executed\nthe Action successfully
|
||||||
|
FAILED --> DELETED : Administrator removes\nAction Plan
|
||||||
|
SUCCEEDED --> DELETED : Administrator removes\n theAction
|
||||||
|
ONGOING --> CANCELLED : The Action was cancelled\n as part of an Action Plan cancellation.
|
||||||
|
PENDING --> CANCELLED : The Action was cancelled\n as part of an Action Plan cancellation.
|
||||||
|
CANCELLED --> DELETED
|
||||||
|
FAILED --> DELETED
|
||||||
|
SKIPPED --> DELETED
|
||||||
|
DELETED --> [*]
|
||||||
|
|
||||||
|
@enduml
|
||||||
BIN
doc/source/images/action_state_machine.png
Normal file
BIN
doc/source/images/action_state_machine.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 75 KiB |
@@ -32,91 +32,22 @@ specific prior release.
|
|||||||
.. _python-watcherclient: https://opendev.org/openstack/python-watcherclient/
|
.. _python-watcherclient: https://opendev.org/openstack/python-watcherclient/
|
||||||
.. _watcher-dashboard: https://opendev.org/openstack/watcher-dashboard/
|
.. _watcher-dashboard: https://opendev.org/openstack/watcher-dashboard/
|
||||||
|
|
||||||
Developer Guide
|
|
||||||
===============
|
|
||||||
|
|
||||||
Introduction
|
|
||||||
------------
|
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: 1
|
:maxdepth: 2
|
||||||
|
|
||||||
glossary
|
|
||||||
architecture
|
architecture
|
||||||
contributor/contributing
|
|
||||||
|
|
||||||
|
|
||||||
Getting Started
|
|
||||||
---------------
|
|
||||||
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 1
|
|
||||||
|
|
||||||
contributor/index
|
contributor/index
|
||||||
|
|
||||||
Installation
|
|
||||||
============
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 2
|
|
||||||
|
|
||||||
install/index
|
install/index
|
||||||
|
|
||||||
Admin Guide
|
|
||||||
===========
|
|
||||||
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 2
|
|
||||||
|
|
||||||
admin/index
|
admin/index
|
||||||
|
|
||||||
User Guide
|
|
||||||
==========
|
|
||||||
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 2
|
|
||||||
|
|
||||||
user/index
|
user/index
|
||||||
|
configuration/index
|
||||||
API References
|
contributor/plugin/index
|
||||||
==============
|
integrations/index
|
||||||
|
man/index
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: 1
|
:maxdepth: 1
|
||||||
|
|
||||||
API Reference <https://docs.openstack.org/api-ref/resource-optimization/>
|
API Reference <https://docs.openstack.org/api-ref/resource-optimization/>
|
||||||
Watcher API Microversion History </contributor/api_microversion_history>
|
Watcher API Microversion History </contributor/api_microversion_history>
|
||||||
|
glossary
|
||||||
Plugins
|
|
||||||
-------
|
|
||||||
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 1
|
|
||||||
|
|
||||||
contributor/plugin/index
|
|
||||||
|
|
||||||
Watcher Configuration Options
|
|
||||||
=============================
|
|
||||||
|
|
||||||
.. toctree::
|
|
||||||
:maxdepth: 2
|
|
||||||
|
|
||||||
configuration/index
|
|
||||||
|
|
||||||
Watcher Manual Pages
|
|
||||||
====================
|
|
||||||
|
|
||||||
.. toctree::
|
|
||||||
:glob:
|
|
||||||
:maxdepth: 1
|
|
||||||
|
|
||||||
man/index
|
|
||||||
|
|
||||||
|
|
||||||
.. only:: html
|
|
||||||
|
|
||||||
Indices and tables
|
|
||||||
==================
|
|
||||||
|
|
||||||
* :ref:`genindex`
|
|
||||||
* :ref:`modindex`
|
|
||||||
* :ref:`search`
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@
|
|||||||
...
|
...
|
||||||
connection = mysql+pymysql://watcher:WATCHER_DBPASS@controller/watcher?charset=utf8
|
connection = mysql+pymysql://watcher:WATCHER_DBPASS@controller/watcher?charset=utf8
|
||||||
|
|
||||||
* In the `[DEFAULT]` section, configure the transport url for RabbitMQ message broker.
|
* In the ``[DEFAULT]`` section, configure the transport url for RabbitMQ message broker.
|
||||||
|
|
||||||
.. code-block:: ini
|
.. code-block:: ini
|
||||||
|
|
||||||
@@ -20,7 +20,7 @@
|
|||||||
|
|
||||||
Replace the RABBIT_PASS with the password you chose for OpenStack user in RabbitMQ.
|
Replace the RABBIT_PASS with the password you chose for OpenStack user in RabbitMQ.
|
||||||
|
|
||||||
* In the `[keystone_authtoken]` section, configure Identity service access.
|
* In the ``[keystone_authtoken]`` section, configure Identity service access.
|
||||||
|
|
||||||
.. code-block:: ini
|
.. code-block:: ini
|
||||||
|
|
||||||
@@ -39,7 +39,7 @@
|
|||||||
Replace WATCHER_PASS with the password you chose for the watcher user in the Identity service.
|
Replace WATCHER_PASS with the password you chose for the watcher user in the Identity service.
|
||||||
|
|
||||||
* Watcher interacts with other OpenStack projects via project clients, in order to instantiate these
|
* Watcher interacts with other OpenStack projects via project clients, in order to instantiate these
|
||||||
clients, Watcher requests new session from Identity service. In the `[watcher_clients_auth]` section,
|
clients, Watcher requests new session from Identity service. In the ``[watcher_clients_auth]`` section,
|
||||||
configure the identity service access to interact with other OpenStack project clients.
|
configure the identity service access to interact with other OpenStack project clients.
|
||||||
|
|
||||||
.. code-block:: ini
|
.. code-block:: ini
|
||||||
@@ -56,7 +56,7 @@
|
|||||||
|
|
||||||
Replace WATCHER_PASS with the password you chose for the watcher user in the Identity service.
|
Replace WATCHER_PASS with the password you chose for the watcher user in the Identity service.
|
||||||
|
|
||||||
* In the `[api]` section, configure host option.
|
* In the ``[api]`` section, configure host option.
|
||||||
|
|
||||||
.. code-block:: ini
|
.. code-block:: ini
|
||||||
|
|
||||||
@@ -66,7 +66,7 @@
|
|||||||
|
|
||||||
Replace controller with the IP address of the management network interface on your controller node, typically 10.0.0.11 for the first node in the example architecture.
|
Replace controller with the IP address of the management network interface on your controller node, typically 10.0.0.11 for the first node in the example architecture.
|
||||||
|
|
||||||
* In the `[oslo_messaging_notifications]` section, configure the messaging driver.
|
* In the ``[oslo_messaging_notifications]`` section, configure the messaging driver.
|
||||||
|
|
||||||
.. code-block:: ini
|
.. code-block:: ini
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
===================================
|
=============
|
||||||
Infrastructure Optimization service
|
Install Guide
|
||||||
===================================
|
=============
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: 2
|
:maxdepth: 2
|
||||||
|
|||||||
126
doc/source/integrations/index.rst
Normal file
126
doc/source/integrations/index.rst
Normal file
@@ -0,0 +1,126 @@
|
|||||||
|
============
|
||||||
|
Integrations
|
||||||
|
============
|
||||||
|
|
||||||
|
The following table provides an Integration status with different services
|
||||||
|
which Watcher interact with. Some integrations are marked as Supported,
|
||||||
|
while others as Experimental due to the lack of testing and a proper
|
||||||
|
documentations.
|
||||||
|
|
||||||
|
Integration Status Matrix
|
||||||
|
-------------------------
|
||||||
|
|
||||||
|
.. list-table::
|
||||||
|
:widths: 20 20 20 20
|
||||||
|
:header-rows: 1
|
||||||
|
|
||||||
|
* - Service Name
|
||||||
|
- Integration Status
|
||||||
|
- Documentation
|
||||||
|
- Testing
|
||||||
|
* - :ref:`Cinder <cinder_integration>`
|
||||||
|
- Supported
|
||||||
|
- Minimal
|
||||||
|
- Unit
|
||||||
|
* - :ref:`Glance <glance_integration>`
|
||||||
|
- Experimental
|
||||||
|
- Missing
|
||||||
|
- None
|
||||||
|
* - :ref:`Ironic <ironic_integration>`
|
||||||
|
- Experimental
|
||||||
|
- Minimal
|
||||||
|
- Unit
|
||||||
|
* - :ref:`Keystone <keystone_integration>`
|
||||||
|
- Supported
|
||||||
|
- Minimal
|
||||||
|
- Integration
|
||||||
|
* - :ref:`MAAS <maas_integration>`
|
||||||
|
- Experimental
|
||||||
|
- Missing
|
||||||
|
- Unit
|
||||||
|
* - :ref:`Neutron <neutron_integration>`
|
||||||
|
- Experimental
|
||||||
|
- Missing
|
||||||
|
- Unit
|
||||||
|
* - :ref:`Nova <nova_integration>`
|
||||||
|
- Supported
|
||||||
|
- Minimal
|
||||||
|
- Unit and Integration
|
||||||
|
* - :ref:`Placement <placement_integration>`
|
||||||
|
- Supported
|
||||||
|
- Minimal
|
||||||
|
- Unit and Integration
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
Minimal documentation covers only basic configuration and, if available,
|
||||||
|
how to enable notifications.
|
||||||
|
|
||||||
|
.. _cinder_integration:
|
||||||
|
|
||||||
|
Cinder
|
||||||
|
^^^^^^
|
||||||
|
The OpenStack Block Storage service integration includes a cluster data
|
||||||
|
model collector that creates a in-memory representation of the storage
|
||||||
|
resources, strategies that propose solutions based on storage capacity
|
||||||
|
and Actions that perform volume migration.
|
||||||
|
|
||||||
|
.. _glance_integration:
|
||||||
|
|
||||||
|
Glance
|
||||||
|
^^^^^^
|
||||||
|
The Image service integration is consumed by Nova Helper to create instances
|
||||||
|
from images, which was used older releases of Watcher to cold migrate
|
||||||
|
instances. This procedure is not used by Watcher anymore and this integration
|
||||||
|
is classified as Experimental and may be removed in future releases.
|
||||||
|
|
||||||
|
.. _ironic_integration:
|
||||||
|
|
||||||
|
Ironic
|
||||||
|
^^^^^^
|
||||||
|
The Bare Metal service integration includes a data model collector that
|
||||||
|
creates an in-memory representation of Ironic resources and Actions that
|
||||||
|
allows the management of the power state of nodes. This integration is
|
||||||
|
classified as Experimental and may be removed in future releases.
|
||||||
|
|
||||||
|
.. _keystone_integration:
|
||||||
|
|
||||||
|
Keystone
|
||||||
|
^^^^^^^^
|
||||||
|
The Identity service integration includes authentication with other services
|
||||||
|
and retrieving information about domains, projects and users.
|
||||||
|
|
||||||
|
.. _maas_integration:
|
||||||
|
|
||||||
|
MAAS (Metal As A Service)
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
This integration allows managing bare metal servers of a MAAS service,
|
||||||
|
which includes Actions that manage the power state of nodes. This
|
||||||
|
integration is classified as Experimental and may be removed in future
|
||||||
|
releases.
|
||||||
|
|
||||||
|
.. _neutron_integration:
|
||||||
|
|
||||||
|
Neutron
|
||||||
|
^^^^^^^
|
||||||
|
Neutron integration is currently consumed by Nova Helper to create instance,
|
||||||
|
which was used by older releases of Watcher to cold migrate instances. This
|
||||||
|
procedure is not used by Watcher anymore and this integration is classified
|
||||||
|
as Experimental and may be removed in future releases.
|
||||||
|
|
||||||
|
.. _nova_integration:
|
||||||
|
|
||||||
|
Nova
|
||||||
|
^^^^
|
||||||
|
Nova service integration includes a cluster data model collector that creates
|
||||||
|
an in-memory representation of the compute resources available in the cloud,
|
||||||
|
strategies that propose solutions based on available resources and Actions
|
||||||
|
that perform instance migrations.
|
||||||
|
|
||||||
|
.. _placement_integration:
|
||||||
|
|
||||||
|
Placement
|
||||||
|
^^^^^^^^^
|
||||||
|
Placement integration allows Watcher to track resource provider inventories
|
||||||
|
and usages information, building a in-memory representation of those resources
|
||||||
|
that can be used by strategies when calculating new solutions.
|
||||||
|
|
||||||
@@ -48,7 +48,7 @@
|
|||||||
logging configuration to any other existing logging
|
logging configuration to any other existing logging
|
||||||
options. Please see the Python logging module documentation
|
options. Please see the Python logging module documentation
|
||||||
for details on logging configuration files. The log-config
|
for details on logging configuration files. The log-config
|
||||||
name for this option is depcrecated.
|
name for this option is deprecated.
|
||||||
|
|
||||||
**--log-format FORMAT**
|
**--log-format FORMAT**
|
||||||
A logging.Formatter log message format string which may use any
|
A logging.Formatter log message format string which may use any
|
||||||
|
|||||||
@@ -1,3 +1,7 @@
|
|||||||
|
====================
|
||||||
|
Watcher Manual Pages
|
||||||
|
====================
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
:glob:
|
:glob:
|
||||||
:maxdepth: 1
|
:maxdepth: 1
|
||||||
|
|||||||
@@ -26,8 +26,7 @@ metric service name plugins comment
|
|||||||
``compute_monitors`` option
|
``compute_monitors`` option
|
||||||
to ``cpu.virt_driver`` in
|
to ``cpu.virt_driver`` in
|
||||||
the nova.conf.
|
the nova.conf.
|
||||||
``cpu_util`` ceilometer_ none cpu_util has been removed
|
``cpu`` ceilometer_ none
|
||||||
since Stein.
|
|
||||||
============================ ============ ======= ===========================
|
============================ ============ ======= ===========================
|
||||||
|
|
||||||
.. _ceilometer: https://docs.openstack.org/ceilometer/latest/admin/telemetry-measurements.html#openstack-compute
|
.. _ceilometer: https://docs.openstack.org/ceilometer/latest/admin/telemetry-measurements.html#openstack-compute
|
||||||
|
|||||||
@@ -11,10 +11,6 @@ Synopsis
|
|||||||
|
|
||||||
.. watcher-term:: watcher.decision_engine.strategy.strategies.host_maintenance.HostMaintenance
|
.. watcher-term:: watcher.decision_engine.strategy.strategies.host_maintenance.HostMaintenance
|
||||||
|
|
||||||
Requirements
|
|
||||||
------------
|
|
||||||
|
|
||||||
None.
|
|
||||||
|
|
||||||
Metrics
|
Metrics
|
||||||
*******
|
*******
|
||||||
@@ -56,15 +52,29 @@ Configuration
|
|||||||
|
|
||||||
Strategy parameters are:
|
Strategy parameters are:
|
||||||
|
|
||||||
==================== ====== ====================================
|
========================== ======== ========================== ==========
|
||||||
parameter type default Value description
|
parameter type description required
|
||||||
==================== ====== ====================================
|
========================== ======== ========================== ==========
|
||||||
``maintenance_node`` String The name of the compute node which
|
``maintenance_node`` String The name of the Required
|
||||||
need maintenance. Required.
|
compute node
|
||||||
``backup_node`` String The name of the compute node which
|
which needs maintenance.
|
||||||
will backup the maintenance node.
|
``backup_node`` String The name of the compute Optional
|
||||||
Optional.
|
node which will backup
|
||||||
==================== ====== ====================================
|
the maintenance node.
|
||||||
|
``disable_live_migration`` Boolean False: Active instances Optional
|
||||||
|
will be live migrated.
|
||||||
|
True: Active instances
|
||||||
|
will be cold migrated
|
||||||
|
if cold migration is
|
||||||
|
not disabled. Otherwise,
|
||||||
|
they will be stopped.
|
||||||
|
False by default.
|
||||||
|
``disable_cold_migration`` Boolean False: Inactive instances Optional
|
||||||
|
will be cold migrated.
|
||||||
|
True: Inactive instances
|
||||||
|
will not be cold migrated.
|
||||||
|
False by default.
|
||||||
|
========================== ======== ========================== ==========
|
||||||
|
|
||||||
Efficacy Indicator
|
Efficacy Indicator
|
||||||
------------------
|
------------------
|
||||||
@@ -80,13 +90,46 @@ to: https://specs.openstack.org/openstack/watcher-specs/specs/queens/approved/cl
|
|||||||
How to use it ?
|
How to use it ?
|
||||||
---------------
|
---------------
|
||||||
|
|
||||||
|
Run an audit using Host Maintenance strategy.
|
||||||
|
Executing the actions will move the servers from compute01 host
|
||||||
|
to a host determined by the Nova scheduler service.
|
||||||
|
|
||||||
|
.. code-block:: shell
|
||||||
|
|
||||||
|
$ openstack optimize audit create \
|
||||||
|
-g cluster_maintaining -s host_maintenance \
|
||||||
|
-p maintenance_node=compute01
|
||||||
|
|
||||||
|
Run an audit using Host Maintenance strategy with a backup node specified.
|
||||||
|
Executing the actions will move the servers from compute01 host
|
||||||
|
to compute02 host.
|
||||||
|
|
||||||
.. code-block:: shell
|
.. code-block:: shell
|
||||||
|
|
||||||
$ openstack optimize audit create \
|
$ openstack optimize audit create \
|
||||||
-g cluster_maintaining -s host_maintenance \
|
-g cluster_maintaining -s host_maintenance \
|
||||||
-p maintenance_node=compute01 \
|
-p maintenance_node=compute01 \
|
||||||
-p backup_node=compute02 \
|
-p backup_node=compute02
|
||||||
--auto-trigger
|
|
||||||
|
Run an audit using Host Maintenance strategy with migration disabled.
|
||||||
|
This will only stop active instances on compute01, useful for maintenance
|
||||||
|
scenarios where operators do not want to migrate workloads to other hosts.
|
||||||
|
|
||||||
|
.. code-block:: shell
|
||||||
|
|
||||||
|
$ openstack optimize audit create \
|
||||||
|
-g cluster_maintaining -s host_maintenance \
|
||||||
|
-p maintenance_node=compute01 \
|
||||||
|
-p disable_live_migration=True \
|
||||||
|
-p disable_cold_migration=True
|
||||||
|
|
||||||
|
Note that after executing this strategy, the *maintenance_node* will be
|
||||||
|
marked as disabled, with the reason set to ``watcher_maintaining``.
|
||||||
|
To enable the node again:
|
||||||
|
|
||||||
|
.. code-block:: shell
|
||||||
|
|
||||||
|
$ openstack compute service set --enable compute01
|
||||||
|
|
||||||
External Links
|
External Links
|
||||||
--------------
|
--------------
|
||||||
|
|||||||
@@ -6,3 +6,53 @@ Strategies
|
|||||||
:maxdepth: 1
|
:maxdepth: 1
|
||||||
|
|
||||||
./*
|
./*
|
||||||
|
|
||||||
|
Strategies status matrix
|
||||||
|
------------------------
|
||||||
|
|
||||||
|
.. list-table::
|
||||||
|
:widths: 33 33 34
|
||||||
|
:header-rows: 1
|
||||||
|
|
||||||
|
* - Strategy Name
|
||||||
|
- Status
|
||||||
|
- Testing
|
||||||
|
* - :doc:`actuation`
|
||||||
|
- Experimental
|
||||||
|
- Unit, Integration
|
||||||
|
* - :doc:`basic-server-consolidation`
|
||||||
|
- Experimental
|
||||||
|
- Missing
|
||||||
|
* - :doc:`host_maintenance`
|
||||||
|
- Supported
|
||||||
|
- Unit, Integration
|
||||||
|
* - :doc:`node_resource_consolidation`
|
||||||
|
- Supported
|
||||||
|
- Unit, Integration
|
||||||
|
* - :doc:`noisy_neighbor`
|
||||||
|
- Deprecated
|
||||||
|
- Unit
|
||||||
|
* - :doc:`outlet_temp_control`
|
||||||
|
- Experimental
|
||||||
|
- Unit
|
||||||
|
* - :doc:`saving_energy`
|
||||||
|
- Experimental
|
||||||
|
- Unit
|
||||||
|
* - :doc:`storage_capacity_balance`
|
||||||
|
- Experimental
|
||||||
|
- Unit
|
||||||
|
* - :doc:`uniform_airflow`
|
||||||
|
- Experimental
|
||||||
|
- Unit
|
||||||
|
* - :doc:`vm_workload_consolidation`
|
||||||
|
- Supported
|
||||||
|
- Unit, Integration
|
||||||
|
* - :doc:`workload-stabilization`
|
||||||
|
- Experimental
|
||||||
|
- Missing
|
||||||
|
* - :doc:`workload_balance`
|
||||||
|
- Supported
|
||||||
|
- Unit, Integration
|
||||||
|
* - :doc:`zone_migration`
|
||||||
|
- Supported (Instance migrations), Experimental (Volume migration)
|
||||||
|
- Unit, Some Integration
|
||||||
|
|||||||
@@ -89,9 +89,9 @@ step 2: Create audit to do optimization
|
|||||||
.. code-block:: shell
|
.. code-block:: shell
|
||||||
|
|
||||||
$ openstack optimize audittemplate create \
|
$ openstack optimize audittemplate create \
|
||||||
at1 saving_energy --strategy saving_energy
|
saving_energy_template1 saving_energy --strategy saving_energy
|
||||||
|
|
||||||
$ openstack optimize audit create -a at1 \
|
$ openstack optimize audit create -a saving_energy_audit1 \
|
||||||
-p free_used_percent=20.0
|
-p free_used_percent=20.0
|
||||||
|
|
||||||
External Links
|
External Links
|
||||||
|
|||||||
@@ -35,6 +35,11 @@ power ceilometer_ kwapi_ one point every 60s
|
|||||||
|
|
||||||
.. _ceilometer: https://docs.openstack.org/ceilometer/latest/admin/telemetry-measurements.html#openstack-compute
|
.. _ceilometer: https://docs.openstack.org/ceilometer/latest/admin/telemetry-measurements.html#openstack-compute
|
||||||
.. _monasca: https://github.com/openstack/monasca-agent/blob/master/docs/Libvirt.md
|
.. _monasca: https://github.com/openstack/monasca-agent/blob/master/docs/Libvirt.md
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
The Monasca datasource is deprecated for removal and optional. If a strategy requires Monasca metrics,
|
||||||
|
ensure the Monasca optional extra is installed: ``pip install watcher[monasca]``.
|
||||||
|
|
||||||
.. _kwapi: https://kwapi.readthedocs.io/en/latest/index.html
|
.. _kwapi: https://kwapi.readthedocs.io/en/latest/index.html
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -22,14 +22,19 @@ The *vm_workload_consolidation* strategy requires the following metrics:
|
|||||||
============================ ============ ======= =========================
|
============================ ============ ======= =========================
|
||||||
metric service name plugins comment
|
metric service name plugins comment
|
||||||
============================ ============ ======= =========================
|
============================ ============ ======= =========================
|
||||||
``cpu_util`` ceilometer_ none cpu_util has been removed
|
``cpu`` ceilometer_ none
|
||||||
since Stein.
|
|
||||||
``memory.resident`` ceilometer_ none
|
``memory.resident`` ceilometer_ none
|
||||||
``memory`` ceilometer_ none
|
``memory`` ceilometer_ none
|
||||||
``disk.root.size`` ceilometer_ none
|
``disk.root.size`` ceilometer_ none
|
||||||
|
``compute.node.cpu.percent`` ceilometer_ none (optional) need to set the
|
||||||
|
``compute_monitors`` option
|
||||||
|
to ``cpu.virt_driver`` in the
|
||||||
|
nova.conf.
|
||||||
|
``hardware.memory.used`` ceilometer_ SNMP_ (optional)
|
||||||
============================ ============ ======= =========================
|
============================ ============ ======= =========================
|
||||||
|
|
||||||
.. _ceilometer: https://docs.openstack.org/ceilometer/latest/admin/telemetry-measurements.html#openstack-compute
|
.. _ceilometer: https://docs.openstack.org/ceilometer/latest/admin/telemetry-measurements.html#openstack-compute
|
||||||
|
.. _SNMP: https://docs.openstack.org/ceilometer/latest/admin/telemetry-measurements.html#snmp-based-meters
|
||||||
|
|
||||||
Cluster data model
|
Cluster data model
|
||||||
******************
|
******************
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user