| Aleš Komárek | 6357299 | 2017-04-11 13:16:44 +0200 | [diff] [blame] | 1 | ============ | 
|  | 2 | Linux Fomula | 
|  | 3 | ============ | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 4 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 5 | Linux Operating Systems: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 6 |  | 
|  | 7 | * Ubuntu | 
|  | 8 | * CentOS | 
|  | 9 | * RedHat | 
|  | 10 | * Fedora | 
|  | 11 | * Arch | 
|  | 12 |  | 
| Aleš Komárek | 6357299 | 2017-04-11 13:16:44 +0200 | [diff] [blame] | 13 | Sample Pillars | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 14 | ============== | 
|  | 15 |  | 
| Aleš Komárek | 6357299 | 2017-04-11 13:16:44 +0200 | [diff] [blame] | 16 | Linux System | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 17 | ------------ | 
|  | 18 |  | 
|  | 19 | Basic Linux box | 
|  | 20 |  | 
|  | 21 | .. code-block:: yaml | 
|  | 22 |  | 
|  | 23 | linux: | 
|  | 24 | system: | 
|  | 25 | enabled: true | 
|  | 26 | name: 'node1' | 
|  | 27 | domain: 'domain.com' | 
|  | 28 | cluster: 'system' | 
|  | 29 | environment: prod | 
|  | 30 | timezone: 'Europe/Prague' | 
|  | 31 | utc: true | 
|  | 32 |  | 
| azvyagintsev | 967af13 | 2017-06-12 12:25:24 +0300 | [diff] [blame] | 33 | Linux with system users, some with password set: | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 34 |  | 
|  | 35 | .. warning:: If no ``password`` variable is passed, | 
|  | 36 | any predifined password will be removed. | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 37 |  | 
|  | 38 | .. code-block:: yaml | 
|  | 39 |  | 
|  | 40 | linux: | 
|  | 41 | system: | 
|  | 42 | ... | 
|  | 43 | user: | 
|  | 44 | jdoe: | 
|  | 45 | name: 'jdoe' | 
|  | 46 | enabled: true | 
|  | 47 | sudo: true | 
|  | 48 | shell: /bin/bash | 
|  | 49 | full_name: 'Jonh Doe' | 
|  | 50 | home: '/home/jdoe' | 
| Martin Polreich | 4fcd5c0 | 2018-07-16 09:41:51 +0200 | [diff] [blame] | 51 | home_dir_mode: 755 | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 52 | email: 'jonh@doe.com' | 
|  | 53 | jsmith: | 
|  | 54 | name: 'jsmith' | 
|  | 55 | enabled: true | 
| azvyagintsev | 967af13 | 2017-06-12 12:25:24 +0300 | [diff] [blame] | 56 | full_name: 'With clear password' | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 57 | home: '/home/jsmith' | 
| azvyagintsev | 967af13 | 2017-06-12 12:25:24 +0300 | [diff] [blame] | 58 | hash_password: true | 
|  | 59 | password: "userpassword" | 
|  | 60 | mark: | 
|  | 61 | name: 'mark' | 
|  | 62 | enabled: true | 
|  | 63 | full_name: "unchange password' | 
|  | 64 | home: '/home/mark' | 
|  | 65 | password: false | 
|  | 66 | elizabeth: | 
|  | 67 | name: 'elizabeth' | 
|  | 68 | enabled: true | 
|  | 69 | full_name: 'With hased password' | 
|  | 70 | home: '/home/elizabeth' | 
|  | 71 | password: "$6$nUI7QEz3$dFYjzQqK5cJ6HQ38KqG4gTWA9eJu3aKx6TRVDFh6BVJxJgFWg2akfAA7f1fCxcSUeOJ2arCO6EEI6XXnHXxG10" | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 72 |  | 
| Petr Michalec | 1c4c8d8 | 2017-02-28 19:09:21 +0100 | [diff] [blame] | 73 | Configure sudo for users and groups under ``/etc/sudoers.d/``. | 
|  | 74 | This ways ``linux.system.sudo`` pillar map to actual sudo attributes: | 
|  | 75 |  | 
|  | 76 | .. code-block:: jinja | 
| Aleš Komárek | 6357299 | 2017-04-11 13:16:44 +0200 | [diff] [blame] | 77 |  | 
| Petr Michalec | 1c4c8d8 | 2017-02-28 19:09:21 +0100 | [diff] [blame] | 78 | # simplified template: | 
|  | 79 | Cmds_Alias {{ alias }}={{ commands }} | 
|  | 80 | {{ user }}   {{ hosts }}=({{ runas }}) NOPASSWD: {{ commands }} | 
|  | 81 | %{{ group }} {{ hosts }}=({{ runas }}) NOPASSWD: {{ commands }} | 
|  | 82 |  | 
|  | 83 | # when rendered: | 
|  | 84 | saltuser1 ALL=(ALL) NOPASSWD: ALL | 
|  | 85 |  | 
| Petr Michalec | 1c4c8d8 | 2017-02-28 19:09:21 +0100 | [diff] [blame] | 86 | .. code-block:: yaml | 
| Aleš Komárek | 6357299 | 2017-04-11 13:16:44 +0200 | [diff] [blame] | 87 |  | 
| Petr Michalec | 1c4c8d8 | 2017-02-28 19:09:21 +0100 | [diff] [blame] | 88 | linux: | 
|  | 89 | system: | 
|  | 90 | sudo: | 
|  | 91 | enabled: true | 
| Tomas Kamm | d8eb300 | 2017-05-08 19:30:29 +0200 | [diff] [blame] | 92 | aliases: | 
| Petr Michalec | 1c4c8d8 | 2017-02-28 19:09:21 +0100 | [diff] [blame] | 93 | host: | 
|  | 94 | LOCAL: | 
|  | 95 | - localhost | 
|  | 96 | PRODUCTION: | 
|  | 97 | - db1 | 
|  | 98 | - db2 | 
|  | 99 | runas: | 
|  | 100 | DBA: | 
|  | 101 | - postgres | 
|  | 102 | - mysql | 
|  | 103 | SALT: | 
|  | 104 | - root | 
|  | 105 | command: | 
|  | 106 | # Note: This is not 100% safe when ALL keyword is used, user still may modify configs and hide his actions. | 
|  | 107 | #       Best practice is to specify full list of commands user is allowed to run. | 
|  | 108 | SUPPORT_RESTRICTED: | 
|  | 109 | - /bin/vi /etc/sudoers* | 
|  | 110 | - /bin/vim /etc/sudoers* | 
|  | 111 | - /bin/nano /etc/sudoers* | 
|  | 112 | - /bin/emacs /etc/sudoers* | 
|  | 113 | - /bin/su - root | 
|  | 114 | - /bin/su - | 
|  | 115 | - /bin/su | 
|  | 116 | - /usr/sbin/visudo | 
|  | 117 | SUPPORT_SHELLS: | 
|  | 118 | - /bin/sh | 
|  | 119 | - /bin/ksh | 
|  | 120 | - /bin/bash | 
|  | 121 | - /bin/rbash | 
|  | 122 | - /bin/dash | 
|  | 123 | - /bin/zsh | 
|  | 124 | - /bin/csh | 
|  | 125 | - /bin/fish | 
|  | 126 | - /bin/tcsh | 
|  | 127 | - /usr/bin/login | 
|  | 128 | - /usr/bin/su | 
|  | 129 | - /usr/su | 
|  | 130 | ALL_SALT_SAFE: | 
|  | 131 | - /usr/bin/salt state* | 
|  | 132 | - /usr/bin/salt service* | 
|  | 133 | - /usr/bin/salt pillar* | 
|  | 134 | - /usr/bin/salt grains* | 
|  | 135 | - /usr/bin/salt saltutil* | 
|  | 136 | - /usr/bin/salt-call state* | 
|  | 137 | - /usr/bin/salt-call service* | 
|  | 138 | - /usr/bin/salt-call pillar* | 
|  | 139 | - /usr/bin/salt-call grains* | 
|  | 140 | - /usr/bin/salt-call saltutil* | 
|  | 141 | SALT_TRUSTED: | 
|  | 142 | - /usr/bin/salt* | 
|  | 143 | users: | 
|  | 144 | # saltuser1 with default values: saltuser1 ALL=(ALL) NOPASSWD: ALL | 
|  | 145 | saltuser1: {} | 
|  | 146 | saltuser2: | 
|  | 147 | hosts: | 
|  | 148 | - LOCAL | 
|  | 149 | # User Alias DBA | 
|  | 150 | DBA: | 
|  | 151 | hosts: | 
|  | 152 | - ALL | 
|  | 153 | commands: | 
|  | 154 | - ALL_SALT_SAFE | 
|  | 155 | groups: | 
|  | 156 | db-ops: | 
|  | 157 | hosts: | 
|  | 158 | - ALL | 
|  | 159 | - '!PRODUCTION' | 
|  | 160 | runas: | 
|  | 161 | - DBA | 
|  | 162 | commands: | 
|  | 163 | - /bin/cat * | 
|  | 164 | - /bin/less * | 
|  | 165 | - /bin/ls * | 
|  | 166 | salt-ops: | 
|  | 167 | hosts: | 
|  | 168 | - 'ALL' | 
|  | 169 | runas: | 
|  | 170 | - SALT | 
|  | 171 | commands: | 
|  | 172 | - SUPPORT_SHELLS | 
|  | 173 | salt-ops-2nd: | 
|  | 174 | name: salt-ops | 
|  | 175 | nopasswd: false | 
| Jakub Josef | 7a9d9b9 | 2017-05-16 11:39:01 +0200 | [diff] [blame] | 176 | setenv: true # Enable sudo -E option | 
| Petr Michalec | 1c4c8d8 | 2017-02-28 19:09:21 +0100 | [diff] [blame] | 177 | runas: | 
|  | 178 | - DBA | 
|  | 179 | commands: | 
|  | 180 | - ALL | 
|  | 181 | - '!SUPPORT_SHELLS' | 
|  | 182 | - '!SUPPORT_RESTRICTED' | 
|  | 183 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 184 | Linux with package, latest version: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 185 |  | 
|  | 186 | .. code-block:: yaml | 
|  | 187 |  | 
|  | 188 | linux: | 
|  | 189 | system: | 
|  | 190 | ... | 
|  | 191 | package: | 
|  | 192 | package-name: | 
|  | 193 | version: latest | 
|  | 194 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 195 | Linux with package from certail repo, version with no upgrades: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 196 |  | 
|  | 197 | .. code-block:: yaml | 
|  | 198 |  | 
|  | 199 | linux: | 
|  | 200 | system: | 
|  | 201 | ... | 
|  | 202 | package: | 
|  | 203 | package-name: | 
|  | 204 | version: 2132.323 | 
|  | 205 | repo: 'custom-repo' | 
|  | 206 | hold: true | 
|  | 207 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 208 | Linux with package from certail repo, version with no GPG | 
|  | 209 | verification: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 210 |  | 
|  | 211 | .. code-block:: yaml | 
|  | 212 |  | 
|  | 213 | linux: | 
|  | 214 | system: | 
|  | 215 | ... | 
|  | 216 | package: | 
|  | 217 | package-name: | 
|  | 218 | version: 2132.323 | 
|  | 219 | repo: 'custom-repo' | 
|  | 220 | verify: false | 
|  | 221 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 222 | Linux with autoupdates (automatically install security package | 
|  | 223 | updates): | 
| Bruno Binet | 69a9d8d | 2017-02-16 22:34:32 +0100 | [diff] [blame] | 224 |  | 
|  | 225 | .. code-block:: yaml | 
|  | 226 |  | 
|  | 227 | linux: | 
|  | 228 | system: | 
|  | 229 | ... | 
|  | 230 | autoupdates: | 
|  | 231 | enabled: true | 
|  | 232 | mail: root@localhost | 
|  | 233 | mail_only_on_error: true | 
|  | 234 | remove_unused_dependencies: false | 
|  | 235 | automatic_reboot: true | 
|  | 236 | automatic_reboot_time: "02:00" | 
|  | 237 |  | 
| Dmitry Teselkin | 0f084a0 | 2018-08-29 14:46:38 +0300 | [diff] [blame] | 238 | Managing cron tasks | 
|  | 239 | ------------------- | 
|  | 240 |  | 
|  | 241 | There are two data structures that are related to managing cron itself and | 
|  | 242 | cron tasks: | 
|  | 243 |  | 
|  | 244 | .. code-block:: yaml | 
|  | 245 |  | 
|  | 246 | linux: | 
|  | 247 | system: | 
|  | 248 | cron: | 
|  | 249 |  | 
|  | 250 | and | 
|  | 251 |  | 
|  | 252 | .. code-block:: yaml | 
|  | 253 |  | 
|  | 254 | linux: | 
|  | 255 | system: | 
|  | 256 | job: | 
|  | 257 |  | 
|  | 258 | `linux:system:cron` manages cron packages, services, and '/etc/cron.allow' file. | 
|  | 259 |  | 
|  | 260 | 'deny' files are managed the only way - we're ensuring they are absent, that's | 
|  | 261 | a requirement from CIS 5.1.8 | 
|  | 262 |  | 
|  | 263 | 'cron' pillar structure is the following: | 
|  | 264 |  | 
|  | 265 | .. code-block:: yaml | 
|  | 266 |  | 
|  | 267 | linux: | 
|  | 268 | system: | 
|  | 269 | cron: | 
|  | 270 | enabled: true | 
|  | 271 | pkgs: [ <cron packages> ] | 
|  | 272 | services: [ <cron services> ] | 
|  | 273 | user: | 
|  | 274 | <username>: | 
|  | 275 | enabled: true | 
|  | 276 |  | 
|  | 277 | To add user to '/etc/cron.allow' use 'enabled' key as shown above. | 
|  | 278 |  | 
|  | 279 | '/etc/cron.deny' is not managed as CIS 5.1.8 requires it was removed. | 
|  | 280 |  | 
|  | 281 | A user would be ignored if any of the following is true: | 
|  | 282 | * user is disabled in `linux:system:user:<username>` | 
|  | 283 | * user is disabled in `linux:system:cron:user:<username>` | 
|  | 284 |  | 
|  | 285 | `linux:system:job` manages individual cron tasks. | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 286 |  | 
|  | 287 | By default, it will use name as an identifier, unless identifier key is | 
| Filip Pytloun | 9122222 | 2017-08-04 10:55:27 +0200 | [diff] [blame] | 288 | explicitly set or False (then it will use Salt's default behavior which is | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 289 | identifier same as command resulting in not being able to change it): | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 290 |  | 
|  | 291 | .. code-block:: yaml | 
|  | 292 |  | 
|  | 293 | linux: | 
|  | 294 | system: | 
|  | 295 | ... | 
|  | 296 | job: | 
|  | 297 | cmd1: | 
|  | 298 | command: '/cmd/to/run' | 
| Filip Pytloun | 9122222 | 2017-08-04 10:55:27 +0200 | [diff] [blame] | 299 | identifier: cmd1 | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 300 | enabled: true | 
|  | 301 | user: 'root' | 
|  | 302 | hour: 2 | 
|  | 303 | minute: 0 | 
|  | 304 |  | 
| Dmitry Teselkin | 0f084a0 | 2018-08-29 14:46:38 +0300 | [diff] [blame] | 305 | Managing 'at' tasks | 
|  | 306 | ------------------- | 
|  | 307 |  | 
|  | 308 | Pillar for managing `at` tasks is similar to one for `cron` tasks: | 
|  | 309 |  | 
|  | 310 | .. code-block:: yaml | 
|  | 311 |  | 
|  | 312 | linux: | 
|  | 313 | system: | 
|  | 314 | at: | 
|  | 315 | enabled: true | 
|  | 316 | pkgs: [ <at packages> ] | 
|  | 317 | services: [ <at services> ] | 
|  | 318 | user: | 
|  | 319 | <username>: | 
|  | 320 | enabled: true | 
|  | 321 |  | 
|  | 322 | To add a user to '/etc/at.allow' use 'enabled' key as shown above. | 
|  | 323 |  | 
|  | 324 | '/etc/at.deny' is not managed as CIS 5.1.8 requires it was removed. | 
|  | 325 |  | 
|  | 326 | A user will be ignored if any of the following is true: | 
|  | 327 | * user is disabled in `linux:system:user:<username>` | 
|  | 328 | * user is disabled in `linux:system:at:user:<username>` | 
|  | 329 |  | 
|  | 330 |  | 
| Filip Pytloun | d0a29e7 | 2015-11-30 15:23:34 +0100 | [diff] [blame] | 331 | Linux security limits (limit sensu user memory usage to max 1GB): | 
|  | 332 |  | 
|  | 333 | .. code-block:: yaml | 
|  | 334 |  | 
|  | 335 | linux: | 
|  | 336 | system: | 
|  | 337 | ... | 
|  | 338 | limit: | 
|  | 339 | sensu: | 
|  | 340 | enabled: true | 
|  | 341 | domain: sensu | 
|  | 342 | limits: | 
|  | 343 | - type: hard | 
|  | 344 | item: as | 
|  | 345 | value: 1000000 | 
|  | 346 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 347 | Enable autologin on ``tty1`` (may work only for Ubuntu 14.04): | 
| Filip Pytloun | 7fee054 | 2015-10-15 11:19:24 +0200 | [diff] [blame] | 348 |  | 
|  | 349 | .. code-block:: yaml | 
|  | 350 |  | 
|  | 351 | linux: | 
|  | 352 | system: | 
|  | 353 | console: | 
|  | 354 | tty1: | 
|  | 355 | autologin: root | 
| Filip Pytloun | 281d020 | 2016-01-29 14:03:51 +0100 | [diff] [blame] | 356 | # Enable serial console | 
|  | 357 | ttyS0: | 
|  | 358 | autologin: root | 
|  | 359 | rate: 115200 | 
|  | 360 | term: xterm | 
| Filip Pytloun | 7fee054 | 2015-10-15 11:19:24 +0200 | [diff] [blame] | 361 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 362 | To disable set autologin to ``false``. | 
| Filip Pytloun | 7fee054 | 2015-10-15 11:19:24 +0200 | [diff] [blame] | 363 |  | 
| Filip Pytloun | 7731b85 | 2016-02-01 11:13:47 +0100 | [diff] [blame] | 364 | Set ``policy-rc.d`` on Debian-based systems. Action can be any available | 
|  | 365 | command in ``while true`` loop and ``case`` context. | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 366 | Following will disallow dpkg to stop/start services for the Cassandra | 
|  | 367 | package automatically: | 
| Filip Pytloun | 7731b85 | 2016-02-01 11:13:47 +0100 | [diff] [blame] | 368 |  | 
|  | 369 | .. code-block:: yaml | 
|  | 370 |  | 
|  | 371 | linux: | 
|  | 372 | system: | 
|  | 373 | policyrcd: | 
|  | 374 | - package: cassandra | 
|  | 375 | action: exit 101 | 
|  | 376 | - package: '*' | 
|  | 377 | action: switch | 
|  | 378 |  | 
| Filip Pytloun | c49445a | 2016-04-04 14:23:20 +0200 | [diff] [blame] | 379 | Set system locales: | 
|  | 380 |  | 
|  | 381 | .. code-block:: yaml | 
|  | 382 |  | 
|  | 383 | linux: | 
|  | 384 | system: | 
|  | 385 | locale: | 
|  | 386 | en_US.UTF-8: | 
|  | 387 | default: true | 
| Filip Pytloun | ee1745f | 2016-04-04 17:39:41 +0200 | [diff] [blame] | 388 | "cs_CZ.UTF-8 UTF-8": | 
| Filip Pytloun | c49445a | 2016-04-04 14:23:20 +0200 | [diff] [blame] | 389 | enabled: true | 
|  | 390 |  | 
| Andrey Shestakov | e7cca05 | 2017-05-24 23:06:24 +0300 | [diff] [blame] | 391 | Systemd settings: | 
|  | 392 |  | 
|  | 393 | .. code-block:: yaml | 
|  | 394 |  | 
|  | 395 | linux: | 
|  | 396 | system: | 
|  | 397 | ... | 
|  | 398 | systemd: | 
|  | 399 | system: | 
|  | 400 | Manager: | 
|  | 401 | DefaultLimitNOFILE: 307200 | 
|  | 402 | DefaultLimitNPROC: 307200 | 
|  | 403 | user: | 
|  | 404 | Manager: | 
|  | 405 | DefaultLimitCPU: 2 | 
|  | 406 | DefaultLimitNPROC: 4 | 
|  | 407 |  | 
| Filip Pytloun | 8b2131e | 2017-11-08 13:29:03 +0100 | [diff] [blame] | 408 | Ensure presence of directory: | 
|  | 409 |  | 
|  | 410 | .. code-block:: yaml | 
|  | 411 |  | 
|  | 412 | linux: | 
|  | 413 | system: | 
|  | 414 | directory: | 
|  | 415 | /tmp/test: | 
|  | 416 | user: root | 
|  | 417 | group: root | 
|  | 418 | mode: 700 | 
|  | 419 | makedirs: true | 
|  | 420 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 421 | Ensure presence of file by specifying its source: | 
| Richard Felkl | 2e07d65 | 2018-01-19 10:19:06 +0100 | [diff] [blame] | 422 |  | 
|  | 423 | .. code-block:: yaml | 
|  | 424 |  | 
|  | 425 | linux: | 
|  | 426 | system: | 
|  | 427 | file: | 
|  | 428 | /tmp/test.txt: | 
|  | 429 | source: http://example.com/test.txt | 
| Richard Felkl | f40599a | 2018-02-06 22:56:41 +0100 | [diff] [blame] | 430 | user: root #optional | 
|  | 431 | group: root #optional | 
|  | 432 | mode: 700 #optional | 
|  | 433 | dir_mode: 700 #optional | 
|  | 434 | encoding: utf-8 #optional | 
|  | 435 | hash: <<hash>> or <<URI to hash>> #optional | 
|  | 436 | makedirs: true #optional | 
|  | 437 |  | 
|  | 438 | linux: | 
|  | 439 | system: | 
|  | 440 | file: | 
|  | 441 | test.txt: | 
|  | 442 | name: /tmp/test.txt | 
|  | 443 | source: http://example.com/test.txt | 
| Richard Felkl | 2e07d65 | 2018-01-19 10:19:06 +0100 | [diff] [blame] | 444 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 445 | Ensure presence of file by specifying its contents: | 
| Richard Felkl | 2e07d65 | 2018-01-19 10:19:06 +0100 | [diff] [blame] | 446 |  | 
|  | 447 | .. code-block:: yaml | 
|  | 448 |  | 
|  | 449 | linux: | 
|  | 450 | system: | 
|  | 451 | file: | 
|  | 452 | /tmp/test.txt: | 
|  | 453 | contents: | | 
|  | 454 | line1 | 
|  | 455 | line2 | 
| Richard Felkl | f40599a | 2018-02-06 22:56:41 +0100 | [diff] [blame] | 456 |  | 
|  | 457 | linux: | 
|  | 458 | system: | 
|  | 459 | file: | 
|  | 460 | /tmp/test.txt: | 
|  | 461 | contents_pillar: linux:network:hostname | 
|  | 462 |  | 
|  | 463 | linux: | 
|  | 464 | system: | 
|  | 465 | file: | 
|  | 466 | /tmp/test.txt: | 
|  | 467 | contents_grains: motd | 
|  | 468 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 469 | Ensure presence of file to be serialized through one of the | 
|  | 470 | serializer modules (see: | 
|  | 471 | https://docs.saltstack.com/en/latest/ref/serializers/all/index.html): | 
| Bruno Binet | 9c2fe22 | 2018-06-08 16:57:32 +0200 | [diff] [blame] | 472 |  | 
|  | 473 | .. code-block:: yaml | 
|  | 474 |  | 
|  | 475 | linux: | 
|  | 476 | system: | 
|  | 477 | file: | 
|  | 478 | /tmp/test.json: | 
|  | 479 | serialize: json | 
|  | 480 | contents: | 
|  | 481 | foo: 1 | 
|  | 482 | bar: 'bar' | 
|  | 483 |  | 
| Filip Pytloun | 281034a | 2016-01-04 18:06:22 +0100 | [diff] [blame] | 484 | Kernel | 
|  | 485 | ~~~~~~ | 
|  | 486 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 487 | Install always up to date LTS kernel and headers from Ubuntu Trusty: | 
| Filip Pytloun | 281034a | 2016-01-04 18:06:22 +0100 | [diff] [blame] | 488 |  | 
|  | 489 | .. code-block:: yaml | 
|  | 490 |  | 
|  | 491 | linux: | 
|  | 492 | system: | 
|  | 493 | kernel: | 
|  | 494 | type: generic | 
|  | 495 | lts: trusty | 
|  | 496 | headers: true | 
|  | 497 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 498 | Load kernel modules and add them to ``/etc/modules``: | 
| Tomáš Kukrál | ba35b21 | 2017-02-15 17:59:46 +0100 | [diff] [blame] | 499 |  | 
|  | 500 | .. code-block:: yaml | 
|  | 501 |  | 
|  | 502 | linux: | 
|  | 503 | system: | 
|  | 504 | kernel: | 
|  | 505 | modules: | 
|  | 506 | - nf_conntrack | 
|  | 507 | - tp_smapi | 
|  | 508 | - 8021q | 
|  | 509 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 510 | Configure or blacklist kernel modules with additional options to | 
|  | 511 | ``/etc/modprobe.d`` following example will add | 
|  | 512 | ``/etc/modprobe.d/nf_conntrack.conf`` file with line | 
|  | 513 | ``options nf_conntrack hashsize=262144``: | 
| teoyaomiqui | 32b1f7c | 2017-05-24 14:36:09 +0300 | [diff] [blame] | 514 |  | 
| Dmitry Teselkin | 809834c | 2018-08-13 19:14:42 +0300 | [diff] [blame] | 515 | 'option' can be a mapping (with 'enabled' and 'value' keys) or a scalar. | 
|  | 516 |  | 
|  | 517 | Example for 'scalar' option value: | 
|  | 518 |  | 
| teoyaomiqui | 32b1f7c | 2017-05-24 14:36:09 +0300 | [diff] [blame] | 519 | .. code-block:: yaml | 
|  | 520 |  | 
|  | 521 | linux: | 
|  | 522 | system: | 
|  | 523 | kernel: | 
|  | 524 | module: | 
|  | 525 | nf_conntrack: | 
|  | 526 | option: | 
|  | 527 | hashsize: 262144 | 
|  | 528 |  | 
| Dmitry Teselkin | 809834c | 2018-08-13 19:14:42 +0300 | [diff] [blame] | 529 | Example for 'mapping' option value: | 
|  | 530 |  | 
|  | 531 | .. code-block:: yaml | 
|  | 532 |  | 
|  | 533 | linux: | 
|  | 534 | system: | 
|  | 535 | kernel: | 
|  | 536 | module: | 
|  | 537 | nf_conntrack: | 
|  | 538 | option: | 
|  | 539 | hashsize: | 
|  | 540 | enabled: true | 
|  | 541 | value: 262144 | 
|  | 542 |  | 
|  | 543 | NOTE: 'enabled' key is optional and is True by default. | 
|  | 544 |  | 
|  | 545 | Blacklist a module: | 
|  | 546 |  | 
|  | 547 | .. code-block:: yaml | 
|  | 548 |  | 
|  | 549 | linux: | 
|  | 550 | system: | 
|  | 551 | kernel: | 
|  | 552 | module: | 
|  | 553 | nf_conntrack: | 
|  | 554 | blacklist: true | 
|  | 555 |  | 
|  | 556 | A module can have a number of aliases, wildcards are allowed. | 
|  | 557 | Define an alias for a module: | 
|  | 558 |  | 
|  | 559 | .. code-block:: yaml | 
|  | 560 |  | 
|  | 561 | linux: | 
|  | 562 | system: | 
|  | 563 | kernel: | 
|  | 564 | module: | 
|  | 565 | nf_conntrack: | 
|  | 566 | alias: | 
|  | 567 | nfct: | 
|  | 568 | enabled: true | 
|  | 569 | "nf_conn*": | 
|  | 570 | enabled: true | 
|  | 571 |  | 
|  | 572 | NOTE: 'enabled' key is mandatory as there are no other keys exist. | 
|  | 573 |  | 
|  | 574 | Execute custom command instead of 'insmod' when inserting a module: | 
|  | 575 |  | 
|  | 576 | .. code-block:: yaml | 
|  | 577 |  | 
|  | 578 | linux: | 
|  | 579 | system: | 
|  | 580 | kernel: | 
|  | 581 | module: | 
|  | 582 | nf_conntrack: | 
|  | 583 | install: | 
|  | 584 | enabled: true | 
|  | 585 | command: /bin/true | 
|  | 586 |  | 
|  | 587 | NOTE: 'enabled' key is optional and is True by default. | 
|  | 588 |  | 
|  | 589 | Execute custom command instead of 'rmmod' when removing a module: | 
|  | 590 |  | 
|  | 591 | .. code-block:: yaml | 
|  | 592 |  | 
|  | 593 | linux: | 
|  | 594 | system: | 
|  | 595 | kernel: | 
|  | 596 | module: | 
|  | 597 | nf_conntrack: | 
|  | 598 | remove: | 
|  | 599 | enabled: true | 
|  | 600 | command: /bin/true | 
|  | 601 |  | 
|  | 602 | NOTE: 'enabled' key is optional and is True by default. | 
|  | 603 |  | 
|  | 604 | Define module dependencies: | 
|  | 605 |  | 
|  | 606 | .. code-block:: yaml | 
|  | 607 |  | 
|  | 608 | linux: | 
|  | 609 | system: | 
|  | 610 | kernel: | 
|  | 611 | module: | 
|  | 612 | nf_conntrack: | 
|  | 613 | softdep: | 
|  | 614 | pre: | 
|  | 615 | 1: | 
|  | 616 | enabled: true | 
|  | 617 | value: a | 
|  | 618 | 2: | 
|  | 619 | enabled: true | 
|  | 620 | value: b | 
|  | 621 | 3: | 
|  | 622 | enabled: true | 
|  | 623 | value: c | 
|  | 624 | post: | 
|  | 625 | 1: | 
|  | 626 | enabled: true | 
|  | 627 | value: x | 
|  | 628 | 2: | 
|  | 629 | enabled: true | 
|  | 630 | value: y | 
|  | 631 | 3: | 
|  | 632 | enabled: true | 
|  | 633 | value: z | 
|  | 634 |  | 
|  | 635 | NOTE: 'enabled' key is optional and is True by default. | 
|  | 636 |  | 
|  | 637 |  | 
| Filip Pytloun | 281034a | 2016-01-04 18:06:22 +0100 | [diff] [blame] | 638 | Install specific kernel version and ensure all other kernel packages are | 
|  | 639 | not present. Also install extra modules and headers for this kernel: | 
|  | 640 |  | 
|  | 641 | .. code-block:: yaml | 
|  | 642 |  | 
|  | 643 | linux: | 
|  | 644 | system: | 
|  | 645 | kernel: | 
|  | 646 | type: generic | 
|  | 647 | extra: true | 
|  | 648 | headers: true | 
|  | 649 | version: 4.2.0-22 | 
|  | 650 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 651 | Systcl kernel parameters: | 
| Jakub Pavlik | 32c2cb0 | 2016-01-29 12:45:29 +0100 | [diff] [blame] | 652 |  | 
|  | 653 | .. code-block:: yaml | 
|  | 654 |  | 
|  | 655 | linux: | 
|  | 656 | system: | 
|  | 657 | kernel: | 
|  | 658 | sysctl: | 
|  | 659 | net.ipv4.tcp_keepalive_intvl: 3 | 
|  | 660 | net.ipv4.tcp_keepalive_time: 30 | 
|  | 661 | net.ipv4.tcp_keepalive_probes: 8 | 
|  | 662 |  | 
| Michael Polenchuk | ebf5552 | 2018-01-25 13:22:39 +0400 | [diff] [blame] | 663 | Configure kernel boot options: | 
|  | 664 |  | 
|  | 665 | .. code-block:: yaml | 
|  | 666 |  | 
|  | 667 | linux: | 
|  | 668 | system: | 
|  | 669 | kernel: | 
|  | 670 | boot_options: | 
|  | 671 | - elevator=deadline | 
|  | 672 | - spectre_v2=off | 
|  | 673 | - nopti | 
|  | 674 |  | 
| Jiri Broulik | f8f55a2 | 2017-01-26 14:36:46 +0100 | [diff] [blame] | 675 | CPU | 
|  | 676 | ~~~ | 
|  | 677 |  | 
| teoyaomiqui | 32b1f7c | 2017-05-24 14:36:09 +0300 | [diff] [blame] | 678 | Enable cpufreq governor for every cpu: | 
| Jiri Broulik | f8f55a2 | 2017-01-26 14:36:46 +0100 | [diff] [blame] | 679 |  | 
|  | 680 | .. code-block:: yaml | 
|  | 681 |  | 
|  | 682 | linux: | 
|  | 683 | system: | 
|  | 684 | cpu: | 
|  | 685 | governor: performance | 
|  | 686 |  | 
| Nick Metz | f04f5f3 | 2018-01-08 15:25:04 +0100 | [diff] [blame] | 687 |  | 
| Jiri Broulik | 303905d | 2018-01-11 14:12:48 +0100 | [diff] [blame] | 688 | CGROUPS | 
|  | 689 | ~~~~~~~ | 
|  | 690 |  | 
|  | 691 | Setup linux cgroups: | 
|  | 692 |  | 
|  | 693 | .. code-block:: yaml | 
|  | 694 |  | 
|  | 695 | linux: | 
|  | 696 | system: | 
|  | 697 | cgroup: | 
|  | 698 | enabled: true | 
|  | 699 | group: | 
|  | 700 | ceph_group_1: | 
|  | 701 | controller: | 
|  | 702 | cpu: | 
|  | 703 | shares: | 
|  | 704 | value: 250 | 
|  | 705 | cpuacct: | 
|  | 706 | usage: | 
|  | 707 | value: 0 | 
|  | 708 | cpuset: | 
|  | 709 | cpus: | 
|  | 710 | value: 1,2,3 | 
|  | 711 | memory: | 
|  | 712 | limit_in_bytes: | 
|  | 713 | value: 2G | 
|  | 714 | memsw.limit_in_bytes: | 
|  | 715 | value: 3G | 
|  | 716 | mapping: | 
|  | 717 | subjects: | 
|  | 718 | - '@ceph' | 
|  | 719 | generic_group_1: | 
|  | 720 | controller: | 
|  | 721 | cpu: | 
|  | 722 | shares: | 
|  | 723 | value: 250 | 
|  | 724 | cpuacct: | 
|  | 725 | usage: | 
|  | 726 | value: 0 | 
|  | 727 | mapping: | 
|  | 728 | subjects: | 
|  | 729 | - '*:firefox' | 
|  | 730 | - 'student:cp' | 
|  | 731 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 732 | Shared libraries | 
| Nick Metz | f04f5f3 | 2018-01-08 15:25:04 +0100 | [diff] [blame] | 733 | ~~~~~~~~~~~~~~~~ | 
|  | 734 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 735 | Set additional shared library to Linux system library path: | 
| Nick Metz | f04f5f3 | 2018-01-08 15:25:04 +0100 | [diff] [blame] | 736 |  | 
|  | 737 | .. code-block:: yaml | 
|  | 738 |  | 
|  | 739 | linux: | 
|  | 740 | system: | 
|  | 741 | ld: | 
|  | 742 | library: | 
|  | 743 | java: | 
|  | 744 | - /usr/lib/jvm/jre-openjdk/lib/amd64/server | 
|  | 745 | - /opt/java/jre/lib/amd64/server | 
| Ondrej Smola | ef9bd76 | 2018-07-11 14:26:02 +0200 | [diff] [blame] | 746 |  | 
| Filip Pytloun | 2fde88b | 2017-10-05 10:30:29 +0200 | [diff] [blame] | 747 | Certificates | 
|  | 748 | ~~~~~~~~~~~~ | 
|  | 749 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 750 | Add certificate authority into system trusted CA bundle: | 
| Filip Pytloun | 2fde88b | 2017-10-05 10:30:29 +0200 | [diff] [blame] | 751 |  | 
|  | 752 | .. code-block:: yaml | 
|  | 753 |  | 
|  | 754 | linux: | 
|  | 755 | system: | 
|  | 756 | ca_certificates: | 
|  | 757 | mycert: | | 
|  | 758 | -----BEGIN CERTIFICATE----- | 
|  | 759 | MIICPDCCAaUCEHC65B0Q2Sk0tjjKewPMur8wDQYJKoZIhvcNAQECBQAwXzELMAkG | 
|  | 760 | A1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMTcwNQYDVQQLEy5DbGFz | 
|  | 761 | cyAzIFB1YmxpYyBQcmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTk2 | 
|  | 762 | MDEyOTAwMDAwMFoXDTI4MDgwMTIzNTk1OVowXzELMAkGA1UEBhMCVVMxFzAVBgNV | 
|  | 763 | BAoTDlZlcmlTaWduLCBJbmMuMTcwNQYDVQQLEy5DbGFzcyAzIFB1YmxpYyBQcmlt | 
|  | 764 | YXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIGfMA0GCSqGSIb3DQEBAQUAA4GN | 
|  | 765 | ADCBiQKBgQDJXFme8huKARS0EN8EQNvjV69qRUCPhAwL0TPZ2RHP7gJYHyX3KqhE | 
|  | 766 | BarsAx94f56TuZoAqiN91qyFomNFx3InzPRMxnVx0jnvT0Lwdd8KkMaOIG+YD/is | 
|  | 767 | I19wKTakyYbnsZogy1Olhec9vn2a/iRFM9x2Fe0PonFkTGUugWhFpwIDAQABMA0G | 
|  | 768 | CSqGSIb3DQEBAgUAA4GBALtMEivPLCYATxQT3ab7/AoRhIzzKBxnki98tsX63/Do | 
|  | 769 | lbwdj2wsqFHMc9ikwFPwTtYmwHYBV4GSXiHx0bH/59AhWM1pF+NEHJwZRDmJXNyc | 
|  | 770 | AA9WjQKZ7aKQRUzkuxCkPfAyAw7xzvjoyVGM5mKf5p/AfbdynMk2OmufTqj/ZA1k | 
|  | 771 | -----END CERTIFICATE----- | 
|  | 772 |  | 
| Filip Pytloun | 361096c | 2017-08-23 10:57:20 +0200 | [diff] [blame] | 773 | Sysfs | 
|  | 774 | ~~~~~ | 
|  | 775 |  | 
|  | 776 | Install sysfsutils and set sysfs attributes: | 
|  | 777 |  | 
|  | 778 | .. code-block:: yaml | 
|  | 779 |  | 
|  | 780 | linux: | 
|  | 781 | system: | 
|  | 782 | sysfs: | 
|  | 783 | scheduler: | 
|  | 784 | block/sda/queue/scheduler: deadline | 
|  | 785 | power: | 
|  | 786 | mode: | 
|  | 787 | power/state: 0660 | 
|  | 788 | owner: | 
|  | 789 | power/state: "root:power" | 
|  | 790 | devices/system/cpu/cpu0/cpufreq/scaling_governor: powersave | 
|  | 791 |  | 
| Ondrej Smola | ef9bd76 | 2018-07-11 14:26:02 +0200 | [diff] [blame] | 792 | Optional: You can also use list that will ensure order of items. | 
|  | 793 |  | 
|  | 794 | .. code-block:: yaml | 
|  | 795 |  | 
|  | 796 | linux: | 
|  | 797 | system: | 
|  | 798 | sysfs: | 
|  | 799 | scheduler: | 
|  | 800 | block/sda/queue/scheduler: deadline | 
|  | 801 | power: | 
|  | 802 | - mode: | 
|  | 803 | power/state: 0660 | 
|  | 804 | - owner: | 
|  | 805 | power/state: "root:power" | 
|  | 806 | - devices/system/cpu/cpu0/cpufreq/scaling_governor: powersave | 
|  | 807 |  | 
| Jakub Pavlik | b148c8c | 2017-02-12 21:30:48 +0100 | [diff] [blame] | 808 | Huge Pages | 
|  | 809 | ~~~~~~~~~~~~ | 
|  | 810 |  | 
|  | 811 | Huge Pages give a performance boost to applications that intensively deal | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 812 | with memory allocation/deallocation by decreasing memory fragmentation: | 
| Jakub Pavlik | b148c8c | 2017-02-12 21:30:48 +0100 | [diff] [blame] | 813 |  | 
|  | 814 | .. code-block:: yaml | 
|  | 815 |  | 
|  | 816 | linux: | 
|  | 817 | system: | 
|  | 818 | kernel: | 
|  | 819 | hugepages: | 
|  | 820 | small: | 
|  | 821 | size: 2M | 
|  | 822 | count: 107520 | 
|  | 823 | mount_point: /mnt/hugepages_2MB | 
| Michael Polenchuk | d9369fe | 2018-05-08 17:53:08 +0400 | [diff] [blame] | 824 | mount: false/true # default is true (mount immediately) / false (just save in the fstab) | 
| Jakub Pavlik | b148c8c | 2017-02-12 21:30:48 +0100 | [diff] [blame] | 825 | large: | 
|  | 826 | default: true # default automatically mounted | 
|  | 827 | size: 1G | 
|  | 828 | count: 210 | 
|  | 829 | mount_point: /mnt/hugepages_1GB | 
|  | 830 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 831 | .. note:: Not recommended to use both pagesizes concurrently. | 
| Jiri Broulik | f8f55a2 | 2017-01-26 14:36:46 +0100 | [diff] [blame] | 832 |  | 
| Jakub Pavlik | 5398d87 | 2017-02-13 22:30:47 +0100 | [diff] [blame] | 833 | Intel SR-IOV | 
|  | 834 | ~~~~~~~~~~~~ | 
|  | 835 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 836 | PCI-SIG Single Root I/O Virtualization and Sharing (SR-IOV) | 
|  | 837 | specification defines a standardized mechanism to virtualize | 
|  | 838 | PCIe devices. The mechanism can virtualize a single PCIe | 
|  | 839 | Ethernet controller to appear as multiple PCIe devices: | 
| Jakub Pavlik | 5398d87 | 2017-02-13 22:30:47 +0100 | [diff] [blame] | 840 |  | 
|  | 841 | .. code-block:: yaml | 
|  | 842 |  | 
|  | 843 | linux: | 
|  | 844 | system: | 
|  | 845 | kernel: | 
|  | 846 | sriov: True | 
|  | 847 | unsafe_interrupts: False # Default is false. for older platforms and AMD we need to add interrupt remapping workaround | 
|  | 848 | rc: | 
|  | 849 | local: | | 
|  | 850 | #!/bin/sh -e | 
|  | 851 | # Enable 7 VF on eth1 | 
|  | 852 | echo 7 > /sys/class/net/eth1/device/sriov_numvfs; sleep 2; ifup -a | 
|  | 853 | exit 0 | 
|  | 854 |  | 
| Jakub Pavlik | 6c9ead1 | 2017-02-16 21:53:13 +0100 | [diff] [blame] | 855 | Isolate CPU options | 
|  | 856 | ~~~~~~~~~~~~~~~~~~~ | 
|  | 857 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 858 | Remove the specified CPUs, as defined by the cpu_number values, from | 
|  | 859 | the general kernel SMP balancing and scheduler algroithms. The only | 
|  | 860 | way to move a process onto or off an *isolated* CPU is via the CPU | 
|  | 861 | affinity syscalls. ``cpu_number begins`` at ``0``, so the | 
|  | 862 | maximum value is ``1`` less than the number of CPUs on the system.: | 
| Jakub Pavlik | 6c9ead1 | 2017-02-16 21:53:13 +0100 | [diff] [blame] | 863 |  | 
|  | 864 | .. code-block:: yaml | 
|  | 865 |  | 
|  | 866 | linux: | 
|  | 867 | system: | 
|  | 868 | kernel: | 
|  | 869 | isolcpu: 1,2,3,4,5,6,7 # isolate first cpu 0 | 
| Jiri Broulik | f8f55a2 | 2017-01-26 14:36:46 +0100 | [diff] [blame] | 870 |  | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 871 | Repositories | 
|  | 872 | ~~~~~~~~~~~~ | 
|  | 873 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 874 | RedHat-based Linux with additional OpenStack repo: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 875 |  | 
|  | 876 | .. code-block:: yaml | 
|  | 877 |  | 
|  | 878 | linux: | 
|  | 879 | system: | 
|  | 880 | ... | 
|  | 881 | repo: | 
|  | 882 | rdo-icehouse: | 
|  | 883 | enabled: true | 
|  | 884 | source: 'http://repos.fedorapeople.org/repos/openstack/openstack-icehouse/epel-6/' | 
|  | 885 | pgpcheck: 0 | 
|  | 886 |  | 
|  | 887 | Ensure system repository to use czech Debian mirror (``default: true``) | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 888 | Also pin it's packages with priority ``900``: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 889 |  | 
|  | 890 | .. code-block:: yaml | 
|  | 891 |  | 
|  | 892 | linux: | 
|  | 893 | system: | 
|  | 894 | repo: | 
|  | 895 | debian: | 
|  | 896 | default: true | 
|  | 897 | source: "deb http://ftp.cz.debian.org/debian/ jessie main contrib non-free" | 
|  | 898 | # Import signing key from URL if needed | 
|  | 899 | key_url: "http://dummy.com/public.gpg" | 
|  | 900 | pin: | 
|  | 901 | - pin: 'origin "ftp.cz.debian.org"' | 
|  | 902 | priority: 900 | 
|  | 903 | package: '*' | 
|  | 904 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 905 | .. note:: For old Ubuntu releases (<xenial) | 
| azvyagintsev | ff089d2 | 2018-07-27 16:52:34 +0200 | [diff] [blame] | 906 | extra packages for apt transport, like ``apt-transport-https`` | 
|  | 907 | may be required to be installed manually. | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 908 | (Chicken-eggs issue: we need to install packages to | 
| azvyagintsev | ff089d2 | 2018-07-27 16:52:34 +0200 | [diff] [blame] | 909 | reach repo from where they should be installed) | 
|  | 910 | Otherwise, you still can try 'fortune' and install prereq.packages before | 
|  | 911 | any repo configuration, using list of requires in map.jinja. | 
|  | 912 |  | 
|  | 913 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 914 | Disabling any prerequisite packages installation: | 
|  | 915 |  | 
| azvyagintsev | ff089d2 | 2018-07-27 16:52:34 +0200 | [diff] [blame] | 916 | You can simply drop any package pre-installation (before system.linux.repo | 
|  | 917 | will be processed) via cluster lvl: | 
|  | 918 |  | 
|  | 919 | .. code-block:: yaml | 
|  | 920 |  | 
|  | 921 | linux: | 
|  | 922 | system: | 
|  | 923 | pkgs: ~ | 
|  | 924 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 925 | Package manager proxy global setup: | 
| Petr Michalec | 10462bb | 2017-03-23 19:18:08 +0100 | [diff] [blame] | 926 |  | 
|  | 927 | .. code-block:: yaml | 
|  | 928 |  | 
|  | 929 | linux: | 
|  | 930 | system: | 
|  | 931 | ... | 
|  | 932 | repo: | 
|  | 933 | apt-mk: | 
|  | 934 | source: "deb http://apt-mk.mirantis.com/ stable main salt" | 
|  | 935 | ... | 
|  | 936 | proxy: | 
|  | 937 | pkg: | 
|  | 938 | enabled: true | 
|  | 939 | ftp:   ftp://ftp-proxy-for-apt.host.local:2121 | 
|  | 940 | ... | 
|  | 941 | # NOTE: Global defaults for any other componet that configure proxy on the system. | 
|  | 942 | #       If your environment has just one simple proxy, set it on linux:system:proxy. | 
|  | 943 | # | 
|  | 944 | # fall back system defaults if linux:system:proxy:pkg has no protocol specific entries | 
|  | 945 | # as for https and http | 
|  | 946 | ftp:   ftp://proxy.host.local:2121 | 
|  | 947 | http:  http://proxy.host.local:3142 | 
|  | 948 | https: https://proxy.host.local:3143 | 
|  | 949 |  | 
|  | 950 | Package manager proxy setup per repository: | 
|  | 951 |  | 
|  | 952 | .. code-block:: yaml | 
|  | 953 |  | 
|  | 954 | linux: | 
|  | 955 | system: | 
|  | 956 | ... | 
|  | 957 | repo: | 
|  | 958 | debian: | 
|  | 959 | source: "deb http://apt-mk.mirantis.com/ stable main salt" | 
|  | 960 | ... | 
|  | 961 | apt-mk: | 
|  | 962 | source: "deb http://apt-mk.mirantis.com/ stable main salt" | 
|  | 963 | # per repository proxy | 
|  | 964 | proxy: | 
|  | 965 | enabled: true | 
|  | 966 | http:  http://maas-01:8080 | 
|  | 967 | https: http://maas-01:8080 | 
|  | 968 | ... | 
|  | 969 | proxy: | 
| Oleksandr Vlasov | 27a6c3a | 2017-04-11 16:01:19 -0600 | [diff] [blame] | 970 | # package manager fallback defaults | 
| Petr Michalec | 10462bb | 2017-03-23 19:18:08 +0100 | [diff] [blame] | 971 | # used if linux:system:repo:apt-mk:proxy has no protocol specific entries | 
|  | 972 | pkg: | 
|  | 973 | enabled: true | 
|  | 974 | ftp:   ftp://proxy.host.local:2121 | 
|  | 975 | #http:  http://proxy.host.local:3142 | 
|  | 976 | #https: https://proxy.host.local:3143 | 
| Oleksandr Vlasov | 27a6c3a | 2017-04-11 16:01:19 -0600 | [diff] [blame] | 977 | ... | 
| Petr Michalec | 10462bb | 2017-03-23 19:18:08 +0100 | [diff] [blame] | 978 | # global system fallback system defaults | 
|  | 979 | ftp:   ftp://proxy.host.local:2121 | 
|  | 980 | http:  http://proxy.host.local:3142 | 
|  | 981 | https: https://proxy.host.local:3143 | 
|  | 982 |  | 
| Jiri Broulik | 34a29b4 | 2017-04-25 14:42:54 +0200 | [diff] [blame] | 983 | Remove all repositories: | 
|  | 984 |  | 
|  | 985 | .. code-block:: yaml | 
|  | 986 |  | 
|  | 987 | linux: | 
|  | 988 | system: | 
|  | 989 | purge_repos: true | 
|  | 990 |  | 
| azvyagintsev | ff089d2 | 2018-07-27 16:52:34 +0200 | [diff] [blame] | 991 | Refresh repositories metada, after configuration: | 
|  | 992 |  | 
|  | 993 | .. code-block:: yaml | 
|  | 994 |  | 
|  | 995 | linux: | 
|  | 996 | system: | 
|  | 997 | refresh_repos_meta: true | 
|  | 998 |  | 
| Filip Pytloun | c512e6c | 2017-11-22 14:28:10 +0100 | [diff] [blame] | 999 | Setup custom apt config options: | 
|  | 1000 |  | 
|  | 1001 | .. code-block:: yaml | 
|  | 1002 |  | 
|  | 1003 | linux: | 
|  | 1004 | system: | 
|  | 1005 | apt: | 
|  | 1006 | config: | 
|  | 1007 | compression-workaround: | 
|  | 1008 | "Acquire::CompressionTypes::Order": "gz" | 
|  | 1009 | docker-clean: | 
|  | 1010 | "DPkg::Post-Invoke": | 
|  | 1011 | - "rm -f /var/cache/apt/archives/*.deb /var/cache/apt/archives/partial/*.deb /var/cache/apt/*.bin || true" | 
|  | 1012 | "APT::Update::Post-Invoke": | 
|  | 1013 | - "rm -f /var/cache/apt/archives/*.deb /var/cache/apt/archives/partial/*.deb /var/cache/apt/*.bin || true" | 
| Jiri Broulik | 34a29b4 | 2017-04-25 14:42:54 +0200 | [diff] [blame] | 1014 |  | 
| Petr Michalec | 10462bb | 2017-03-23 19:18:08 +0100 | [diff] [blame] | 1015 | RC | 
|  | 1016 | ~~ | 
|  | 1017 |  | 
| Jakub Pavlik | 7885938 | 2016-01-21 11:26:39 +0100 | [diff] [blame] | 1018 | rc.local example | 
|  | 1019 |  | 
|  | 1020 | .. code-block:: yaml | 
|  | 1021 |  | 
|  | 1022 | linux: | 
|  | 1023 | system: | 
|  | 1024 | rc: | 
|  | 1025 | local: | | 
|  | 1026 | #!/bin/sh -e | 
|  | 1027 | # | 
|  | 1028 | # rc.local | 
|  | 1029 | # | 
|  | 1030 | # This script is executed at the end of each multiuser runlevel. | 
|  | 1031 | # Make sure that the script will "exit 0" on success or any other | 
|  | 1032 | # value on error. | 
|  | 1033 | # | 
|  | 1034 | # In order to enable or disable this script just change the execution | 
|  | 1035 | # bits. | 
|  | 1036 | # | 
|  | 1037 | # By default this script does nothing. | 
|  | 1038 | exit 0 | 
|  | 1039 |  | 
| Filip Pytloun | 1f40dac | 2016-01-22 15:52:57 +0100 | [diff] [blame] | 1040 | Prompt | 
|  | 1041 | ~~~~~~ | 
|  | 1042 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1043 | Setting prompt is implemented by creating ``/etc/profile.d/prompt.sh``. | 
|  | 1044 | Every user can have different prompt: | 
| Filip Pytloun | 1f40dac | 2016-01-22 15:52:57 +0100 | [diff] [blame] | 1045 |  | 
|  | 1046 | .. code-block:: yaml | 
|  | 1047 |  | 
|  | 1048 | linux: | 
|  | 1049 | system: | 
|  | 1050 | prompt: | 
|  | 1051 | root: \\n\\[\\033[0;37m\\]\\D{%y/%m/%d %H:%M:%S} $(hostname -f)\\[\\e[0m\\]\\n\\[\\e[1;31m\\][\\u@\\h:\\w]\\[\\e[0m\\] | 
|  | 1052 | default: \\n\\D{%y/%m/%d %H:%M:%S} $(hostname -f)\\n[\\u@\\h:\\w] | 
|  | 1053 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1054 | On Debian systems, to set prompt system-wide, it's necessary to | 
|  | 1055 | remove setting PS1 in ``/etc/bash.bashrc`` and ``~/.bashrc``, | 
|  | 1056 | which comes from ``/etc/skel/.bashrc``. This formula will do | 
|  | 1057 | this automatically, but will not touch existing user's | 
|  | 1058 | ``~/.bashrc`` files except root. | 
| Jakub Pavlik | 7885938 | 2016-01-21 11:26:39 +0100 | [diff] [blame] | 1059 |  | 
| Filip Pytloun | eef11c1 | 2016-03-25 11:00:23 +0100 | [diff] [blame] | 1060 | Bash | 
|  | 1061 | ~~~~ | 
|  | 1062 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1063 | Fix bash configuration to preserve history across sessions | 
|  | 1064 | like ZSH does by default: | 
| Filip Pytloun | eef11c1 | 2016-03-25 11:00:23 +0100 | [diff] [blame] | 1065 |  | 
|  | 1066 | .. code-block:: yaml | 
|  | 1067 |  | 
|  | 1068 | linux: | 
|  | 1069 | system: | 
|  | 1070 | bash: | 
|  | 1071 | preserve_history: true | 
|  | 1072 |  | 
| Dmitry Teselkin | 949398e | 2018-05-03 15:50:00 +0300 | [diff] [blame] | 1073 | Login banner message | 
|  | 1074 | ~~~~~~~~~~~~~~~~~~~~ | 
|  | 1075 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1076 | ``/etc/issue`` is a text file which contains a message or system | 
|  | 1077 | identification to be printed before the login prompt. It may contain | 
| Dmitry Teselkin | 949398e | 2018-05-03 15:50:00 +0300 | [diff] [blame] | 1078 | various @char and \char sequences, if supported by the getty-type | 
|  | 1079 | program employed on the system. | 
|  | 1080 |  | 
|  | 1081 | Setting logon banner message is easy: | 
|  | 1082 |  | 
|  | 1083 | .. code-block:: yaml | 
|  | 1084 |  | 
|  | 1085 | liunx: | 
|  | 1086 | system: | 
|  | 1087 | banner: | 
|  | 1088 | enabled: true | 
|  | 1089 | contents: | | 
|  | 1090 | UNAUTHORIZED ACCESS TO THIS SYSTEM IS PROHIBITED | 
|  | 1091 |  | 
|  | 1092 | You must have explicit, authorized permission to access or configure this | 
|  | 1093 | device. Unauthorized attempts and actions to access or use this system may | 
|  | 1094 | result in civil and/or criminal penalties. | 
|  | 1095 | All activities performed on this system are logged and monitored. | 
|  | 1096 |  | 
| Filip Pytloun | e874dfb | 2016-01-22 16:57:34 +0100 | [diff] [blame] | 1097 | Message of the day | 
|  | 1098 | ~~~~~~~~~~~~~~~~~~ | 
|  | 1099 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1100 | ``pam_motd`` from package ``libpam-modules`` is used for dynamic | 
|  | 1101 | messages of the day. Setting custom ``motd`` will clean up existing ones. | 
| Filip Pytloun | e874dfb | 2016-01-22 16:57:34 +0100 | [diff] [blame] | 1102 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1103 | Setting static ``motd`` will replace existing ``/etc/motd`` and remove | 
|  | 1104 | scripts from ``/etc/update-motd.d``. | 
| Dmitry Teselkin | 538c824 | 2018-04-02 16:13:37 +0300 | [diff] [blame] | 1105 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1106 | Setting static ``motd``: | 
| Dmitry Teselkin | 538c824 | 2018-04-02 16:13:37 +0300 | [diff] [blame] | 1107 |  | 
|  | 1108 | .. code-block:: yaml | 
|  | 1109 |  | 
|  | 1110 | linux: | 
|  | 1111 | system: | 
|  | 1112 | motd: | | 
|  | 1113 | UNAUTHORIZED ACCESS TO THIS SYSTEM IS PROHIBITED | 
|  | 1114 |  | 
|  | 1115 | You must have explicit, authorized permission to access or configure this | 
|  | 1116 | device. Unauthorized attempts and actions to access or use this system may | 
|  | 1117 | result in civil and/or criminal penalties. | 
|  | 1118 | All activities performed on this system are logged and monitored. | 
|  | 1119 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1120 | Setting dynamic ``motd``: | 
| Dmitry Teselkin | 538c824 | 2018-04-02 16:13:37 +0300 | [diff] [blame] | 1121 |  | 
| Filip Pytloun | e874dfb | 2016-01-22 16:57:34 +0100 | [diff] [blame] | 1122 | .. code-block:: yaml | 
|  | 1123 |  | 
|  | 1124 | linux: | 
|  | 1125 | system: | 
|  | 1126 | motd: | 
|  | 1127 | - release: | | 
|  | 1128 | #!/bin/sh | 
|  | 1129 | [ -r /etc/lsb-release ] && . /etc/lsb-release | 
|  | 1130 |  | 
|  | 1131 | if [ -z "$DISTRIB_DESCRIPTION" ] && [ -x /usr/bin/lsb_release ]; then | 
|  | 1132 | # Fall back to using the very slow lsb_release utility | 
|  | 1133 | DISTRIB_DESCRIPTION=$(lsb_release -s -d) | 
|  | 1134 | fi | 
|  | 1135 |  | 
|  | 1136 | printf "Welcome to %s (%s %s %s)\n" "$DISTRIB_DESCRIPTION" "$(uname -o)" "$(uname -r)" "$(uname -m)" | 
|  | 1137 | - warning: | | 
|  | 1138 | #!/bin/sh | 
|  | 1139 | printf "This is [company name] network.\n" | 
|  | 1140 | printf "Unauthorized access strictly prohibited.\n" | 
|  | 1141 |  | 
| Marek Celoud | 713e907 | 2017-05-18 15:20:25 +0200 | [diff] [blame] | 1142 | Services | 
|  | 1143 | ~~~~~~~~ | 
|  | 1144 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1145 | Stop and disable the ``linux`` service: | 
| Marek Celoud | 713e907 | 2017-05-18 15:20:25 +0200 | [diff] [blame] | 1146 |  | 
|  | 1147 | .. code-block:: yaml | 
|  | 1148 |  | 
|  | 1149 | linux: | 
|  | 1150 | system: | 
|  | 1151 | service: | 
|  | 1152 | apt-daily.timer: | 
|  | 1153 | status: dead | 
|  | 1154 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1155 | Possible statuses are ``dead`` (disable service by default), ``running`` | 
|  | 1156 | (enable service by default), ``enabled``, ``disabled``: | 
| Marek Celoud | 713e907 | 2017-05-18 15:20:25 +0200 | [diff] [blame] | 1157 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1158 | Linux with the ``atop`` service: | 
| Serhiy Ovsianikov | 67bd56a | 2017-08-11 15:56:01 +0300 | [diff] [blame] | 1159 |  | 
|  | 1160 | .. code-block:: yaml | 
|  | 1161 |  | 
|  | 1162 | linux: | 
|  | 1163 | system: | 
|  | 1164 | atop: | 
|  | 1165 | enabled: true | 
|  | 1166 | interval: 20 | 
|  | 1167 | logpath: "/var/log/atop" | 
|  | 1168 | outfile: "/var/log/atop/daily.log" | 
|  | 1169 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1170 | Linux with the ``mcelog`` service: | 
| Oleksii Chupryn | 144432b | 2018-05-22 10:34:48 +0300 | [diff] [blame] | 1171 |  | 
|  | 1172 | .. code-block:: yaml | 
|  | 1173 |  | 
|  | 1174 | linux: | 
|  | 1175 | system: | 
|  | 1176 | mcelog: | 
|  | 1177 | enabled: true | 
|  | 1178 | logging: | 
|  | 1179 | syslog: true | 
|  | 1180 | syslog_error: true | 
|  | 1181 |  | 
| Filip Pytloun | 2f70b49 | 2016-02-19 15:55:25 +0100 | [diff] [blame] | 1182 | RHEL / CentOS | 
| Filip Pytloun | 8296bb9 | 2016-02-19 18:42:09 +0100 | [diff] [blame] | 1183 | ^^^^^^^^^^^^^ | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1184 | Currently, ``update-motd`` is not available | 
|  | 1185 | for RHEL. So there is no native support for dynamic ``motd``. | 
|  | 1186 | You can still set a static one, with a different pillar structure: | 
| Filip Pytloun | 2f70b49 | 2016-02-19 15:55:25 +0100 | [diff] [blame] | 1187 |  | 
|  | 1188 | .. code-block:: yaml | 
|  | 1189 |  | 
|  | 1190 | linux: | 
|  | 1191 | system: | 
|  | 1192 | motd: | | 
|  | 1193 | This is [company name] network. | 
|  | 1194 | Unauthorized access strictly prohibited. | 
|  | 1195 |  | 
| Filip Pytloun | 8296bb9 | 2016-02-19 18:42:09 +0100 | [diff] [blame] | 1196 | Haveged | 
|  | 1197 | ~~~~~~~ | 
|  | 1198 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1199 | If you are running headless server and are low on entropy, | 
|  | 1200 | you may set up Haveged: | 
| Filip Pytloun | 8296bb9 | 2016-02-19 18:42:09 +0100 | [diff] [blame] | 1201 |  | 
|  | 1202 | .. code-block:: yaml | 
|  | 1203 |  | 
|  | 1204 | linux: | 
|  | 1205 | system: | 
|  | 1206 | haveged: | 
|  | 1207 | enabled: true | 
|  | 1208 |  | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1209 | Linux network | 
|  | 1210 | ------------- | 
|  | 1211 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1212 | Linux with network manager: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1213 |  | 
|  | 1214 | .. code-block:: yaml | 
|  | 1215 |  | 
|  | 1216 | linux: | 
|  | 1217 | network: | 
|  | 1218 | enabled: true | 
|  | 1219 | network_manager: true | 
|  | 1220 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1221 | Linux with default static network interfaces, default gateway | 
|  | 1222 | interface and DNS servers: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1223 |  | 
|  | 1224 | .. code-block:: yaml | 
|  | 1225 |  | 
|  | 1226 | linux: | 
|  | 1227 | network: | 
|  | 1228 | enabled: true | 
|  | 1229 | interface: | 
|  | 1230 | eth0: | 
|  | 1231 | enabled: true | 
|  | 1232 | type: eth | 
|  | 1233 | address: 192.168.0.102 | 
|  | 1234 | netmask: 255.255.255.0 | 
|  | 1235 | gateway: 192.168.0.1 | 
|  | 1236 | name_servers: | 
|  | 1237 | - 8.8.8.8 | 
|  | 1238 | - 8.8.4.4 | 
|  | 1239 | mtu: 1500 | 
|  | 1240 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1241 | Linux with bonded interfaces and disabled ``NetworkManager``: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1242 |  | 
|  | 1243 | .. code-block:: yaml | 
|  | 1244 |  | 
|  | 1245 | linux: | 
|  | 1246 | network: | 
|  | 1247 | enabled: true | 
|  | 1248 | interface: | 
|  | 1249 | eth0: | 
|  | 1250 | type: eth | 
|  | 1251 | ... | 
|  | 1252 | eth1: | 
|  | 1253 | type: eth | 
|  | 1254 | ... | 
|  | 1255 | bond0: | 
|  | 1256 | enabled: true | 
|  | 1257 | type: bond | 
|  | 1258 | address: 192.168.0.102 | 
|  | 1259 | netmask: 255.255.255.0 | 
|  | 1260 | mtu: 1500 | 
|  | 1261 | use_in: | 
|  | 1262 | - interface: ${linux:interface:eth0} | 
|  | 1263 | - interface: ${linux:interface:eth0} | 
| jan kaufman | 6d30adf | 2016-01-18 17:30:12 +0100 | [diff] [blame] | 1264 | network_manager: | 
|  | 1265 | disable: true | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1266 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1267 | Linux with VLAN ``interface_params``: | 
| Jan Kaufman | 6a1ad71 | 2015-12-11 14:44:19 +0100 | [diff] [blame] | 1268 |  | 
|  | 1269 | .. code-block:: yaml | 
|  | 1270 |  | 
|  | 1271 | linux: | 
|  | 1272 | network: | 
|  | 1273 | enabled: true | 
|  | 1274 | interface: | 
|  | 1275 | vlan69: | 
|  | 1276 | type: vlan | 
| jan kaufman | c0bd76f | 2015-12-15 16:45:44 +0100 | [diff] [blame] | 1277 | use_interfaces: | 
| Jan Kaufman | 6a1ad71 | 2015-12-11 14:44:19 +0100 | [diff] [blame] | 1278 | - interface: ${linux:interface:bond0} | 
| Jan Kaufman | 6a1ad71 | 2015-12-11 14:44:19 +0100 | [diff] [blame] | 1279 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1280 | Linux with wireless interface parameters: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1281 |  | 
|  | 1282 | .. code-block:: yaml | 
|  | 1283 |  | 
|  | 1284 | linux: | 
|  | 1285 | network: | 
|  | 1286 | enabled: true | 
|  | 1287 | gateway: 10.0.0.1 | 
| Jan Kaufman | 6a1ad71 | 2015-12-11 14:44:19 +0100 | [diff] [blame] | 1288 | default_interface: eth0 | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1289 | interface: | 
|  | 1290 | wlan0: | 
|  | 1291 | type: eth | 
|  | 1292 | wireless: | 
|  | 1293 | essid: example | 
|  | 1294 | key: example_key | 
|  | 1295 | security: wpa | 
|  | 1296 | priority: 1 | 
|  | 1297 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1298 | Linux networks with routes defined: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1299 |  | 
|  | 1300 | .. code-block:: yaml | 
|  | 1301 |  | 
|  | 1302 | linux: | 
|  | 1303 | network: | 
|  | 1304 | enabled: true | 
|  | 1305 | gateway: 10.0.0.1 | 
| Jan Kaufman | 6a1ad71 | 2015-12-11 14:44:19 +0100 | [diff] [blame] | 1306 | default_interface: eth0 | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1307 | interface: | 
|  | 1308 | eth0: | 
|  | 1309 | type: eth | 
|  | 1310 | route: | 
|  | 1311 | default: | 
|  | 1312 | address: 192.168.0.123 | 
|  | 1313 | netmask: 255.255.255.0 | 
|  | 1314 | gateway: 192.168.0.1 | 
|  | 1315 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1316 | Native Linux Bridges: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1317 |  | 
|  | 1318 | .. code-block:: yaml | 
|  | 1319 |  | 
|  | 1320 | linux: | 
|  | 1321 | network: | 
|  | 1322 | interface: | 
|  | 1323 | eth1: | 
|  | 1324 | enabled: true | 
|  | 1325 | type: eth | 
|  | 1326 | proto: manual | 
|  | 1327 | up_cmds: | 
|  | 1328 | - ip address add 0/0 dev $IFACE | 
|  | 1329 | - ip link set $IFACE up | 
|  | 1330 | down_cmds: | 
|  | 1331 | - ip link set $IFACE down | 
|  | 1332 | br-ex: | 
|  | 1333 | enabled: true | 
|  | 1334 | type: bridge | 
|  | 1335 | address: ${linux:network:host:public_local:address} | 
|  | 1336 | netmask: 255.255.255.0 | 
|  | 1337 | use_interfaces: | 
|  | 1338 | - eth1 | 
|  | 1339 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1340 | Open vSwitch Bridges: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1341 |  | 
|  | 1342 | .. code-block:: yaml | 
|  | 1343 |  | 
|  | 1344 | linux: | 
|  | 1345 | network: | 
|  | 1346 | bridge: openvswitch | 
|  | 1347 | interface: | 
|  | 1348 | eth1: | 
|  | 1349 | enabled: true | 
|  | 1350 | type: eth | 
|  | 1351 | proto: manual | 
|  | 1352 | up_cmds: | 
|  | 1353 | - ip address add 0/0 dev $IFACE | 
|  | 1354 | - ip link set $IFACE up | 
|  | 1355 | down_cmds: | 
|  | 1356 | - ip link set $IFACE down | 
|  | 1357 | br-ex: | 
|  | 1358 | enabled: true | 
|  | 1359 | type: bridge | 
|  | 1360 | address: ${linux:network:host:public_local:address} | 
|  | 1361 | netmask: 255.255.255.0 | 
|  | 1362 | use_interfaces: | 
|  | 1363 | - eth1 | 
| Dmitry Stremkouski | a581ea7 | 2017-10-18 14:24:16 +0300 | [diff] [blame] | 1364 | br-prv: | 
|  | 1365 | enabled: true | 
|  | 1366 | type: ovs_bridge | 
|  | 1367 | mtu: 65000 | 
|  | 1368 | br-ens7: | 
|  | 1369 | enabled: true | 
|  | 1370 | name: br-ens7 | 
|  | 1371 | type: ovs_bridge | 
|  | 1372 | proto: manual | 
|  | 1373 | mtu: 9000 | 
|  | 1374 | use_interfaces: | 
|  | 1375 | - ens7 | 
|  | 1376 | patch-br-ens7-br-prv: | 
|  | 1377 | enabled: true | 
|  | 1378 | name: ens7-prv | 
|  | 1379 | ovs_type: ovs_port | 
|  | 1380 | type: ovs_port | 
|  | 1381 | bridge: br-ens7 | 
|  | 1382 | port_type: patch | 
|  | 1383 | peer: prv-ens7 | 
| Oleksii Chupryn | 694ee72 | 2018-06-13 14:08:58 +0300 | [diff] [blame] | 1384 | tag: 109 # [] to unset a tag | 
| Dmitry Stremkouski | a581ea7 | 2017-10-18 14:24:16 +0300 | [diff] [blame] | 1385 | mtu: 65000 | 
|  | 1386 | patch-br-prv-br-ens7: | 
|  | 1387 | enabled: true | 
|  | 1388 | name: prv-ens7 | 
|  | 1389 | bridge: br-prv | 
|  | 1390 | ovs_type: ovs_port | 
|  | 1391 | type: ovs_port | 
|  | 1392 | port_type: patch | 
|  | 1393 | peer: ens7-prv | 
| Oleksii Chupryn | 694ee72 | 2018-06-13 14:08:58 +0300 | [diff] [blame] | 1394 | tag: 109 | 
| Dmitry Stremkouski | a581ea7 | 2017-10-18 14:24:16 +0300 | [diff] [blame] | 1395 | mtu: 65000 | 
|  | 1396 | ens7: | 
|  | 1397 | enabled: true | 
|  | 1398 | name: ens7 | 
|  | 1399 | proto: manual | 
|  | 1400 | ovs_port_type: OVSPort | 
|  | 1401 | type: ovs_port | 
|  | 1402 | ovs_bridge: br-ens7 | 
|  | 1403 | bridge: br-ens7 | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1404 |  | 
| Petr Jediný | 8f8ae54 | 2017-07-13 16:19:12 +0200 | [diff] [blame] | 1405 | Debian manual proto interfaces | 
|  | 1406 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1407 | When you are changing interface proto from static in up state | 
|  | 1408 | to manual, you may need to flush ip addresses. For example, | 
|  | 1409 | if you want to use the interface and the ip on the bridge. | 
|  | 1410 | This can be done by setting the ``ipflush_onchange`` to true. | 
| Petr Jediný | 8f8ae54 | 2017-07-13 16:19:12 +0200 | [diff] [blame] | 1411 |  | 
|  | 1412 | .. code-block:: yaml | 
|  | 1413 |  | 
|  | 1414 | linux: | 
|  | 1415 | network: | 
|  | 1416 | interface: | 
|  | 1417 | eth1: | 
|  | 1418 | enabled: true | 
|  | 1419 | type: eth | 
|  | 1420 | proto: manual | 
|  | 1421 | mtu: 9100 | 
|  | 1422 | ipflush_onchange: true | 
|  | 1423 |  | 
| Jiri Broulik | 1a191e3 | 2018-01-15 15:54:21 +0100 | [diff] [blame] | 1424 | Debian static proto interfaces | 
|  | 1425 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1426 | When you are changing interface proto from dhcp in up state to | 
|  | 1427 | static, you may need to flush ip addresses and restart interface | 
|  | 1428 | to assign ip address from a managed file. For example, if you wantto | 
|  | 1429 | use the interface and the ip on the bridge. This can be done by | 
|  | 1430 | setting the ``ipflush_onchange`` with combination ``restart_on_ipflush`` | 
|  | 1431 | param set to true. | 
| Jiri Broulik | 1a191e3 | 2018-01-15 15:54:21 +0100 | [diff] [blame] | 1432 |  | 
|  | 1433 | .. code-block:: yaml | 
|  | 1434 |  | 
|  | 1435 | linux: | 
|  | 1436 | network: | 
|  | 1437 | interface: | 
|  | 1438 | eth1: | 
|  | 1439 | enabled: true | 
|  | 1440 | type: eth | 
|  | 1441 | proto: static | 
|  | 1442 | address: 10.1.0.22 | 
|  | 1443 | netmask: 255.255.255.0 | 
|  | 1444 | ipflush_onchange: true | 
|  | 1445 | restart_on_ipflush: true | 
| Petr Jediný | 8f8ae54 | 2017-07-13 16:19:12 +0200 | [diff] [blame] | 1446 |  | 
| Petr Jediný | d577cb5 | 2017-06-28 20:17:49 +0200 | [diff] [blame] | 1447 | Concatinating and removing interface files | 
|  | 1448 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1449 | Debian based distributions have ``/etc/network/interfaces.d/`` | 
|  | 1450 | directory, where you can store configuration of network | 
|  | 1451 | interfaces in separate files. You can concatinate the files | 
|  | 1452 | to the defined destination when needed, this operation removes | 
|  | 1453 | the file from the ``/etc/network/interfaces.d/``. If you just need | 
|  | 1454 | to remove iface files, you can use the ``remove_iface_files`` key. | 
| Petr Jediný | d577cb5 | 2017-06-28 20:17:49 +0200 | [diff] [blame] | 1455 |  | 
|  | 1456 | .. code-block:: yaml | 
|  | 1457 |  | 
|  | 1458 | linux: | 
|  | 1459 | network: | 
|  | 1460 | concat_iface_files: | 
|  | 1461 | - src: '/etc/network/interfaces.d/50-cloud-init.cfg' | 
|  | 1462 | dst: '/etc/network/interfaces' | 
|  | 1463 | remove_iface_files: | 
|  | 1464 | - '/etc/network/interfaces.d/90-custom.cfg' | 
|  | 1465 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1466 | Configure DHCP client | 
| Petr Jediný | d577cb5 | 2017-06-28 20:17:49 +0200 | [diff] [blame] | 1467 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1468 | None of the keys is mandatory, include only those you really need. | 
|  | 1469 | For full list of available options under send, supersede, prepend, | 
|  | 1470 | append refer to dhcp-options(5). | 
| Oleksandr Vlasov | 27a6c3a | 2017-04-11 16:01:19 -0600 | [diff] [blame] | 1471 |  | 
|  | 1472 | .. code-block:: yaml | 
|  | 1473 |  | 
|  | 1474 | linux: | 
|  | 1475 | network: | 
|  | 1476 | dhclient: | 
|  | 1477 | enabled: true | 
|  | 1478 | backoff_cutoff: 15 | 
|  | 1479 | initial_interval: 10 | 
|  | 1480 | reboot: 10 | 
|  | 1481 | retry: 60 | 
|  | 1482 | select_timeout: 0 | 
|  | 1483 | timeout: 120 | 
|  | 1484 | send: | 
|  | 1485 | - option: host-name | 
|  | 1486 | declaration: "= gethostname()" | 
|  | 1487 | supersede: | 
|  | 1488 | - option: host-name | 
|  | 1489 | declaration: "spaceship" | 
|  | 1490 | - option: domain-name | 
|  | 1491 | declaration: "domain.home" | 
|  | 1492 | #- option: arp-cache-timeout | 
|  | 1493 | #  declaration: 20 | 
|  | 1494 | prepend: | 
|  | 1495 | - option: domain-name-servers | 
|  | 1496 | declaration: | 
|  | 1497 | - 8.8.8.8 | 
|  | 1498 | - 8.8.4.4 | 
|  | 1499 | - option: domain-search | 
|  | 1500 | declaration: | 
|  | 1501 | - example.com | 
|  | 1502 | - eng.example.com | 
|  | 1503 | #append: | 
|  | 1504 | #- option: domain-name-servers | 
|  | 1505 | #  declaration: 127.0.0.1 | 
|  | 1506 | # ip or subnet to reject dhcp offer from | 
|  | 1507 | reject: | 
|  | 1508 | - 192.33.137.209 | 
|  | 1509 | - 10.0.2.0/24 | 
|  | 1510 | request: | 
|  | 1511 | - subnet-mask | 
|  | 1512 | - broadcast-address | 
|  | 1513 | - time-offset | 
|  | 1514 | - routers | 
|  | 1515 | - domain-name | 
|  | 1516 | - domain-name-servers | 
|  | 1517 | - domain-search | 
|  | 1518 | - host-name | 
|  | 1519 | - dhcp6.name-servers | 
|  | 1520 | - dhcp6.domain-search | 
|  | 1521 | - dhcp6.fqdn | 
|  | 1522 | - dhcp6.sntp-servers | 
|  | 1523 | - netbios-name-servers | 
|  | 1524 | - netbios-scope | 
|  | 1525 | - interface-mtu | 
|  | 1526 | - rfc3442-classless-static-routes | 
|  | 1527 | - ntp-servers | 
|  | 1528 | require: | 
|  | 1529 | - subnet-mask | 
|  | 1530 | - domain-name-servers | 
|  | 1531 | # if per interface configuration required add below | 
|  | 1532 | interface: | 
|  | 1533 | ens2: | 
|  | 1534 | initial_interval: 11 | 
|  | 1535 | reject: | 
|  | 1536 | - 192.33.137.210 | 
|  | 1537 | ens3: | 
|  | 1538 | initial_interval: 12 | 
|  | 1539 | reject: | 
|  | 1540 | - 192.33.137.211 | 
|  | 1541 |  | 
| Petr Michalec | eb14b55 | 2017-06-01 10:27:05 +0200 | [diff] [blame] | 1542 | Linux network systemd settings: | 
|  | 1543 |  | 
|  | 1544 | .. code-block:: yaml | 
|  | 1545 |  | 
|  | 1546 | linux: | 
|  | 1547 | network: | 
|  | 1548 | ... | 
|  | 1549 | systemd: | 
|  | 1550 | link: | 
|  | 1551 | 10-iface-dmz: | 
|  | 1552 | Match: | 
|  | 1553 | MACAddress: c8:5b:67:fa:1a:af | 
|  | 1554 | OriginalName: eth0 | 
|  | 1555 | Link: | 
|  | 1556 | Name: dmz0 | 
|  | 1557 | netdev: | 
|  | 1558 | 20-bridge-dmz: | 
|  | 1559 | match: | 
|  | 1560 | name: dmz0 | 
|  | 1561 | network: | 
|  | 1562 | mescription: bridge | 
|  | 1563 | bridge: br-dmz0 | 
|  | 1564 | network: | 
|  | 1565 | # works with lowercase, keys are by default capitalized | 
|  | 1566 | 40-dhcp: | 
|  | 1567 | match: | 
|  | 1568 | name: '*' | 
|  | 1569 | network: | 
|  | 1570 | DHCP: yes | 
|  | 1571 |  | 
| Petr Michalec | 10462bb | 2017-03-23 19:18:08 +0100 | [diff] [blame] | 1572 | Configure global environment variables | 
| Petr Michalec | 10462bb | 2017-03-23 19:18:08 +0100 | [diff] [blame] | 1573 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1574 | Use ``/etc/environment`` for static system wide variable assignment | 
|  | 1575 | after boot. Variable expansion is frequently not supported. | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1576 |  | 
|  | 1577 | .. code-block:: yaml | 
|  | 1578 |  | 
|  | 1579 | linux: | 
| Petr Michalec | 10462bb | 2017-03-23 19:18:08 +0100 | [diff] [blame] | 1580 | system: | 
|  | 1581 | env: | 
|  | 1582 | BOB_VARIABLE: Alice | 
|  | 1583 | ... | 
|  | 1584 | BOB_PATH: | 
|  | 1585 | - /srv/alice/bin | 
|  | 1586 | - /srv/bob/bin | 
|  | 1587 | ... | 
|  | 1588 | ftp_proxy:   none | 
|  | 1589 | http_proxy:  http://global-http-proxy.host.local:8080 | 
|  | 1590 | https_proxy: ${linux:system:proxy:https} | 
|  | 1591 | no_proxy: | 
|  | 1592 | - 192.168.0.80 | 
|  | 1593 | - 192.168.1.80 | 
|  | 1594 | - .domain.com | 
|  | 1595 | - .local | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1596 | ... | 
| Petr Michalec | 10462bb | 2017-03-23 19:18:08 +0100 | [diff] [blame] | 1597 | # NOTE: global defaults proxy configuration. | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1598 | proxy: | 
| Petr Michalec | 10462bb | 2017-03-23 19:18:08 +0100 | [diff] [blame] | 1599 | ftp:   ftp://proxy.host.local:2121 | 
|  | 1600 | http:  http://proxy.host.local:3142 | 
|  | 1601 | https: https://proxy.host.local:3143 | 
|  | 1602 | noproxy: | 
|  | 1603 | - .domain.com | 
|  | 1604 | - .local | 
|  | 1605 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1606 | Configure the ``profile.d`` scripts | 
| Petr Michalec | 10462bb | 2017-03-23 19:18:08 +0100 | [diff] [blame] | 1607 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1608 | The ``profile.d`` scripts are being sourced during ``.sh`` execution | 
|  | 1609 | and support variable expansion in opposite to /etc/environment global | 
|  | 1610 | settings in ``/etc/environment``. | 
| Petr Michalec | 10462bb | 2017-03-23 19:18:08 +0100 | [diff] [blame] | 1611 |  | 
|  | 1612 | .. code-block:: yaml | 
|  | 1613 |  | 
|  | 1614 | linux: | 
|  | 1615 | system: | 
|  | 1616 | profile: | 
|  | 1617 | locales: | | 
|  | 1618 | export LANG=C | 
|  | 1619 | export LC_ALL=C | 
|  | 1620 | ... | 
|  | 1621 | vi_flavors.sh: | | 
|  | 1622 | export PAGER=view | 
|  | 1623 | export EDITOR=vim | 
|  | 1624 | alias vi=vim | 
|  | 1625 | shell_locales.sh: | | 
|  | 1626 | export LANG=en_US | 
|  | 1627 | export LC_ALL=en_US.UTF-8 | 
|  | 1628 | shell_proxies.sh: | | 
|  | 1629 | export FTP_PROXY=ftp://127.0.3.3:2121 | 
|  | 1630 | export NO_PROXY='.local' | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1631 |  | 
| Dmitry Teselkin | a0d31d1 | 2018-09-04 14:43:09 +0300 | [diff] [blame^] | 1632 |  | 
|  | 1633 | Configure login.defs parameters | 
|  | 1634 | ------------------------------- | 
|  | 1635 |  | 
|  | 1636 | .. code-block:: yaml | 
|  | 1637 |  | 
|  | 1638 | linux: | 
|  | 1639 | system: | 
|  | 1640 | login_defs: | 
|  | 1641 | <opt_name>: | 
|  | 1642 | enabled: true | 
|  | 1643 | value: <opt_value> | 
|  | 1644 |  | 
|  | 1645 | <opt_name> is a configurational option defined in 'man login.defs'. | 
|  | 1646 | <opt_name> is case sensitive, should be UPPERCASE only! | 
|  | 1647 |  | 
|  | 1648 |  | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1649 | Linux with hosts | 
|  | 1650 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1651 | Parameter ``purge_hosts`` will enforce whole ``/etc/hosts file``, | 
|  | 1652 | removing entries that are not defined in model except defaults | 
|  | 1653 | for both IPv4 and IPv6 localhost and hostname as well as FQDN. | 
| Ales Komarek | 417e8c5 | 2017-08-25 15:10:29 +0200 | [diff] [blame] | 1654 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1655 | We recommend using this option to verify that ``/etc/hosts`` | 
|  | 1656 | is always in a clean state. However it is not enabled by default | 
|  | 1657 | for security reasons. | 
| Filip Pytloun | 86506fe | 2017-01-26 14:36:16 +0100 | [diff] [blame] | 1658 |  | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1659 | .. code-block:: yaml | 
|  | 1660 |  | 
|  | 1661 | linux: | 
|  | 1662 | network: | 
| Filip Pytloun | 86506fe | 2017-01-26 14:36:16 +0100 | [diff] [blame] | 1663 | purge_hosts: true | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1664 | host: | 
| Filip Pytloun | 86506fe | 2017-01-26 14:36:16 +0100 | [diff] [blame] | 1665 | # No need to define this one if purge_hosts is true | 
|  | 1666 | hostname: | 
|  | 1667 | address: 127.0.1.1 | 
|  | 1668 | names: | 
|  | 1669 | - ${linux:network:fqdn} | 
|  | 1670 | - ${linux:network:hostname} | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1671 | node1: | 
|  | 1672 | address: 192.168.10.200 | 
|  | 1673 | names: | 
|  | 1674 | - node2.domain.com | 
|  | 1675 | - service2.domain.com | 
|  | 1676 | node2: | 
|  | 1677 | address: 192.168.10.201 | 
|  | 1678 | names: | 
|  | 1679 | - node2.domain.com | 
|  | 1680 | - service2.domain.com | 
|  | 1681 |  | 
| Ales Komarek | 417e8c5 | 2017-08-25 15:10:29 +0200 | [diff] [blame] | 1682 | Linux with hosts collected from mine | 
|  | 1683 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1684 | All DNS records defined within infrastrucuture | 
|  | 1685 | are passed to the local hosts records or any DNS server. Only | 
|  | 1686 | hosts with the ``grain`` parameter set to ``true`` will be propagated | 
|  | 1687 | to the mine. | 
| Ales Komarek | 417e8c5 | 2017-08-25 15:10:29 +0200 | [diff] [blame] | 1688 |  | 
|  | 1689 | .. code-block:: yaml | 
|  | 1690 |  | 
|  | 1691 | linux: | 
|  | 1692 | network: | 
|  | 1693 | purge_hosts: true | 
|  | 1694 | mine_dns_records: true | 
|  | 1695 | host: | 
|  | 1696 | node1: | 
|  | 1697 | address: 192.168.10.200 | 
|  | 1698 | grain: true | 
|  | 1699 | names: | 
|  | 1700 | - node2.domain.com | 
|  | 1701 | - service2.domain.com | 
| Filip Pytloun | 86506fe | 2017-01-26 14:36:16 +0100 | [diff] [blame] | 1702 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1703 | Set up ``resolv.conf``, nameservers, domain and search domains: | 
| Filip Pytloun | de9bea5 | 2016-01-11 15:39:10 +0100 | [diff] [blame] | 1704 |  | 
|  | 1705 | .. code-block:: yaml | 
|  | 1706 |  | 
|  | 1707 | linux: | 
|  | 1708 | network: | 
|  | 1709 | resolv: | 
|  | 1710 | dns: | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1711 | - 8.8.4.4 | 
|  | 1712 | - 8.8.8.8 | 
| Filip Pytloun | de9bea5 | 2016-01-11 15:39:10 +0100 | [diff] [blame] | 1713 | domain: my.example.com | 
|  | 1714 | search: | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1715 | - my.example.com | 
|  | 1716 | - example.com | 
| Marek Celoud | f6cd192 | 2016-12-05 13:39:49 +0100 | [diff] [blame] | 1717 | options: | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1718 | - ndots: 5 | 
|  | 1719 | - timeout: 2 | 
|  | 1720 | - attempts: 2 | 
| Filip Pytloun | de9bea5 | 2016-01-11 15:39:10 +0100 | [diff] [blame] | 1721 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1722 | Set up custom TX queue length for tap interfaces: | 
| Andrii Petrenko | 735761d | 2017-03-21 17:17:35 -0700 | [diff] [blame] | 1723 |  | 
|  | 1724 | .. code-block:: yaml | 
|  | 1725 |  | 
|  | 1726 | linux: | 
|  | 1727 | network: | 
|  | 1728 | tap_custom_txqueuelen: 10000 | 
|  | 1729 |  | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1730 | DPDK OVS interfaces | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1731 |  | 
|  | 1732 | **DPDK OVS NIC** | 
|  | 1733 |  | 
|  | 1734 | .. code-block:: yaml | 
|  | 1735 |  | 
|  | 1736 | linux: | 
|  | 1737 | network: | 
|  | 1738 | bridge: openvswitch | 
|  | 1739 | dpdk: | 
|  | 1740 | enabled: true | 
| Oleg Bondarev | 9a46679 | 2017-05-25 15:55:42 +0400 | [diff] [blame] | 1741 | driver: uio/vfio | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1742 | openvswitch: | 
|  | 1743 | pmd_cpu_mask: "0x6" | 
|  | 1744 | dpdk_socket_mem: "1024,1024" | 
|  | 1745 | dpdk_lcore_mask: "0x400" | 
|  | 1746 | memory_channels: 2 | 
|  | 1747 | interface: | 
|  | 1748 | dpkd0: | 
|  | 1749 | name: ${_param:dpdk_nic} | 
|  | 1750 | pci: 0000:06:00.0 | 
| Oleg Bondarev | 9a46679 | 2017-05-25 15:55:42 +0400 | [diff] [blame] | 1751 | driver: igb_uio/vfio-pci | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1752 | enabled: true | 
|  | 1753 | type: dpdk_ovs_port | 
|  | 1754 | n_rxq: 2 | 
| Oleg Bondarev | 43dbbd3 | 2017-05-24 17:06:19 +0400 | [diff] [blame] | 1755 | pmd_rxq_affinity: "0:1,1:2" | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1756 | bridge: br-prv | 
| Jakub Pavlik | aa75906 | 2017-03-13 15:57:26 +0100 | [diff] [blame] | 1757 | mtu: 9000 | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1758 | br-prv: | 
|  | 1759 | enabled: true | 
|  | 1760 | type: dpdk_ovs_bridge | 
|  | 1761 |  | 
|  | 1762 | **DPDK OVS Bond** | 
|  | 1763 |  | 
|  | 1764 | .. code-block:: yaml | 
|  | 1765 |  | 
|  | 1766 | linux: | 
|  | 1767 | network: | 
|  | 1768 | bridge: openvswitch | 
|  | 1769 | dpdk: | 
|  | 1770 | enabled: true | 
| Oleg Bondarev | 9a46679 | 2017-05-25 15:55:42 +0400 | [diff] [blame] | 1771 | driver: uio/vfio | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1772 | openvswitch: | 
|  | 1773 | pmd_cpu_mask: "0x6" | 
|  | 1774 | dpdk_socket_mem: "1024,1024" | 
|  | 1775 | dpdk_lcore_mask: "0x400" | 
|  | 1776 | memory_channels: 2 | 
|  | 1777 | interface: | 
|  | 1778 | dpdk_second_nic: | 
|  | 1779 | name: ${_param:primary_second_nic} | 
|  | 1780 | pci: 0000:06:00.0 | 
| Oleg Bondarev | 9a46679 | 2017-05-25 15:55:42 +0400 | [diff] [blame] | 1781 | driver: igb_uio/vfio-pci | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1782 | bond: dpdkbond0 | 
|  | 1783 | enabled: true | 
|  | 1784 | type: dpdk_ovs_port | 
|  | 1785 | n_rxq: 2 | 
| Oleg Bondarev | 43dbbd3 | 2017-05-24 17:06:19 +0400 | [diff] [blame] | 1786 | pmd_rxq_affinity: "0:1,1:2" | 
| Jakub Pavlik | aa75906 | 2017-03-13 15:57:26 +0100 | [diff] [blame] | 1787 | mtu: 9000 | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1788 | dpdk_first_nic: | 
|  | 1789 | name: ${_param:primary_first_nic} | 
|  | 1790 | pci: 0000:05:00.0 | 
| Oleg Bondarev | 9a46679 | 2017-05-25 15:55:42 +0400 | [diff] [blame] | 1791 | driver: igb_uio/vfio-pci | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1792 | bond: dpdkbond0 | 
|  | 1793 | enabled: true | 
|  | 1794 | type: dpdk_ovs_port | 
|  | 1795 | n_rxq: 2 | 
| Oleg Bondarev | 43dbbd3 | 2017-05-24 17:06:19 +0400 | [diff] [blame] | 1796 | pmd_rxq_affinity: "0:1,1:2" | 
| Jakub Pavlik | aa75906 | 2017-03-13 15:57:26 +0100 | [diff] [blame] | 1797 | mtu: 9000 | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1798 | dpdkbond0: | 
|  | 1799 | enabled: true | 
|  | 1800 | bridge: br-prv | 
|  | 1801 | type: dpdk_ovs_bond | 
|  | 1802 | mode: active-backup | 
|  | 1803 | br-prv: | 
|  | 1804 | enabled: true | 
|  | 1805 | type: dpdk_ovs_bridge | 
|  | 1806 |  | 
| Dzmitry Stremkouski | f619b07 | 2018-03-15 20:13:42 +0100 | [diff] [blame] | 1807 | **DPDK OVS LACP Bond with vlan tag** | 
|  | 1808 |  | 
|  | 1809 | .. code-block:: yaml | 
|  | 1810 |  | 
|  | 1811 | linux: | 
|  | 1812 | network: | 
|  | 1813 | bridge: openvswitch | 
|  | 1814 | dpdk: | 
|  | 1815 | enabled: true | 
|  | 1816 | driver: uio | 
|  | 1817 | openvswitch: | 
|  | 1818 | pmd_cpu_mask: "0x6" | 
|  | 1819 | dpdk_socket_mem: "1024,1024" | 
|  | 1820 | dpdk_lcore_mask: "0x400" | 
|  | 1821 | memory_channels: "2" | 
|  | 1822 | interface: | 
|  | 1823 | eth3: | 
|  | 1824 | enabled: true | 
|  | 1825 | type: eth | 
|  | 1826 | proto: manual | 
|  | 1827 | name: ${_param:tenant_first_nic} | 
|  | 1828 | eth4: | 
|  | 1829 | enabled: true | 
|  | 1830 | type: eth | 
|  | 1831 | proto: manual | 
|  | 1832 | name: ${_param:tenant_second_nic} | 
|  | 1833 | dpdk0: | 
|  | 1834 | name: ${_param:tenant_first_nic} | 
|  | 1835 | pci: "0000:81:00.0" | 
|  | 1836 | driver: igb_uio | 
|  | 1837 | bond: bond1 | 
|  | 1838 | enabled: true | 
|  | 1839 | type: dpdk_ovs_port | 
|  | 1840 | n_rxq: 2 | 
|  | 1841 | dpdk1: | 
|  | 1842 | name: ${_param:tenant_second_nic} | 
|  | 1843 | pci: "0000:81:00.1" | 
|  | 1844 | driver: igb_uio | 
|  | 1845 | bond: bond1 | 
|  | 1846 | enabled: true | 
|  | 1847 | type: dpdk_ovs_port | 
|  | 1848 | n_rxq: 2 | 
|  | 1849 | bond1: | 
|  | 1850 | enabled: true | 
|  | 1851 | bridge: br-prv | 
|  | 1852 | type: dpdk_ovs_bond | 
|  | 1853 | mode: balance-slb | 
|  | 1854 | br-prv: | 
|  | 1855 | enabled: true | 
|  | 1856 | type: dpdk_ovs_bridge | 
|  | 1857 | tag: ${_param:tenant_vlan} | 
|  | 1858 | address: ${_param:tenant_address} | 
|  | 1859 | netmask: ${_param:tenant_network_netmask} | 
|  | 1860 |  | 
| Jakub Pavlik | aa75906 | 2017-03-13 15:57:26 +0100 | [diff] [blame] | 1861 | **DPDK OVS bridge for VXLAN** | 
|  | 1862 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1863 | If VXLAN is used as tenant segmentation, IP address must | 
|  | 1864 | be set on ``br-prv``. | 
| Jakub Pavlik | aa75906 | 2017-03-13 15:57:26 +0100 | [diff] [blame] | 1865 |  | 
|  | 1866 | .. code-block:: yaml | 
|  | 1867 |  | 
|  | 1868 | linux: | 
|  | 1869 | network: | 
|  | 1870 | ... | 
|  | 1871 | interface: | 
|  | 1872 | br-prv: | 
|  | 1873 | enabled: true | 
|  | 1874 | type: dpdk_ovs_bridge | 
|  | 1875 | address: 192.168.50.0 | 
|  | 1876 | netmask: 255.255.255.0 | 
| Michael Polenchuk | d173d55 | 2018-01-22 15:22:47 +0400 | [diff] [blame] | 1877 | tag: 101 | 
| Jakub Pavlik | aa75906 | 2017-03-13 15:57:26 +0100 | [diff] [blame] | 1878 | mtu: 9000 | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1879 |  | 
| Oleksii Chupryn | e2151ff | 2018-03-13 16:01:12 +0200 | [diff] [blame] | 1880 | **DPDK OVS bridge with Linux network interface** | 
|  | 1881 |  | 
|  | 1882 | .. code-block:: yaml | 
|  | 1883 |  | 
|  | 1884 | linux: | 
|  | 1885 | network: | 
|  | 1886 | ... | 
|  | 1887 | interface: | 
|  | 1888 | eth0: | 
|  | 1889 | type: eth | 
|  | 1890 | ovs_bridge: br-prv | 
|  | 1891 | ... | 
|  | 1892 | br-prv: | 
|  | 1893 | enabled: true | 
|  | 1894 | type: dpdk_ovs_bridge | 
|  | 1895 | ... | 
|  | 1896 |  | 
| Jakub Pavlik | 21ca215 | 2017-02-27 22:21:09 +0100 | [diff] [blame] | 1897 | Linux storage | 
|  | 1898 | ------------- | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1899 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1900 | Linux with mounted Samba: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1901 |  | 
|  | 1902 | .. code-block:: yaml | 
|  | 1903 |  | 
|  | 1904 | linux: | 
|  | 1905 | storage: | 
|  | 1906 | enabled: true | 
|  | 1907 | mount: | 
|  | 1908 | samba1: | 
| Simon Pasquier | 376262a | 2016-11-16 15:21:51 +0100 | [diff] [blame] | 1909 | - enabled: true | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1910 | - path: /media/myuser/public/ | 
|  | 1911 | - device: //192.168.0.1/storage | 
|  | 1912 | - file_system: cifs | 
|  | 1913 | - options: guest,uid=myuser,iocharset=utf8,file_mode=0777,dir_mode=0777,noperm | 
|  | 1914 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1915 | NFS mount: | 
| Jiri Broulik | b017f93 | 2017-03-31 13:55:36 +0200 | [diff] [blame] | 1916 |  | 
|  | 1917 | .. code-block:: yaml | 
|  | 1918 |  | 
|  | 1919 | linux: | 
|  | 1920 | storage: | 
|  | 1921 | enabled: true | 
|  | 1922 | mount: | 
|  | 1923 | nfs_glance: | 
|  | 1924 | enabled: true | 
|  | 1925 | path: /var/lib/glance/images | 
|  | 1926 | device: 172.16.10.110:/var/nfs/glance | 
|  | 1927 | file_system: nfs | 
|  | 1928 | opts: rw,sync | 
|  | 1929 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1930 | File swap configuration: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 1931 |  | 
|  | 1932 | .. code-block:: yaml | 
|  | 1933 |  | 
|  | 1934 | linux: | 
|  | 1935 | storage: | 
|  | 1936 | enabled: true | 
|  | 1937 | swap: | 
|  | 1938 | file: | 
|  | 1939 | enabled: true | 
|  | 1940 | engine: file | 
|  | 1941 | device: /swapfile | 
|  | 1942 | size: 1024 | 
|  | 1943 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1944 | Partition swap configuration: | 
| Lachlan Evenson | 3067651 | 2016-01-22 15:43:28 -0800 | [diff] [blame] | 1945 |  | 
|  | 1946 | .. code-block:: yaml | 
|  | 1947 |  | 
|  | 1948 | linux: | 
|  | 1949 | storage: | 
|  | 1950 | enabled: true | 
|  | 1951 | swap: | 
|  | 1952 | partition: | 
|  | 1953 | enabled: true | 
|  | 1954 | engine: partition | 
|  | 1955 | device: /dev/vg0/swap | 
|  | 1956 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1957 | LVM group ``vg1`` with one device and ``data`` volume mounted | 
|  | 1958 | into ``/mnt/data``. | 
| Filip Pytloun | c8a001a | 2015-12-15 14:09:19 +0100 | [diff] [blame] | 1959 |  | 
|  | 1960 | .. code-block:: yaml | 
|  | 1961 |  | 
|  | 1962 | parameters: | 
|  | 1963 | linux: | 
|  | 1964 | storage: | 
|  | 1965 | mount: | 
|  | 1966 | data: | 
| Simon Pasquier | 376262a | 2016-11-16 15:21:51 +0100 | [diff] [blame] | 1967 | enabled: true | 
| Filip Pytloun | c8a001a | 2015-12-15 14:09:19 +0100 | [diff] [blame] | 1968 | device: /dev/vg1/data | 
|  | 1969 | file_system: ext4 | 
|  | 1970 | path: /mnt/data | 
|  | 1971 | lvm: | 
|  | 1972 | vg1: | 
|  | 1973 | enabled: true | 
|  | 1974 | devices: | 
|  | 1975 | - /dev/sdb | 
|  | 1976 | volume: | 
|  | 1977 | data: | 
|  | 1978 | size: 40G | 
|  | 1979 | mount: ${linux:storage:mount:data} | 
|  | 1980 |  | 
| Jakub Pavlik | 4f74214 | 2017-08-08 15:05:50 +0200 | [diff] [blame] | 1981 | Create partitions on disk. Specify size in MB. It expects empty | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 1982 | disk without any existing partitions. | 
|  | 1983 | Set ``startsector=1`` if you want to start partitions from ``2048``. | 
| Jakub Pavlik | 4f74214 | 2017-08-08 15:05:50 +0200 | [diff] [blame] | 1984 |  | 
|  | 1985 | .. code-block:: yaml | 
|  | 1986 |  | 
|  | 1987 | linux: | 
|  | 1988 | storage: | 
|  | 1989 | disk: | 
|  | 1990 | first_drive: | 
| Piotr Kruk | d51911b | 2017-12-04 11:27:08 +0100 | [diff] [blame] | 1991 | startsector: 1 | 
| Jakub Pavlik | 4f74214 | 2017-08-08 15:05:50 +0200 | [diff] [blame] | 1992 | name: /dev/loop1 | 
|  | 1993 | type: gpt | 
|  | 1994 | partitions: | 
|  | 1995 | - size: 200 #size in MB | 
|  | 1996 | type: fat32 | 
|  | 1997 | - size: 300 #size in MB | 
| Jakub Pavlik | 8e2140a | 2017-08-14 23:29:57 +0200 | [diff] [blame] | 1998 | mkfs: True | 
|  | 1999 | type: xfs | 
| Jakub Pavlik | 4f74214 | 2017-08-08 15:05:50 +0200 | [diff] [blame] | 2000 | /dev/vda1: | 
|  | 2001 | partitions: | 
|  | 2002 | - size: 5 | 
|  | 2003 | type: ext2 | 
|  | 2004 | - size: 10 | 
|  | 2005 | type: ext4 | 
| Ales Komarek | a634f4b | 2016-10-02 13:11:04 +0200 | [diff] [blame] | 2006 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2007 | Multipath with Fujitsu Eternus DXL: | 
| Ales Komarek | a634f4b | 2016-10-02 13:11:04 +0200 | [diff] [blame] | 2008 |  | 
|  | 2009 | .. code-block:: yaml | 
|  | 2010 |  | 
|  | 2011 | parameters: | 
|  | 2012 | linux: | 
|  | 2013 | storage: | 
|  | 2014 | multipath: | 
|  | 2015 | enabled: true | 
|  | 2016 | blacklist_devices: | 
|  | 2017 | - /dev/sda | 
|  | 2018 | - /dev/sdb | 
|  | 2019 | backends: | 
|  | 2020 | - fujitsu_eternus_dxl | 
|  | 2021 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2022 | Multipath with Hitachi VSP 1000: | 
| Ales Komarek | a634f4b | 2016-10-02 13:11:04 +0200 | [diff] [blame] | 2023 |  | 
|  | 2024 | .. code-block:: yaml | 
|  | 2025 |  | 
|  | 2026 | parameters: | 
|  | 2027 | linux: | 
|  | 2028 | storage: | 
|  | 2029 | multipath: | 
|  | 2030 | enabled: true | 
|  | 2031 | blacklist_devices: | 
|  | 2032 | - /dev/sda | 
|  | 2033 | - /dev/sdb | 
|  | 2034 | backends: | 
|  | 2035 | - hitachi_vsp1000 | 
|  | 2036 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2037 | Multipath with IBM Storwize: | 
| Ales Komarek | a634f4b | 2016-10-02 13:11:04 +0200 | [diff] [blame] | 2038 |  | 
|  | 2039 | .. code-block:: yaml | 
|  | 2040 |  | 
|  | 2041 | parameters: | 
|  | 2042 | linux: | 
|  | 2043 | storage: | 
|  | 2044 | multipath: | 
|  | 2045 | enabled: true | 
|  | 2046 | blacklist_devices: | 
|  | 2047 | - /dev/sda | 
|  | 2048 | - /dev/sdb | 
|  | 2049 | backends: | 
|  | 2050 | - ibm_storwize | 
|  | 2051 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2052 | Multipath with multiple backends: | 
| Ales Komarek | a634f4b | 2016-10-02 13:11:04 +0200 | [diff] [blame] | 2053 |  | 
|  | 2054 | .. code-block:: yaml | 
|  | 2055 |  | 
|  | 2056 | parameters: | 
|  | 2057 | linux: | 
|  | 2058 | storage: | 
|  | 2059 | multipath: | 
|  | 2060 | enabled: true | 
|  | 2061 | blacklist_devices: | 
|  | 2062 | - /dev/sda | 
|  | 2063 | - /dev/sdb | 
|  | 2064 | - /dev/sdc | 
|  | 2065 | - /dev/sdd | 
|  | 2066 | backends: | 
|  | 2067 | - ibm_storwize | 
|  | 2068 | - fujitsu_eternus_dxl | 
|  | 2069 | - hitachi_vsp1000 | 
|  | 2070 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2071 | PAM LDAP integration: | 
| Dmitry Stremkouski | 7d8d67a | 2017-11-15 13:08:19 +0300 | [diff] [blame] | 2072 |  | 
|  | 2073 | .. code-block:: yaml | 
|  | 2074 |  | 
|  | 2075 | parameters: | 
|  | 2076 | linux: | 
|  | 2077 | system: | 
|  | 2078 | auth: | 
|  | 2079 | enabled: true | 
| Dzmitry Stremkouski | 602735d | 2018-05-09 22:31:39 +0200 | [diff] [blame] | 2080 | mkhomedir: | 
|  | 2081 | enabled: true | 
|  | 2082 | umask: 0027 | 
| Dmitry Stremkouski | 7d8d67a | 2017-11-15 13:08:19 +0300 | [diff] [blame] | 2083 | ldap: | 
|  | 2084 | enabled: true | 
|  | 2085 | binddn: cn=bind,ou=service_users,dc=example,dc=com | 
|  | 2086 | bindpw: secret | 
|  | 2087 | uri: ldap://127.0.0.1 | 
|  | 2088 | base: ou=users,dc=example,dc=com | 
|  | 2089 | ldap_version: 3 | 
|  | 2090 | pagesize: 65536 | 
|  | 2091 | referrals: off | 
|  | 2092 | filter: | 
|  | 2093 | passwd: (&(&(objectClass=person)(uidNumber=*))(unixHomeDirectory=*)) | 
|  | 2094 | shadow: (&(&(objectClass=person)(uidNumber=*))(unixHomeDirectory=*)) | 
|  | 2095 | group:  (&(objectClass=group)(gidNumber=*)) | 
|  | 2096 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2097 | Disabled multipath (the default setup): | 
| Ales Komarek | a634f4b | 2016-10-02 13:11:04 +0200 | [diff] [blame] | 2098 |  | 
|  | 2099 | .. code-block:: yaml | 
|  | 2100 |  | 
|  | 2101 | parameters: | 
|  | 2102 | linux: | 
|  | 2103 | storage: | 
|  | 2104 | multipath: | 
|  | 2105 | enabled: false | 
|  | 2106 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2107 | Linux with local loopback device: | 
| Simon Pasquier | 375001e | 2017-01-26 13:22:33 +0100 | [diff] [blame] | 2108 |  | 
|  | 2109 | .. code-block:: yaml | 
|  | 2110 |  | 
|  | 2111 | linux: | 
|  | 2112 | storage: | 
|  | 2113 | loopback: | 
|  | 2114 | disk1: | 
|  | 2115 | file: /srv/disk1 | 
|  | 2116 | size: 50G | 
|  | 2117 |  | 
| Filip Pytloun | b2c8f85 | 2016-11-21 17:03:43 +0100 | [diff] [blame] | 2118 | External config generation | 
|  | 2119 | -------------------------- | 
|  | 2120 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2121 | You are able to use config support metadata between formulas | 
|  | 2122 | and only generate configuration files for external use, for example, Docker, and so on. | 
| Filip Pytloun | b2c8f85 | 2016-11-21 17:03:43 +0100 | [diff] [blame] | 2123 |  | 
|  | 2124 | .. code-block:: yaml | 
|  | 2125 |  | 
|  | 2126 | parameters: | 
|  | 2127 | linux: | 
|  | 2128 | system: | 
|  | 2129 | config: | 
|  | 2130 | pillar: | 
|  | 2131 | jenkins: | 
|  | 2132 | master: | 
|  | 2133 | home: /srv/volumes/jenkins | 
|  | 2134 | approved_scripts: | 
|  | 2135 | - method java.net.URL openConnection | 
|  | 2136 | credentials: | 
|  | 2137 | - type: username_password | 
|  | 2138 | scope: global | 
|  | 2139 | id: test | 
|  | 2140 | desc: Testing credentials | 
|  | 2141 | username: test | 
|  | 2142 | password: test | 
|  | 2143 |  | 
| Vladimir Eremin | ccf2884 | 2017-04-10 23:52:10 +0300 | [diff] [blame] | 2144 | Netconsole Remote Kernel Logging | 
|  | 2145 | -------------------------------- | 
|  | 2146 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2147 | Netconsole logger can be configured for the configfs-enabled kernels | 
|  | 2148 | (``CONFIG_NETCONSOLE_DYNAMIC`` must be enabled). The configuration | 
|  | 2149 | applies both in runtime (if network is already configured), | 
|  | 2150 | and on-boot after an interface initialization. | 
| Vladimir Eremin | ccf2884 | 2017-04-10 23:52:10 +0300 | [diff] [blame] | 2151 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2152 | .. note:: | 
|  | 2153 |  | 
|  | 2154 | * Receiver can be located only on the same L3 domain | 
|  | 2155 | (or you need to configure gateway MAC manually). | 
|  | 2156 | * The Receiver MAC is detected only on configuration time. | 
|  | 2157 | * Using broadcast MAC is not recommended. | 
| Vladimir Eremin | ccf2884 | 2017-04-10 23:52:10 +0300 | [diff] [blame] | 2158 |  | 
|  | 2159 | .. code-block:: yaml | 
|  | 2160 |  | 
|  | 2161 | parameters: | 
|  | 2162 | linux: | 
|  | 2163 | system: | 
|  | 2164 | netconsole: | 
|  | 2165 | enabled: true | 
|  | 2166 | port: 514 (optional) | 
|  | 2167 | loglevel: debug (optional) | 
|  | 2168 | target: | 
|  | 2169 | 192.168.0.1: | 
|  | 2170 | interface: bond0 | 
|  | 2171 | mac: "ff:ff:ff:ff:ff:ff" (optional) | 
| Ales Komarek | a634f4b | 2016-10-02 13:11:04 +0200 | [diff] [blame] | 2172 |  | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 2173 | Usage | 
|  | 2174 | ===== | 
|  | 2175 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2176 | Set MTU of the eth0 network interface to 1400: | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 2177 |  | 
|  | 2178 | .. code-block:: bash | 
|  | 2179 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2180 | ip link set dev eth0 mtu 1400 | 
| Filip Pytloun | f5383a4 | 2015-10-06 16:28:32 +0200 | [diff] [blame] | 2181 |  | 
|  | 2182 | Read more | 
|  | 2183 | ========= | 
|  | 2184 |  | 
|  | 2185 | * https://www.archlinux.org/ | 
|  | 2186 | * http://askubuntu.com/questions/175172/how-do-i-configure-proxies-in-ubuntu-server-or-minimal-cli-ubuntu | 
| Filip Pytloun | 018f871 | 2017-02-02 13:02:03 +0100 | [diff] [blame] | 2187 |  | 
|  | 2188 | Documentation and Bugs | 
|  | 2189 | ====================== | 
|  | 2190 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2191 | * http://salt-formulas.readthedocs.io/ | 
|  | 2192 | Learn how to install and update salt-formulas. | 
| Filip Pytloun | 018f871 | 2017-02-02 13:02:03 +0100 | [diff] [blame] | 2193 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2194 | * https://github.com/salt-formulas/salt-formula-linux/issues | 
|  | 2195 | In the unfortunate event that bugs are discovered, report the issue to the | 
|  | 2196 | appropriate issue tracker. Use the Github issue tracker for a specific salt | 
|  | 2197 | formula. | 
| Filip Pytloun | 018f871 | 2017-02-02 13:02:03 +0100 | [diff] [blame] | 2198 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2199 | * https://launchpad.net/salt-formulas | 
|  | 2200 | For feature requests, bug reports, or blueprints affecting the entire | 
|  | 2201 | ecosystem, use the Launchpad salt-formulas project. | 
| Filip Pytloun | 018f871 | 2017-02-02 13:02:03 +0100 | [diff] [blame] | 2202 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2203 | * https://launchpad.net/~salt-formulas-users | 
|  | 2204 | Join the salt-formulas-users team and subscribe to mailing list if required. | 
| Filip Pytloun | 018f871 | 2017-02-02 13:02:03 +0100 | [diff] [blame] | 2205 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2206 | * https://github.com/salt-formulas/salt-formula-linux | 
|  | 2207 | Develop the salt-formulas projects in the master branch and then submit pull | 
|  | 2208 | requests against a specific formula. | 
| Filip Pytloun | 018f871 | 2017-02-02 13:02:03 +0100 | [diff] [blame] | 2209 |  | 
| OlgaGusarenko | 2828f5f | 2018-07-30 19:37:05 +0300 | [diff] [blame] | 2210 | * #salt-formulas @ irc.freenode.net | 
|  | 2211 | Use this IRC channel in case of any questions or feedback which is always | 
|  | 2212 | welcome. | 
| Filip Pytloun | 018f871 | 2017-02-02 13:02:03 +0100 | [diff] [blame] | 2213 |  |