blob: f6c1f9fa5e45fab9c8954e9efee29a15246a47ea [file] [log] [blame]
Ales Komarekef982692016-02-21 14:56:07 +01001
2==================
smolaon552ba582016-02-23 20:35:42 +01003Metal as a Service
Ales Komarekef982692016-02-21 14:56:07 +01004==================
5
6Service maas description
7
8Sample pillars
9==============
10
11Single maas service
12
13.. code-block:: yaml
14
15 maas:
16 server:
17 enabled: true
18
Ondrej Smola9af2b082016-08-25 17:37:29 +020019Single MAAS region service [single UI/API]
20
21.. code-block:: yaml
22
Damian Szelugaa8248102017-03-16 08:48:51 +010023 maas:
Damian Szeluga336ff2e2017-03-30 11:19:34 +020024 salt_master_ip: 192.168.0.10
Damian Szelugaa8248102017-03-16 08:48:51 +010025 region:
Jiri Broulik0df14bc2017-08-07 10:01:55 +020026 upstream_proxy:
27 address: 10.0.0.1
28 port: 8080
Ondrej Smola3ffb6312017-09-22 17:13:10 +020029 user: username #OPTIONAL
30 password: password #OPTIONAL
Damian Szelugaa8248102017-03-16 08:48:51 +010031 theme: mirantis
32 bind:
33 host: 192.168.0.10:5240
34 port: 5240
35 admin:
36 username: exampleuser
37 password: examplepassword
38 email: email@example.com
39 database:
40 engine: null
41 host: localhost
42 name: maasdb
43 password: qwqwqw
44 username: maas
45 enabled: true
46 user: mirantis
47 token: "89EgtWkX45ddjMYpuL:SqVjxFG87Dr6kVf4Wp:5WLfbUgmm9XQtJxm3V2LUUy7bpCmqmnk"
48 fabrics:
49 test-fabric:
50 description: Test fabric
51 subnets:
52 subnet1:
53 fabric: test-fabric
54 cidr: 2.2.3.0/24
55 gateway_ip: 2.2.3.2
56 iprange:
57 start: 2.2.3.20
58 end: 2.2.3.250
59 dhcp_snippets:
60 test-snippet:
61 value: option bootfile-name "tftp://192.168.0.10/snippet";
62 description: Test snippet
63 enabled: true
64 subnet: subnet1
65 boot_resources:
66 bootscript1:
67 title: bootscript
68 architecture: amd64/generic
69 filetype: tgz
70 content: /srv/salt/reclass/nodes/path_to_file
71 package_repositories:
72 Saltstack:
73 url: http://repo.saltstack.com/apt/ubuntu/14.04/amd64/2016.3/
74 distributions:
75 - trusty
76 components:
77 - main
Damian Szelugaa8248102017-03-16 08:48:51 +010078 arches: amd64
79 key: "-----BEGIN PGP PUBLIC KEY BLOCK-----
80 Version: GnuPG v2
Pavel Cizinsky5a6e2722016-08-31 15:58:13 +020081
Damian Szelugaa8248102017-03-16 08:48:51 +010082 mQENBFOpvpgBCADkP656H41i8fpplEEB8IeLhugyC2rTEwwSclb8tQNYtUiGdna9
83 m38kb0OS2DDrEdtdQb2hWCnswxaAkUunb2qq18vd3dBvlnI+C4/xu5ksZZkRj+fW
84 tArNR18V+2jkwcG26m8AxIrT+m4M6/bgnSfHTBtT5adNfVcTHqiT1JtCbQcXmwVw
85 WbqS6v/LhcsBE//SHne4uBCK/GHxZHhQ5jz5h+3vWeV4gvxS3Xu6v1IlIpLDwUts
86 kT1DumfynYnnZmWTGc6SYyIFXTPJLtnoWDb9OBdWgZxXfHEcBsKGha+bXO+m2tHA
87 gNneN9i5f8oNxo5njrL8jkCckOpNpng18BKXABEBAAG0MlNhbHRTdGFjayBQYWNr
88 YWdpbmcgVGVhbSA8cGFja2FnaW5nQHNhbHRzdGFjay5jb20+iQE4BBMBAgAiBQJT
89 qb6YAhsDBgsJCAcDAgYVCAIJCgsEFgIDAQIeAQIXgAAKCRAOCKFJ3le/vhkqB/0Q
90 WzELZf4d87WApzolLG+zpsJKtt/ueXL1W1KA7JILhXB1uyvVORt8uA9FjmE083o1
91 yE66wCya7V8hjNn2lkLXboOUd1UTErlRg1GYbIt++VPscTxHxwpjDGxDB1/fiX2o
92 nK5SEpuj4IeIPJVE/uLNAwZyfX8DArLVJ5h8lknwiHlQLGlnOu9ulEAejwAKt9CU
93 4oYTszYM4xrbtjB/fR+mPnYh2fBoQO4d/NQiejIEyd9IEEMd/03AJQBuMux62tjA
94 /NwvQ9eqNgLw9NisFNHRWtP4jhAOsshv1WW+zPzu3ozoO+lLHixUIz7fqRk38q8Q
95 9oNR31KvrkSNrFbA3D89uQENBFOpvpgBCADJ79iH10AfAfpTBEQwa6vzUI3Eltqb
96 9aZ0xbZV8V/8pnuU7rqM7Z+nJgldibFk4gFG2bHCG1C5aEH/FmcOMvTKDhJSFQUx
97 uhgxttMArXm2c22OSy1hpsnVG68G32Nag/QFEJ++3hNnbyGZpHnPiYgej3FrerQJ
98 zv456wIsxRDMvJ1NZQB3twoCqwapC6FJE2hukSdWB5yCYpWlZJXBKzlYz/gwD/Fr
99 GL578WrLhKw3UvnJmlpqQaDKwmV2s7MsoZogC6wkHE92kGPG2GmoRD3ALjmCvN1E
100 PsIsQGnwpcXsRpYVCoW7e2nW4wUf7IkFZ94yOCmUq6WreWI4NggRcFC5ABEBAAGJ
101 AR8EGAECAAkFAlOpvpgCGwwACgkQDgihSd5Xv74/NggA08kEdBkiWWwJZUZEy7cK
102 WWcgjnRuOHd4rPeT+vQbOWGu6x4bxuVf9aTiYkf7ZjVF2lPn97EXOEGFWPZeZbH4
103 vdRFH9jMtP+rrLt6+3c9j0M8SIJYwBL1+CNpEC/BuHj/Ra/cmnG5ZNhYebm76h5f
104 T9iPW9fFww36FzFka4VPlvA4oB7ebBtquFg3sdQNU/MmTVV4jPFWXxh4oRDDR+8N
105 1bcPnbB11b5ary99F/mqr7RgQ+YFF0uKRE3SKa7a+6cIuHEZ7Za+zhPaQlzAOZlx
106 fuBmScum8uQTrEF5+Um5zkwC7EXTdH1co/+/V/fpOtxIg4XO4kcugZefVm5ERfVS
107 MA==
108 =dtMN
109 -----END PGP PUBLIC KEY BLOCK-----"
110 enabled: true
111 machines:
112 machine1:
Petr Ruzicka5fe96742017-11-10 14:22:24 +0100113 interface:
Maciej Relewicz37b12a22017-04-25 15:23:16 +0200114 mac: "11:22:33:44:55:66"
Damian Szelugaa8248102017-03-16 08:48:51 +0100115 power_parameters:
116 power_type: ipmi
117 power_address: '192.168.10.10'
118 power_user: bmc_user
119 power_password: bmc_password
Ondrej Smola455003c2017-06-01 22:53:39 +0200120 #Optional (for legacy HW)
121 power_driver: LAN
Petr Ruzicka5fe96742017-11-10 14:22:24 +0100122 # Used in case of power_type: virsh
123 power_id: my_libvirt_vm_name
Maciej Relewicz37b12a22017-04-25 15:23:16 +0200124 distro_series: xenial
125 hwe_kernel: hwe-16.04
Damian Szelugaa8248102017-03-16 08:48:51 +0100126 devices:
127 machine1-ipmi:
128 interface:
129 ip_address: 192.168.10.10
130 subnet: cidr:192.168.10.0/24
131 mac: '66:55:44:33:22:11'
Damian Szeluga336ff2e2017-03-30 11:19:34 +0200132 commissioning_scripts:
azvyagintsevec61dd62017-11-16 19:12:05 +0200133 00-maas-05-simplify-network-interfaces: /etc/maas/files/commisioning_scripts/00-maas-05-simplify-network-interfaces
Damian Szeluga336ff2e2017-03-30 11:19:34 +0200134 maas_config:
135 domain: mydomain.local
136 http_proxy: http://192.168.0.10:3142
137 commissioning_distro_series: xenial
138 default_distro_series: xenial
139 default_osystem: 'ubuntu'
140 default_storage_layout: lvm
141 disk_erase_with_secure_erase: true
142 dnssec_validation: 'no'
143 enable_third_party_drivers: true
144 maas_name: cfg01
145 network_discovery: 'enabled'
146 active_discovery_interval: '600'
147 ntp_external_only: true
148 ntp_servers: 10.10.11.23 10.10.11.24
149 upstream_dns: 192.168.12.13
150 enable_http_proxy: true
151 default_min_hwe_kernel: ''
152 sshprefs:
153 - 'ssh-rsa ASDFOSADFISdfasdfasjdklfjasdJFASDJfASdf923@AAAAB3NzaC1yc2EAAAADAQABAAACAQCv8ISOESGgYUOycYw1SAs/SfHTqtSCTephD/7o2+mEZO53xN98sChiFscFaPA2ZSMoZbJ6MQLKcWKMK2OaTdNSAvn4UE4T6VP0ccdumHDNRwO3f6LptvXr9NR5Wocz2KAgptk+uaA8ytM0Aj9NT0UlfjAXkKnoKyNq6yG+lx4HpwolVaFSlqRXf/iuHpCrspv/u1NW7ReMElJoXv+0zZ7Ow0ZylISdYkaqbV8QatCb17v1+xX03xLsZigfugce/8CDsibSYvJv+Hli5CCBsKgfFqLy4R5vGxiLSVzG/asdjalskjdlkasjdasd/asdajsdkjalaksdjfasd/fa/sdf/asd/fas/dfsadf blah@blah'
Ondrej Smola9af2b082016-08-25 17:37:29 +0200154
155
azvyagintsev7605a662017-11-03 19:05:04 +0200156
Richard Felklce118a22017-09-13 11:09:12 +0200157Usage of local repos
158
159.. code-block:: yaml
azvyagintsev7605a662017-11-03 19:05:04 +0200160
Richard Felklce118a22017-09-13 11:09:12 +0200161 maas:
162 cluster:
163 enabled: true
164 region:
165 port: 80
166 host: localhost
167 saltstack_repo_key: |
168 -----BEGIN PGP PUBLIC KEY BLOCK-----
169 Version: GnuPG v2
170
171 mQENBFOpvpgBCADkP656H41i8fpplEEB8IeLhugyC2rTEwwSclb8tQNYtUiGdna9
172 m38kb0OS2DDrEdtdQb2hWCnswxaAkUunb2qq18vd3dBvlnI+C4/xu5ksZZkRj+fW
173 tArNR18V+2jkwcG26m8AxIrT+m4M6/bgnSfHTBtT5adNfVcTHqiT1JtCbQcXmwVw
174 WbqS6v/LhcsBE//SHne4uBCK/GHxZHhQ5jz5h+3vWeV4gvxS3Xu6v1IlIpLDwUts
175 kT1DumfynYnnZmWTGc6SYyIFXTPJLtnoWDb9OBdWgZxXfHEcBsKGha+bXO+m2tHA
176 gNneN9i5f8oNxo5njrL8jkCckOpNpng18BKXABEBAAG0MlNhbHRTdGFjayBQYWNr
177 YWdpbmcgVGVhbSA8cGFja2FnaW5nQHNhbHRzdGFjay5jb20+iQE4BBMBAgAiBQJT
178 qb6YAhsDBgsJCAcDAgYVCAIJCgsEFgIDAQIeAQIXgAAKCRAOCKFJ3le/vhkqB/0Q
179 WzELZf4d87WApzolLG+zpsJKtt/ueXL1W1KA7JILhXB1uyvVORt8uA9FjmE083o1
180 yE66wCya7V8hjNn2lkLXboOUd1UTErlRg1GYbIt++VPscTxHxwpjDGxDB1/fiX2o
181 nK5SEpuj4IeIPJVE/uLNAwZyfX8DArLVJ5h8lknwiHlQLGlnOu9ulEAejwAKt9CU
182 4oYTszYM4xrbtjB/fR+mPnYh2fBoQO4d/NQiejIEyd9IEEMd/03AJQBuMux62tjA
183 /NwvQ9eqNgLw9NisFNHRWtP4jhAOsshv1WW+zPzu3ozoO+lLHixUIz7fqRk38q8Q
184 9oNR31KvrkSNrFbA3D89uQENBFOpvpgBCADJ79iH10AfAfpTBEQwa6vzUI3Eltqb
185 9aZ0xbZV8V/8pnuU7rqM7Z+nJgldibFk4gFG2bHCG1C5aEH/FmcOMvTKDhJSFQUx
186 uhgxttMArXm2c22OSy1hpsnVG68G32Nag/QFEJ++3hNnbyGZpHnPiYgej3FrerQJ
187 zv456wIsxRDMvJ1NZQB3twoCqwapC6FJE2hukSdWB5yCYpWlZJXBKzlYz/gwD/Fr
188 GL578WrLhKw3UvnJmlpqQaDKwmV2s7MsoZogC6wkHE92kGPG2GmoRD3ALjmCvN1E
189 PsIsQGnwpcXsRpYVCoW7e2nW4wUf7IkFZ94yOCmUq6WreWI4NggRcFC5ABEBAAGJ
190 AR8EGAECAAkFAlOpvpgCGwwACgkQDgihSd5Xv74/NggA08kEdBkiWWwJZUZEy7cK
191 WWcgjnRuOHd4rPeT+vQbOWGu6x4bxuVf9aTiYkf7ZjVF2lPn97EXOEGFWPZeZbH4
192 vdRFH9jMtP+rrLt6+3c9j0M8SIJYwBL1+CNpEC/BuHj/Ra/cmnG5ZNhYebm76h5f
193 T9iPW9fFww36FzFka4VPlvA4oB7ebBtquFg3sdQNU/MmTVV4jPFWXxh4oRDDR+8N
194 1bcPnbB11b5ary99F/mqr7RgQ+YFF0uKRE3SKa7a+6cIuHEZ7Za+zhPaQlzAOZlx
195 fuBmScum8uQTrEF5+Um5zkwC7EXTdH1co/+/V/fpOtxIg4XO4kcugZefVm5ERfVS
196 MA==
197 =dtMN
198 -----END PGP PUBLIC KEY BLOCK-----
199 saltstack_repo_xenial: "http://${_param:local_repo_url}/ubuntu-xenial stable salt"
200 saltstack_repo_trusty: "http://${_param:local_repo_url}/ubuntu-trusty stable salt"
201
Ondrej Smola9af2b082016-08-25 17:37:29 +0200202Single MAAS cluster service [multiple racks]
203
204.. code-block:: yaml
205
206 maas:
207 cluster:
208 enabled: true
Jakub Pavlikf43512b2016-08-30 10:25:42 +0200209 role: master/slave
Ondrej Smola9af2b082016-08-25 17:37:29 +0200210
azvyagintsev7605a662017-11-03 19:05:04 +0200211.. code-block:: yaml
212
213 maas:
214 cluster:
215 enabled: true
216 role: master/slave
217
218Module function's example:
219==========================
220
221* Wait for status of selected machine's:
222
223.. code-block:: bash
224
225 > cat maas/machines/wait_for_machines_ready.sls
226
227 ...
228
229 wait_for_machines_ready:
230 module.run:
231 - name: maas.wait_for_machine_status
232 - kwargs:
233 machines:
234 - kvm01
235 - kvm02
236 timeout: 1200 # in seconds
237 req_status: "Ready"
238 - require:
239 - cmd: maas_login_admin
240 ...
241
242If module run w/\o any extra paremeters - `wait_for_machines_ready` will wait for defined in salt machines. In those case, will be usefull to skip some machines:
243
244.. code-block:: bash
245
246 > cat maas/machines/wait_for_machines_deployed.sls
247
248 ...
249
250 wait_for_machines_ready:
251 module.run:
252 - name: maas.wait_for_machine_status
253 - kwargs:
254 timeout: 1200 # in seconds
Michael Polenchuke438bd32017-11-09 20:42:42 +0400255 req_status: "Deployed"
azvyagintsev7605a662017-11-03 19:05:04 +0200256 ignore_machines:
257 - kvm01 # in case it's broken or whatever
258 - require:
259 - cmd: maas_login_admin
260 ...
261
262List of avaibled `req_status` defined in global variable:
263
264
Ales Komarekef982692016-02-21 14:56:07 +0100265Read more
266=========
267
Roald Nefsc86d84a2017-10-12 21:19:50 +0200268* https://maas.io/
Filip Pytlounc07d2352017-02-02 13:02:03 +0100269
270Documentation and Bugs
271======================
272
273To learn how to install and update salt-formulas, consult the documentation
274available online at:
275
276 http://salt-formulas.readthedocs.io/
277
278In the unfortunate event that bugs are discovered, they should be reported to
279the appropriate issue tracker. Use Github issue tracker for specific salt
280formula:
281
282 https://github.com/salt-formulas/salt-formula-maas/issues
283
284For feature requests, bug reports or blueprints affecting entire ecosystem,
285use Launchpad salt-formulas project:
286
287 https://launchpad.net/salt-formulas
288
289You can also join salt-formulas-users team and subscribe to mailing list:
290
291 https://launchpad.net/~salt-formulas-users
292
293Developers wishing to work on the salt-formulas projects should always base
294their work on master branch and submit pull request against specific formula.
295
296 https://github.com/salt-formulas/salt-formula-maas
297
298Any questions or feedback is always welcome so feel free to join our IRC
299channel:
300
301 #salt-formulas @ irc.freenode.net