|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586 |
- ============
- Linux Fomula
- ============
-
- Linux Operating Systems:
-
- * Ubuntu
- * CentOS
- * RedHat
- * Fedora
- * Arch
-
- Sample Pillars
- ==============
-
- Linux System
- ------------
-
- Basic Linux box
-
- .. code-block:: yaml
-
- linux:
- system:
- enabled: true
- name: 'node1'
- domain: 'domain.com'
- cluster: 'system'
- environment: prod
- timezone: 'Europe/Prague'
- utc: true
-
- Linux with system users, some with password set:
-
- .. warning:: If no ``password`` variable is passed,
- any predifined password will be removed.
-
- .. code-block:: yaml
-
- linux:
- system:
- ...
- user:
- jdoe:
- name: 'jdoe'
- enabled: true
- sudo: true
- shell: /bin/bash
- full_name: 'Jonh Doe'
- home: '/home/jdoe'
- home_dir_mode: 755
- email: 'jonh@doe.com'
- unique: false
- jsmith:
- name: 'jsmith'
- enabled: true
- full_name: 'With clear password'
- home: '/home/jsmith'
- hash_password: true
- password: "userpassword"
- mark:
- name: 'mark'
- enabled: true
- full_name: "unchange password'
- home: '/home/mark'
- password: false
- elizabeth:
- name: 'elizabeth'
- enabled: true
- full_name: 'With hased password'
- home: '/home/elizabeth'
- password: "$6$nUI7QEz3$dFYjzQqK5cJ6HQ38KqG4gTWA9eJu3aKx6TRVDFh6BVJxJgFWg2akfAA7f1fCxcSUeOJ2arCO6EEI6XXnHXxG10"
-
- Configure password expiration parameters
- ----------------------------------------
- The following login.defs parameters can be overridden per-user:
-
- * PASS_MAX_DAYS
- * PASS_MIN_DAYS
- * PASS_WARN_DAYS
- * INACTIVE
-
- .. code-block:: yaml
-
- linux:
- system:
- ...
- user:
- jdoe:
- name: 'jdoe'
- enabled: true
- ...
- maxdays: <PASS_MAX_DAYS>
- mindays: <PASS_MIN_DAYS>
- warndays: <PASS_WARN_DAYS>
- inactdays: <INACTIVE>
-
- Configure sudo for users and groups under ``/etc/sudoers.d/``.
- This ways ``linux.system.sudo`` pillar map to actual sudo attributes:
-
- .. code-block:: jinja
-
- # simplified template:
- Cmds_Alias {{ alias }}={{ commands }}
- {{ user }} {{ hosts }}=({{ runas }}) NOPASSWD: {{ commands }}
- %{{ group }} {{ hosts }}=({{ runas }}) NOPASSWD: {{ commands }}
-
- # when rendered:
- saltuser1 ALL=(ALL) NOPASSWD: ALL
-
- .. code-block:: yaml
-
- linux:
- system:
- sudo:
- enabled: true
- aliases:
- host:
- LOCAL:
- - localhost
- PRODUCTION:
- - db1
- - db2
- runas:
- DBA:
- - postgres
- - mysql
- SALT:
- - root
- command:
- # Note: This is not 100% safe when ALL keyword is used, user still may modify configs and hide his actions.
- # Best practice is to specify full list of commands user is allowed to run.
- SUPPORT_RESTRICTED:
- - /bin/vi /etc/sudoers*
- - /bin/vim /etc/sudoers*
- - /bin/nano /etc/sudoers*
- - /bin/emacs /etc/sudoers*
- - /bin/su - root
- - /bin/su -
- - /bin/su
- - /usr/sbin/visudo
- SUPPORT_SHELLS:
- - /bin/sh
- - /bin/ksh
- - /bin/bash
- - /bin/rbash
- - /bin/dash
- - /bin/zsh
- - /bin/csh
- - /bin/fish
- - /bin/tcsh
- - /usr/bin/login
- - /usr/bin/su
- - /usr/su
- ALL_SALT_SAFE:
- - /usr/bin/salt state*
- - /usr/bin/salt service*
- - /usr/bin/salt pillar*
- - /usr/bin/salt grains*
- - /usr/bin/salt saltutil*
- - /usr/bin/salt-call state*
- - /usr/bin/salt-call service*
- - /usr/bin/salt-call pillar*
- - /usr/bin/salt-call grains*
- - /usr/bin/salt-call saltutil*
- SALT_TRUSTED:
- - /usr/bin/salt*
- users:
- # saltuser1 with default values: saltuser1 ALL=(ALL) NOPASSWD: ALL
- saltuser1: {}
- saltuser2:
- hosts:
- - LOCAL
- # User Alias DBA
- DBA:
- hosts:
- - ALL
- commands:
- - ALL_SALT_SAFE
- groups:
- db-ops:
- hosts:
- - ALL
- - '!PRODUCTION'
- runas:
- - DBA
- commands:
- - /bin/cat *
- - /bin/less *
- - /bin/ls *
- salt-ops:
- hosts:
- - 'ALL'
- runas:
- - SALT
- commands:
- - SUPPORT_SHELLS
- salt-ops-2nd:
- name: salt-ops
- nopasswd: false
- setenv: true # Enable sudo -E option
- runas:
- - DBA
- commands:
- - ALL
- - '!SUPPORT_SHELLS'
- - '!SUPPORT_RESTRICTED'
-
- Linux with package, latest version:
-
- .. code-block:: yaml
-
- linux:
- system:
- ...
- package:
- package-name:
- version: latest
-
- Linux with package from certail repo, version with no upgrades:
-
- .. code-block:: yaml
-
- linux:
- system:
- ...
- package:
- package-name:
- version: 2132.323
- repo: 'custom-repo'
- hold: true
-
- Linux with package from certail repo, version with no GPG
- verification:
-
- .. code-block:: yaml
-
- linux:
- system:
- ...
- package:
- package-name:
- version: 2132.323
- repo: 'custom-repo'
- verify: false
-
- Linux with autoupdates (automatically install security package
- updates):
-
- .. code-block:: yaml
-
- linux:
- system:
- ...
- autoupdates:
- enabled: true
- mail: root@localhost
- mail_only_on_error: true
- remove_unused_dependencies: false
- automatic_reboot: true
- automatic_reboot_time: "02:00"
-
- Managing cron tasks
- -------------------
-
- There are two data structures that are related to managing cron itself and
- cron tasks:
-
- .. code-block:: yaml
-
- linux:
- system:
- cron:
-
- and
-
- .. code-block:: yaml
-
- linux:
- system:
- job:
-
- `linux:system:cron` manages cron packages, services, and '/etc/cron.allow' file.
-
- 'deny' files are managed the only way - we're ensuring they are absent, that's
- a requirement from CIS 5.1.8
-
- 'cron' pillar structure is the following:
-
- .. code-block:: yaml
-
- linux:
- system:
- cron:
- enabled: true
- pkgs: [ <cron packages> ]
- services: [ <cron services> ]
- user:
- <username>:
- enabled: true
-
- To add user to '/etc/cron.allow' use 'enabled' key as shown above.
-
- '/etc/cron.deny' is not managed as CIS 5.1.8 requires it was removed.
-
- A user would be ignored if any of the following is true:
- * user is disabled in `linux:system:user:<username>`
- * user is disabled in `linux:system:cron:user:<username>`
-
- `linux:system:job` manages individual cron tasks.
-
- By default, it will use name as an identifier, unless identifier key is
- explicitly set or False (then it will use Salt's default behavior which is
- identifier same as command resulting in not being able to change it):
-
- .. code-block:: yaml
-
- linux:
- system:
- ...
- job:
- cmd1:
- command: '/cmd/to/run'
- identifier: cmd1
- enabled: true
- user: 'root'
- hour: 2
- minute: 0
-
- Managing 'at' tasks
- -------------------
-
- Pillar for managing `at` tasks is similar to one for `cron` tasks:
-
- .. code-block:: yaml
-
- linux:
- system:
- at:
- enabled: true
- pkgs: [ <at packages> ]
- services: [ <at services> ]
- user:
- <username>:
- enabled: true
-
- To add a user to '/etc/at.allow' use 'enabled' key as shown above.
-
- '/etc/at.deny' is not managed as CIS 5.1.8 requires it was removed.
-
- A user will be ignored if any of the following is true:
- * user is disabled in `linux:system:user:<username>`
- * user is disabled in `linux:system:at:user:<username>`
-
-
- Linux security limits (limit sensu user memory usage to max 1GB):
-
- .. code-block:: yaml
-
- linux:
- system:
- ...
- limit:
- sensu:
- enabled: true
- domain: sensu
- limits:
- - type: hard
- item: as
- value: 1000000
-
- Enable autologin on ``tty1`` (may work only for Ubuntu 14.04):
-
- .. code-block:: yaml
-
- linux:
- system:
- console:
- tty1:
- autologin: root
- # Enable serial console
- ttyS0:
- autologin: root
- rate: 115200
- term: xterm
-
- To disable set autologin to ``false``.
-
- Set ``policy-rc.d`` on Debian-based systems. Action can be any available
- command in ``while true`` loop and ``case`` context.
- Following will disallow dpkg to stop/start services for the Cassandra
- package automatically:
-
- .. code-block:: yaml
-
- linux:
- system:
- policyrcd:
- - package: cassandra
- action: exit 101
- - package: '*'
- action: switch
-
- Set system locales:
-
- .. code-block:: yaml
-
- linux:
- system:
- locale:
- en_US.UTF-8:
- default: true
- "cs_CZ.UTF-8 UTF-8":
- enabled: true
-
- Systemd settings:
-
- .. code-block:: yaml
-
- linux:
- system:
- ...
- systemd:
- system:
- Manager:
- DefaultLimitNOFILE: 307200
- DefaultLimitNPROC: 307200
- user:
- Manager:
- DefaultLimitCPU: 2
- DefaultLimitNPROC: 4
-
- Ensure presence of directory:
-
- .. code-block:: yaml
-
- linux:
- system:
- directory:
- /tmp/test:
- user: root
- group: root
- mode: 700
- makedirs: true
-
- Ensure presence of file by specifying its source:
-
- .. code-block:: yaml
-
- linux:
- system:
- file:
- /tmp/test.txt:
- source: http://example.com/test.txt
- user: root #optional
- group: root #optional
- mode: 700 #optional
- dir_mode: 700 #optional
- encoding: utf-8 #optional
- hash: <<hash>> or <<URI to hash>> #optional
- makedirs: true #optional
-
- linux:
- system:
- file:
- test.txt:
- name: /tmp/test.txt
- source: http://example.com/test.txt
-
- linux:
- system:
- file:
- test2:
- name: /tmp/test2.txt
- source: http://example.com/test2.jinja
- template: jinja
-
- Ensure presence of file by specifying its contents:
-
- .. code-block:: yaml
-
- linux:
- system:
- file:
- /tmp/test.txt:
- contents: |
- line1
- line2
-
- linux:
- system:
- file:
- /tmp/test.txt:
- contents_pillar: linux:network:hostname
-
- linux:
- system:
- file:
- /tmp/test.txt:
- contents_grains: motd
-
- Ensure presence of file to be serialized through one of the
- serializer modules (see:
- https://docs.saltstack.com/en/latest/ref/serializers/all/index.html):
-
- .. code-block:: yaml
-
- linux:
- system:
- file:
- /tmp/test.json:
- serialize: json
- contents:
- foo: 1
- bar: 'bar'
-
- Kernel
- ~~~~~~
-
- Install always up to date LTS kernel and headers from Ubuntu Trusty:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- type: generic
- lts: trusty
- headers: true
-
- Load kernel modules and add them to ``/etc/modules``:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- modules:
- - nf_conntrack
- - tp_smapi
- - 8021q
-
- Configure or blacklist kernel modules with additional options to
- ``/etc/modprobe.d`` following example will add
- ``/etc/modprobe.d/nf_conntrack.conf`` file with line
- ``options nf_conntrack hashsize=262144``:
-
- 'option' can be a mapping (with 'enabled' and 'value' keys) or a scalar.
-
- Example for 'scalar' option value:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- module:
- nf_conntrack:
- option:
- hashsize: 262144
-
- Example for 'mapping' option value:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- module:
- nf_conntrack:
- option:
- hashsize:
- enabled: true
- value: 262144
-
- NOTE: 'enabled' key is optional and is True by default.
-
- Blacklist a module:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- module:
- nf_conntrack:
- blacklist: true
-
- A module can have a number of aliases, wildcards are allowed.
- Define an alias for a module:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- module:
- nf_conntrack:
- alias:
- nfct:
- enabled: true
- "nf_conn*":
- enabled: true
-
- NOTE: 'enabled' key is mandatory as there are no other keys exist.
-
- Execute custom command instead of 'insmod' when inserting a module:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- module:
- nf_conntrack:
- install:
- enabled: true
- command: /bin/true
-
- NOTE: 'enabled' key is optional and is True by default.
-
- Execute custom command instead of 'rmmod' when removing a module:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- module:
- nf_conntrack:
- remove:
- enabled: true
- command: /bin/true
-
- NOTE: 'enabled' key is optional and is True by default.
-
- Define module dependencies:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- module:
- nf_conntrack:
- softdep:
- pre:
- 1:
- enabled: true
- value: a
- 2:
- enabled: true
- value: b
- 3:
- enabled: true
- value: c
- post:
- 1:
- enabled: true
- value: x
- 2:
- enabled: true
- value: y
- 3:
- enabled: true
- value: z
-
- NOTE: 'enabled' key is optional and is True by default.
-
-
- Install specific kernel version and ensure all other kernel packages are
- not present. Also install extra modules and headers for this kernel:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- type: generic
- extra: true
- headers: true
- version: 4.2.0-22
-
- Systcl kernel parameters:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- sysctl:
- net.ipv4.tcp_keepalive_intvl: 3
- net.ipv4.tcp_keepalive_time: 30
- net.ipv4.tcp_keepalive_probes: 8
-
- Configure kernel boot options:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- boot_options:
- - elevator=deadline
- - spectre_v2=off
- - nopti
-
- Alternative way to set kernel boot options:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- transparent_hugepage: always
- elevator: deadline
- isolcpu: 1,2,3,4
-
- CPU
- ~~~
-
- Enable cpufreq governor for every cpu:
-
- .. code-block:: yaml
-
- linux:
- system:
- cpu:
- governor: performance
-
- SELinux
- ~~~~~~~
-
- Set SELinux mode on System:
-
- .. code-block:: yaml
-
- linux:
- system:
- selinux: permissive
-
- CGROUPS
- ~~~~~~~
-
- Setup linux cgroups:
-
- .. code-block:: yaml
-
- linux:
- system:
- cgroup:
- enabled: true
- group:
- ceph_group_1:
- controller:
- cpu:
- shares:
- value: 250
- cpuacct:
- usage:
- value: 0
- cpuset:
- cpus:
- value: 1,2,3
- memory:
- limit_in_bytes:
- value: 2G
- memsw.limit_in_bytes:
- value: 3G
- mapping:
- subjects:
- - '@ceph'
- generic_group_1:
- controller:
- cpu:
- shares:
- value: 250
- cpuacct:
- usage:
- value: 0
- mapping:
- subjects:
- - '*:firefox'
- - 'student:cp'
-
- Shared libraries
- ~~~~~~~~~~~~~~~~
-
- Set additional shared library to Linux system library path:
-
- .. code-block:: yaml
-
- linux:
- system:
- ld:
- library:
- java:
- - /usr/lib/jvm/jre-openjdk/lib/amd64/server
- - /opt/java/jre/lib/amd64/server
-
- Certificates
- ~~~~~~~~~~~~
-
- Add certificate authority into system trusted CA bundle:
-
- .. code-block:: yaml
-
- linux:
- system:
- ca_certificates:
- mycert: |
- -----BEGIN CERTIFICATE-----
- MIICPDCCAaUCEHC65B0Q2Sk0tjjKewPMur8wDQYJKoZIhvcNAQECBQAwXzELMAkG
- A1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMTcwNQYDVQQLEy5DbGFz
- cyAzIFB1YmxpYyBQcmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTk2
- MDEyOTAwMDAwMFoXDTI4MDgwMTIzNTk1OVowXzELMAkGA1UEBhMCVVMxFzAVBgNV
- BAoTDlZlcmlTaWduLCBJbmMuMTcwNQYDVQQLEy5DbGFzcyAzIFB1YmxpYyBQcmlt
- YXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIGfMA0GCSqGSIb3DQEBAQUAA4GN
- ADCBiQKBgQDJXFme8huKARS0EN8EQNvjV69qRUCPhAwL0TPZ2RHP7gJYHyX3KqhE
- BarsAx94f56TuZoAqiN91qyFomNFx3InzPRMxnVx0jnvT0Lwdd8KkMaOIG+YD/is
- I19wKTakyYbnsZogy1Olhec9vn2a/iRFM9x2Fe0PonFkTGUugWhFpwIDAQABMA0G
- CSqGSIb3DQEBAgUAA4GBALtMEivPLCYATxQT3ab7/AoRhIzzKBxnki98tsX63/Do
- lbwdj2wsqFHMc9ikwFPwTtYmwHYBV4GSXiHx0bH/59AhWM1pF+NEHJwZRDmJXNyc
- AA9WjQKZ7aKQRUzkuxCkPfAyAw7xzvjoyVGM5mKf5p/AfbdynMk2OmufTqj/ZA1k
- -----END CERTIFICATE-----
-
- Sysfs
- ~~~~~
-
- Install sysfsutils and set sysfs attributes:
-
- .. code-block:: yaml
-
- linux:
- system:
- sysfs:
- scheduler:
- block/sda/queue/scheduler: deadline
- power:
- mode:
- power/state: 0660
- owner:
- power/state: "root:power"
- devices/system/cpu/cpu0/cpufreq/scaling_governor: powersave
-
- Optional: You can also use list that will ensure order of items.
-
- .. code-block:: yaml
-
- linux:
- system:
- sysfs:
- scheduler:
- block/sda/queue/scheduler: deadline
- power:
- - mode:
- power/state: 0660
- - owner:
- power/state: "root:power"
- - devices/system/cpu/cpu0/cpufreq/scaling_governor: powersave
-
- Sysfs definition with disabled automatic write. Attributes are saved
- to configuration, but are not applied during the run.
- Thay will be applied automatically after the reboot.
-
-
- .. code-block:: yaml
-
- linux:
- system:
- sysfs:
- enable_apply: false
- scheduler:
- block/sda/queue/scheduler: deadline
-
- .. note:: The `enable_apply` parameter defaults to `True` if not defined.
-
- Huge Pages
- ~~~~~~~~~~~~
-
- Huge Pages give a performance boost to applications that intensively deal
- with memory allocation/deallocation by decreasing memory fragmentation:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- hugepages:
- small:
- size: 2M
- count: 107520
- mount_point: /mnt/hugepages_2MB
- mount: false/true # default is true (mount immediately) / false (just save in the fstab)
- large:
- default: true # default automatically mounted
- size: 1G
- count: 210
- mount_point: /mnt/hugepages_1GB
-
- .. note:: Not recommended to use both pagesizes concurrently.
-
- Intel SR-IOV
- ~~~~~~~~~~~~
-
- PCI-SIG Single Root I/O Virtualization and Sharing (SR-IOV)
- specification defines a standardized mechanism to virtualize
- PCIe devices. The mechanism can virtualize a single PCIe
- Ethernet controller to appear as multiple PCIe devices:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- sriov: True
- unsafe_interrupts: False # Default is false. for older platforms and AMD we need to add interrupt remapping workaround
- rc:
- local: |
- #!/bin/sh -e
- # Enable 7 VF on eth1
- echo 7 > /sys/class/net/eth1/device/sriov_numvfs; sleep 2; ifup -a
- exit 0
-
- Isolate CPU options
- ~~~~~~~~~~~~~~~~~~~
-
- Remove the specified CPUs, as defined by the cpu_number values, from
- the general kernel SMP balancing and scheduler algroithms. The only
- way to move a process onto or off an *isolated* CPU is via the CPU
- affinity syscalls. ``cpu_number begins`` at ``0``, so the
- maximum value is ``1`` less than the number of CPUs on the system.:
-
- .. code-block:: yaml
-
- linux:
- system:
- kernel:
- isolcpu: 1,2,3,4,5,6,7 # isolate first cpu 0
-
- Repositories
- ~~~~~~~~~~~~
-
- RedHat-based Linux with additional OpenStack repo:
-
- .. code-block:: yaml
-
- linux:
- system:
- ...
- repo:
- rdo-icehouse:
- enabled: true
- source: 'http://repos.fedorapeople.org/repos/openstack/openstack-icehouse/epel-6/'
- pgpcheck: 0
-
- Ensure system repository to use czech Debian mirror (``default: true``)
- Also pin it's packages with priority ``900``:
-
- .. code-block:: yaml
-
- linux:
- system:
- repo:
- debian:
- default: true
- source: "deb http://ftp.cz.debian.org/debian/ jessie main contrib non-free"
- # Import signing key from URL if needed
- key_url: "http://dummy.com/public.gpg"
- pin:
- - pin: 'origin "ftp.cz.debian.org"'
- priority: 900
- package: '*'
-
- If you need to add multiple pin rules for one repo, please use new,ordered definition format
- ('pinning' definition will be in priotity to use):
-
- .. code-block:: yaml
-
- linux:
- system:
- repo:
- mcp_saltstack:
- source: "deb [arch=amd64] http://repo.saltstack.com/apt/ubuntu/16.04/amd64/2017.7/ xenial main"
- architectures: amd64
- clean_file: true
- pinning:
- 10:
- enabled: true
- pin: 'release o=SaltStack'
- priority: 50
- package: 'libsodium18'
- 20:
- enabled: true
- pin: 'release o=SaltStack'
- priority: 1100
- package: '*'
-
-
- .. note:: For old Ubuntu releases (<xenial)
- extra packages for apt transport, like ``apt-transport-https``
- may be required to be installed manually.
- (Chicken-eggs issue: we need to install packages to
- reach repo from where they should be installed)
- Otherwise, you still can try 'fortune' and install prereq.packages before
- any repo configuration, using list of requires in map.jinja.
-
-
- Disabling any prerequisite packages installation:
-
- You can simply drop any package pre-installation (before system.linux.repo
- will be processed) via cluster lvl:
-
- .. code-block:: yaml
-
- linux:
- system:
- pkgs: ~
-
- Package manager proxy global setup:
-
- .. code-block:: yaml
-
- linux:
- system:
- ...
- repo:
- apt-mk:
- source: "deb http://apt-mk.mirantis.com/ stable main salt"
- ...
- proxy:
- pkg:
- enabled: true
- ftp: ftp://ftp-proxy-for-apt.host.local:2121
- ...
- # NOTE: Global defaults for any other componet that configure proxy on the system.
- # If your environment has just one simple proxy, set it on linux:system:proxy.
- #
- # fall back system defaults if linux:system:proxy:pkg has no protocol specific entries
- # as for https and http
- ftp: ftp://proxy.host.local:2121
- http: http://proxy.host.local:3142
- https: https://proxy.host.local:3143
-
- Package manager proxy setup per repository:
-
- .. code-block:: yaml
-
- linux:
- system:
- ...
- repo:
- debian:
- source: "deb http://apt-mk.mirantis.com/ stable main salt"
- ...
- apt-mk:
- source: "deb http://apt-mk.mirantis.com/ stable main salt"
- # per repository proxy
- proxy:
- enabled: true
- http: http://maas-01:8080
- https: http://maas-01:8080
- ...
- proxy:
- # package manager fallback defaults
- # used if linux:system:repo:apt-mk:proxy has no protocol specific entries
- pkg:
- enabled: true
- ftp: ftp://proxy.host.local:2121
- #http: http://proxy.host.local:3142
- #https: https://proxy.host.local:3143
- ...
- # global system fallback system defaults
- ftp: ftp://proxy.host.local:2121
- http: http://proxy.host.local:3142
- https: https://proxy.host.local:3143
-
- Remove all repositories:
-
- .. code-block:: yaml
-
- linux:
- system:
- purge_repos: true
-
- Refresh repositories metada, after configuration:
-
- .. code-block:: yaml
-
- linux:
- system:
- refresh_repos_meta: true
-
- Setup custom apt config options:
-
- .. code-block:: yaml
-
- linux:
- system:
- apt:
- config:
- compression-workaround:
- "Acquire::CompressionTypes::Order": "gz"
- docker-clean:
- "DPkg::Post-Invoke":
- - "rm -f /var/cache/apt/archives/*.deb /var/cache/apt/archives/partial/*.deb /var/cache/apt/*.bin || true"
- "APT::Update::Post-Invoke":
- - "rm -f /var/cache/apt/archives/*.deb /var/cache/apt/archives/partial/*.deb /var/cache/apt/*.bin || true"
-
- RC
- ~~
-
- rc.local example
-
- .. code-block:: yaml
-
- linux:
- system:
- rc:
- local: |
- #!/bin/sh -e
- #
- # rc.local
- #
- # This script is executed at the end of each multiuser runlevel.
- # Make sure that the script will "exit 0" on success or any other
- # value on error.
- #
- # In order to enable or disable this script just change the execution
- # bits.
- #
- # By default this script does nothing.
- exit 0
-
- Prompt
- ~~~~~~
-
- Setting prompt is implemented by creating ``/etc/profile.d/prompt.sh``.
- Every user can have different prompt:
-
- .. code-block:: yaml
-
- linux:
- system:
- prompt:
- 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\\]
- default: \\n\\D{%y/%m/%d %H:%M:%S} $(hostname -f)\\n[\\u@\\h:\\w]
-
- On Debian systems, to set prompt system-wide, it's necessary to
- remove setting PS1 in ``/etc/bash.bashrc`` and ``~/.bashrc``,
- which comes from ``/etc/skel/.bashrc``. This formula will do
- this automatically, but will not touch existing user's
- ``~/.bashrc`` files except root.
-
- Bash
- ~~~~
-
- Fix bash configuration to preserve history across sessions
- like ZSH does by default:
-
- .. code-block:: yaml
-
- linux:
- system:
- bash:
- preserve_history: true
-
- Login banner message
- ~~~~~~~~~~~~~~~~~~~~
-
- ``/etc/issue`` is a text file which contains a message or system
- identification to be printed before the login prompt. It may contain
- various @char and \char sequences, if supported by the getty-type
- program employed on the system.
-
- Setting logon banner message is easy:
-
- .. code-block:: yaml
-
- liunx:
- system:
- banner:
- enabled: true
- contents: |
- UNAUTHORIZED ACCESS TO THIS SYSTEM IS PROHIBITED
-
- You must have explicit, authorized permission to access or configure this
- device. Unauthorized attempts and actions to access or use this system may
- result in civil and/or criminal penalties.
- All activities performed on this system are logged and monitored.
-
- Message of the day
- ~~~~~~~~~~~~~~~~~~
-
- ``pam_motd`` from package ``libpam-modules`` is used for dynamic
- messages of the day. Setting custom ``motd`` will clean up existing ones.
-
- Setting static ``motd`` will replace existing ``/etc/motd`` and remove
- scripts from ``/etc/update-motd.d``.
-
- Setting static ``motd``:
-
- .. code-block:: yaml
-
- linux:
- system:
- motd: |
- UNAUTHORIZED ACCESS TO THIS SYSTEM IS PROHIBITED
-
- You must have explicit, authorized permission to access or configure this
- device. Unauthorized attempts and actions to access or use this system may
- result in civil and/or criminal penalties.
- All activities performed on this system are logged and monitored.
-
- Setting dynamic ``motd``:
-
- .. code-block:: yaml
-
- linux:
- system:
- motd:
- - release: |
- #!/bin/sh
- [ -r /etc/lsb-release ] && . /etc/lsb-release
-
- if [ -z "$DISTRIB_DESCRIPTION" ] && [ -x /usr/bin/lsb_release ]; then
- # Fall back to using the very slow lsb_release utility
- DISTRIB_DESCRIPTION=$(lsb_release -s -d)
- fi
-
- printf "Welcome to %s (%s %s %s)\n" "$DISTRIB_DESCRIPTION" "$(uname -o)" "$(uname -r)" "$(uname -m)"
- - warning: |
- #!/bin/sh
- printf "This is [company name] network.\n"
- printf "Unauthorized access strictly prohibited.\n"
-
- Services
- ~~~~~~~~
-
- Stop and disable the ``linux`` service:
-
- .. code-block:: yaml
-
- linux:
- system:
- service:
- apt-daily.timer:
- status: dead
-
- Possible statuses are ``dead`` (disable service by default), ``running``
- (enable service by default), ``enabled``, ``disabled``:
-
- Linux with the ``atop`` service:
-
- .. code-block:: yaml
-
- linux:
- system:
- atop:
- enabled: true
- interval: 20
- logpath: "/var/log/atop"
- outfile: "/var/log/atop/daily.log"
-
- Linux with the ``mcelog`` service:
-
- .. code-block:: yaml
-
- linux:
- system:
- mcelog:
- enabled: true
- logging:
- syslog: true
- syslog_error: true
-
- RHEL / CentOS
- ^^^^^^^^^^^^^
- Currently, ``update-motd`` is not available
- for RHEL. So there is no native support for dynamic ``motd``.
- You can still set a static one, with a different pillar structure:
-
- .. code-block:: yaml
-
- linux:
- system:
- motd: |
- This is [company name] network.
- Unauthorized access strictly prohibited.
-
- Haveged
- ~~~~~~~
-
- If you are running headless server and are low on entropy,
- you may set up Haveged:
-
- .. code-block:: yaml
-
- linux:
- system:
- haveged:
- enabled: true
-
- Linux network
- -------------
-
- Linux with network manager:
-
- .. code-block:: yaml
-
- linux:
- network:
- enabled: true
- network_manager: true
-
- Execute linux.network.interface state without ifupdown activity:
-
- .. code-block:: bash
-
- salt-call linux.network.interface pillar='{"linux":{"network":{"noifupdown":True}}}'
-
-
- Linux with default static network interfaces, default gateway
- interface and DNS servers:
-
- .. code-block:: yaml
-
- linux:
- network:
- enabled: true
- interface:
- eth0:
- enabled: true
- type: eth
- address: 192.168.0.102
- netmask: 255.255.255.0
- gateway: 192.168.0.1
- name_servers:
- - 8.8.8.8
- - 8.8.4.4
- mtu: 1500
-
- Linux with bonded interfaces and disabled ``NetworkManager``:
-
- .. code-block:: yaml
-
- linux:
- network:
- enabled: true
- interface:
- eth0:
- type: eth
- ...
- eth1:
- type: eth
- ...
- bond0:
- enabled: true
- type: bond
- address: 192.168.0.102
- netmask: 255.255.255.0
- mtu: 1500
- use_in:
- - interface: ${linux:interface:eth0}
- - interface: ${linux:interface:eth0}
- network_manager:
- disable: true
-
- Linux with VLAN ``interface_params``:
-
- .. code-block:: yaml
-
- linux:
- network:
- enabled: true
- interface:
- vlan69:
- type: vlan
- use_interfaces:
- - interface: ${linux:interface:bond0}
-
- Linux with wireless interface parameters:
-
- .. code-block:: yaml
-
- linux:
- network:
- enabled: true
- gateway: 10.0.0.1
- default_interface: eth0
- interface:
- wlan0:
- type: eth
- wireless:
- essid: example
- key: example_key
- security: wpa
- priority: 1
-
- Linux networks with routes defined:
-
- .. code-block:: yaml
-
- linux:
- network:
- enabled: true
- gateway: 10.0.0.1
- default_interface: eth0
- interface:
- eth0:
- type: eth
- route:
- default:
- address: 192.168.0.123
- netmask: 255.255.255.0
- gateway: 192.168.0.1
-
- Native Linux Bridges:
-
- .. code-block:: yaml
-
- linux:
- network:
- interface:
- eth1:
- enabled: true
- type: eth
- proto: manual
- up_cmds:
- - ip address add 0/0 dev $IFACE
- - ip link set $IFACE up
- down_cmds:
- - ip link set $IFACE down
- br-ex:
- enabled: true
- type: bridge
- address: ${linux:network:host:public_local:address}
- netmask: 255.255.255.0
- use_interfaces:
- - eth1
-
- Open vSwitch Bridges:
-
- .. code-block:: yaml
-
- linux:
- network:
- bridge: openvswitch
- interface:
- eth1:
- enabled: true
- type: eth
- proto: manual
- up_cmds:
- - ip address add 0/0 dev $IFACE
- - ip link set $IFACE up
- down_cmds:
- - ip link set $IFACE down
- br-ex:
- enabled: true
- type: bridge
- address: ${linux:network:host:public_local:address}
- netmask: 255.255.255.0
- use_interfaces:
- - eth1
- br-prv:
- enabled: true
- type: ovs_bridge
- mtu: 65000
- br-ens7:
- enabled: true
- name: br-ens7
- type: ovs_bridge
- ovs_ports: ens7
- proto: manual
- mtu: 9000
- use_interfaces:
- - ens7
- patch-br-ens7-br-prv:
- enabled: true
- name: ens7-prv
- ovs_type: ovs_port
- type: ovs_port
- bridge: br-ens7
- port_type: patch
- peer: prv-ens7
- tag: 109 # [] to unset a tag
- mtu: 65000
- patch-br-prv-br-ens7:
- enabled: true
- name: prv-ens7
- bridge: br-prv
- ovs_type: ovs_port
- type: ovs_port
- port_type: patch
- peer: ens7-prv
- tag: 109
- mtu: 65000
- ens7:
- enabled: true
- name: ens7
- proto: manual
- ovs_port_type: OVSPort
- type: ovs_port
- ovs_bridge: br-ens7
- bridge: br-ens7
-
- Debian manual proto interfaces
-
- When you are changing interface proto from static in up state
- to manual, you may need to flush ip addresses. For example,
- if you want to use the interface and the ip on the bridge.
- This can be done by setting the ``ipflush_onchange`` to true.
-
- .. code-block:: yaml
-
- linux:
- network:
- interface:
- eth1:
- enabled: true
- type: eth
- proto: manual
- mtu: 9100
- ipflush_onchange: true
-
- Debian static proto interfaces
-
- When you are changing interface proto from dhcp in up state to
- static, you may need to flush ip addresses and restart interface
- to assign ip address from a managed file. For example, if you wantto
- use the interface and the ip on the bridge. This can be done by
- setting the ``ipflush_onchange`` with combination ``restart_on_ipflush``
- param set to true.
-
- .. code-block:: yaml
-
- linux:
- network:
- interface:
- eth1:
- enabled: true
- type: eth
- proto: static
- address: 10.1.0.22
- netmask: 255.255.255.0
- ipflush_onchange: true
- restart_on_ipflush: true
-
- Concatinating and removing interface files
-
- Debian based distributions have ``/etc/network/interfaces.d/``
- directory, where you can store configuration of network
- interfaces in separate files. You can concatinate the files
- to the defined destination when needed, this operation removes
- the file from the ``/etc/network/interfaces.d/``. If you just need
- to remove iface files, you can use the ``remove_iface_files`` key.
-
- .. code-block:: yaml
-
- linux:
- network:
- concat_iface_files:
- - src: '/etc/network/interfaces.d/50-cloud-init.cfg'
- dst: '/etc/network/interfaces'
- remove_iface_files:
- - '/etc/network/interfaces.d/90-custom.cfg'
-
- Configure DHCP client
-
- None of the keys is mandatory, include only those you really need.
- For full list of available options under send, supersede, prepend,
- append refer to dhcp-options(5).
-
- .. code-block:: yaml
-
- linux:
- network:
- dhclient:
- enabled: true
- backoff_cutoff: 15
- initial_interval: 10
- reboot: 10
- retry: 60
- select_timeout: 0
- timeout: 120
- send:
- - option: host-name
- declaration: "= gethostname()"
- supersede:
- - option: host-name
- declaration: "spaceship"
- - option: domain-name
- declaration: "domain.home"
- #- option: arp-cache-timeout
- # declaration: 20
- prepend:
- - option: domain-name-servers
- declaration:
- - 8.8.8.8
- - 8.8.4.4
- - option: domain-search
- declaration:
- - example.com
- - eng.example.com
- #append:
- #- option: domain-name-servers
- # declaration: 127.0.0.1
- # ip or subnet to reject dhcp offer from
- reject:
- - 192.33.137.209
- - 10.0.2.0/24
- request:
- - subnet-mask
- - broadcast-address
- - time-offset
- - routers
- - domain-name
- - domain-name-servers
- - domain-search
- - host-name
- - dhcp6.name-servers
- - dhcp6.domain-search
- - dhcp6.fqdn
- - dhcp6.sntp-servers
- - netbios-name-servers
- - netbios-scope
- - interface-mtu
- - rfc3442-classless-static-routes
- - ntp-servers
- require:
- - subnet-mask
- - domain-name-servers
- # if per interface configuration required add below
- interface:
- ens2:
- initial_interval: 11
- reject:
- - 192.33.137.210
- ens3:
- initial_interval: 12
- reject:
- - 192.33.137.211
-
- Linux network systemd settings:
-
- .. code-block:: yaml
-
- linux:
- network:
- ...
- systemd:
- link:
- 10-iface-dmz:
- Match:
- MACAddress: c8:5b:67:fa:1a:af
- OriginalName: eth0
- Link:
- Name: dmz0
- netdev:
- 20-bridge-dmz:
- match:
- name: dmz0
- network:
- mescription: bridge
- bridge: br-dmz0
- network:
- # works with lowercase, keys are by default capitalized
- 40-dhcp:
- match:
- name: '*'
- network:
- DHCP: yes
-
- Configure global environment variables
-
- Use ``/etc/environment`` for static system wide variable assignment
- after boot. Variable expansion is frequently not supported.
-
- .. code-block:: yaml
-
- linux:
- system:
- env:
- BOB_VARIABLE: Alice
- ...
- BOB_PATH:
- - /srv/alice/bin
- - /srv/bob/bin
- ...
- ftp_proxy: none
- http_proxy: http://global-http-proxy.host.local:8080
- https_proxy: ${linux:system:proxy:https}
- no_proxy:
- - 192.168.0.80
- - 192.168.1.80
- - .domain.com
- - .local
- ...
- # NOTE: global defaults proxy configuration.
- proxy:
- ftp: ftp://proxy.host.local:2121
- http: http://proxy.host.local:3142
- https: https://proxy.host.local:3143
- noproxy:
- - .domain.com
- - .local
-
- Configure the ``profile.d`` scripts
-
- The ``profile.d`` scripts are being sourced during ``.sh`` execution
- and support variable expansion in opposite to /etc/environment global
- settings in ``/etc/environment``.
-
- .. code-block:: yaml
-
- linux:
- system:
- profile:
- locales: |
- export LANG=C
- export LC_ALL=C
- ...
- vi_flavors.sh: |
- export PAGER=view
- export EDITOR=vim
- alias vi=vim
- shell_locales.sh: |
- export LANG=en_US
- export LC_ALL=en_US.UTF-8
- shell_proxies.sh: |
- export FTP_PROXY=ftp://127.0.3.3:2121
- export NO_PROXY='.local'
-
-
- Configure login.defs parameters
- -------------------------------
-
- .. code-block:: yaml
-
- linux:
- system:
- login_defs:
- <opt_name>:
- enabled: true
- value: <opt_value>
-
- <opt_name> is a configurational option defined in 'man login.defs'.
- <opt_name> is case sensitive, should be UPPERCASE only!
-
-
- Linux with hosts
-
- Parameter ``purge_hosts`` will enforce whole ``/etc/hosts file``,
- removing entries that are not defined in model except defaults
- for both IPv4 and IPv6 localhost and hostname as well as FQDN.
-
- We recommend using this option to verify that ``/etc/hosts``
- is always in a clean state. However it is not enabled by default
- for security reasons.
-
- .. code-block:: yaml
-
- linux:
- network:
- purge_hosts: true
- host:
- # No need to define this one if purge_hosts is true
- hostname:
- address: 127.0.1.1
- names:
- - ${linux:network:fqdn}
- - ${linux:network:hostname}
- node1:
- address: 192.168.10.200
- names:
- - node2.domain.com
- - service2.domain.com
- node2:
- address: 192.168.10.201
- names:
- - node2.domain.com
- - service2.domain.com
-
- Linux with hosts collected from mine
-
- All DNS records defined within infrastrucuture
- are passed to the local hosts records or any DNS server. Only
- hosts with the ``grain`` parameter set to ``true`` will be propagated
- to the mine.
-
- .. code-block:: yaml
-
- linux:
- network:
- purge_hosts: true
- mine_dns_records: true
- host:
- node1:
- address: 192.168.10.200
- grain: true
- names:
- - node2.domain.com
- - service2.domain.com
-
- Set up ``resolv.conf``, nameservers, domain and search domains:
-
- .. code-block:: yaml
-
- linux:
- network:
- resolv:
- dns:
- - 8.8.4.4
- - 8.8.8.8
- domain: my.example.com
- search:
- - my.example.com
- - example.com
- options:
- - ndots: 5
- - timeout: 2
- - attempts: 2
-
- Set up custom TX queue length for tap interfaces:
-
- .. code-block:: yaml
-
- linux:
- network:
- tap_custom_txqueuelen: 10000
-
- Open vSwitch native bond:
-
- .. code-block:: yaml
-
- bond1:
- enabled: true
- type: ovs_bond
- mode: balance-slb
- bridge: br-ex
- slaves: eno3 eno4
-
- DPDK OVS interfaces
-
- **DPDK OVS NIC**
-
- .. code-block:: yaml
-
- linux:
- network:
- bridge: openvswitch
- dpdk:
- enabled: true
- driver: uio/vfio
- openvswitch:
- pmd_cpu_mask: "0x6"
- dpdk_socket_mem: "1024,1024"
- dpdk_lcore_mask: "0x400"
- memory_channels: 2
- interface:
- dpkd0:
- name: ${_param:dpdk_nic}
- pci: 0000:06:00.0
- driver: igb_uio/vfio-pci
- enabled: true
- type: dpdk_ovs_port
- n_rxq: 2
- pmd_rxq_affinity: "0:1,1:2"
- bridge: br-prv
- mtu: 9000
- br-prv:
- enabled: true
- type: dpdk_ovs_bridge
-
- **DPDK OVS Bond**
-
- .. code-block:: yaml
-
- linux:
- network:
- bridge: openvswitch
- dpdk:
- enabled: true
- driver: uio/vfio
- openvswitch:
- pmd_cpu_mask: "0x6"
- dpdk_socket_mem: "1024,1024"
- dpdk_lcore_mask: "0x400"
- memory_channels: 2
- interface:
- dpdk_second_nic:
- name: ${_param:primary_second_nic}
- pci: 0000:06:00.0
- driver: igb_uio/vfio-pci
- bond: dpdkbond0
- enabled: true
- type: dpdk_ovs_port
- n_rxq: 2
- pmd_rxq_affinity: "0:1,1:2"
- mtu: 9000
- dpdk_first_nic:
- name: ${_param:primary_first_nic}
- pci: 0000:05:00.0
- driver: igb_uio/vfio-pci
- bond: dpdkbond0
- enabled: true
- type: dpdk_ovs_port
- n_rxq: 2
- pmd_rxq_affinity: "0:1,1:2"
- mtu: 9000
- dpdkbond0:
- enabled: true
- bridge: br-prv
- type: dpdk_ovs_bond
- mode: active-backup
- br-prv:
- enabled: true
- type: dpdk_ovs_bridge
-
- **DPDK OVS LACP Bond with vlan tag**
-
- .. code-block:: yaml
-
- linux:
- network:
- bridge: openvswitch
- dpdk:
- enabled: true
- driver: uio
- openvswitch:
- pmd_cpu_mask: "0x6"
- dpdk_socket_mem: "1024,1024"
- dpdk_lcore_mask: "0x400"
- memory_channels: "2"
- interface:
- eth3:
- enabled: true
- type: eth
- proto: manual
- name: ${_param:tenant_first_nic}
- eth4:
- enabled: true
- type: eth
- proto: manual
- name: ${_param:tenant_second_nic}
- dpdk0:
- name: ${_param:tenant_first_nic}
- pci: "0000:81:00.0"
- driver: igb_uio
- bond: bond1
- enabled: true
- type: dpdk_ovs_port
- n_rxq: 2
- dpdk1:
- name: ${_param:tenant_second_nic}
- pci: "0000:81:00.1"
- driver: igb_uio
- bond: bond1
- enabled: true
- type: dpdk_ovs_port
- n_rxq: 2
- bond1:
- enabled: true
- bridge: br-prv
- type: dpdk_ovs_bond
- mode: balance-slb
- br-prv:
- enabled: true
- type: dpdk_ovs_bridge
- tag: ${_param:tenant_vlan}
- address: ${_param:tenant_address}
- netmask: ${_param:tenant_network_netmask}
-
- **DPDK OVS bridge for VXLAN**
-
- If VXLAN is used as tenant segmentation, IP address must
- be set on ``br-prv``.
-
- .. code-block:: yaml
-
- linux:
- network:
- ...
- interface:
- br-prv:
- enabled: true
- type: dpdk_ovs_bridge
- address: 192.168.50.0
- netmask: 255.255.255.0
- tag: 101
- mtu: 9000
-
- **DPDK OVS bridge with Linux network interface**
-
- .. code-block:: yaml
-
- linux:
- network:
- ...
- interface:
- eth0:
- type: eth
- ovs_bridge: br-prv
- ...
- br-prv:
- enabled: true
- type: dpdk_ovs_bridge
- ...
-
- Linux storage
- -------------
-
- Linux with mounted Samba:
-
- .. code-block:: yaml
-
- linux:
- storage:
- enabled: true
- mount:
- samba1:
- - enabled: true
- - path: /media/myuser/public/
- - device: //192.168.0.1/storage
- - file_system: cifs
- - options: guest,uid=myuser,iocharset=utf8,file_mode=0777,dir_mode=0777,noperm
-
- NFS mount:
-
- .. code-block:: yaml
-
- linux:
- storage:
- enabled: true
- mount:
- nfs_glance:
- enabled: true
- path: /var/lib/glance/images
- device: 172.16.10.110:/var/nfs/glance
- file_system: nfs
- opts: rw,sync
-
- File swap configuration:
-
- .. code-block:: yaml
-
- linux:
- storage:
- enabled: true
- swap:
- file:
- enabled: true
- engine: file
- device: /swapfile
- size: 1024
-
- Partition swap configuration:
-
- .. code-block:: yaml
-
- linux:
- storage:
- enabled: true
- swap:
- partition:
- enabled: true
- engine: partition
- device: /dev/vg0/swap
-
- LVM group ``vg1`` with one device and ``data`` volume mounted
- into ``/mnt/data``.
-
- .. code-block:: yaml
-
- parameters:
- linux:
- storage:
- mount:
- data:
- enabled: true
- device: /dev/vg1/data
- file_system: ext4
- path: /mnt/data
- lvm:
- vg1:
- enabled: true
- devices:
- - /dev/sdb
- volume:
- data:
- size: 40G
- mount: ${linux:storage:mount:data}
-
- Create partitions on disk. Specify size in MB. It expects empty
- disk without any existing partitions.
- Set ``startsector=1`` if you want to start partitions from ``2048``.
-
- .. code-block:: yaml
-
- linux:
- storage:
- disk:
- first_drive:
- startsector: 1
- name: /dev/loop1
- type: gpt
- partitions:
- - size: 200 #size in MB
- type: fat32
- - size: 300 #size in MB
- mkfs: True
- type: xfs
- /dev/vda1:
- partitions:
- - size: 5
- type: ext2
- - size: 10
- type: ext4
-
- Multipath with Fujitsu Eternus DXL:
-
- .. code-block:: yaml
-
- parameters:
- linux:
- storage:
- multipath:
- enabled: true
- blacklist_devices:
- - /dev/sda
- - /dev/sdb
- backends:
- - fujitsu_eternus_dxl
-
- Multipath with Hitachi VSP 1000:
-
- .. code-block:: yaml
-
- parameters:
- linux:
- storage:
- multipath:
- enabled: true
- blacklist_devices:
- - /dev/sda
- - /dev/sdb
- backends:
- - hitachi_vsp1000
-
- Multipath with IBM Storwize:
-
- .. code-block:: yaml
-
- parameters:
- linux:
- storage:
- multipath:
- enabled: true
- blacklist_devices:
- - /dev/sda
- - /dev/sdb
- backends:
- - ibm_storwize
-
- Multipath with multiple backends:
-
- .. code-block:: yaml
-
- parameters:
- linux:
- storage:
- multipath:
- enabled: true
- blacklist_devices:
- - /dev/sda
- - /dev/sdb
- - /dev/sdc
- - /dev/sdd
- backends:
- - ibm_storwize
- - fujitsu_eternus_dxl
- - hitachi_vsp1000
-
- PAM LDAP integration:
-
- .. code-block:: yaml
-
- parameters:
- linux:
- system:
- auth:
- enabled: true
- mkhomedir:
- enabled: true
- umask: 0027
- ldap:
- enabled: true
- binddn: cn=bind,ou=service_users,dc=example,dc=com
- bindpw: secret
- uri: ldap://127.0.0.1
- base: ou=users,dc=example,dc=com
- ldap_version: 3
- pagesize: 65536
- referrals: off
- filter:
- passwd: (&(&(objectClass=person)(uidNumber=*))(unixHomeDirectory=*))
- shadow: (&(&(objectClass=person)(uidNumber=*))(unixHomeDirectory=*))
- group: (&(objectClass=group)(gidNumber=*))
-
- PAM duo 2FA integration
-
- .. code-block:: yaml
-
- parameters:
- linux:
- system:
- auth:
- enabled: true
- duo:
- enabled: true
- duo_host: localhost
- duo_ikey: DUO-INTEGRATION-KEY
- duo_skey: DUO-SECRET-KEY
-
- duo package version may be specified (optional)
-
- .. code-block:: yaml
-
- linux:
- system:
- package:
- duo-unix:
- version: 1.10.1-0
-
- Disabled multipath (the default setup):
-
- .. code-block:: yaml
-
- parameters:
- linux:
- storage:
- multipath:
- enabled: false
-
- Linux with local loopback device:
-
- .. code-block:: yaml
-
- linux:
- storage:
- loopback:
- disk1:
- file: /srv/disk1
- size: 50G
-
- External config generation
- --------------------------
-
- You are able to use config support metadata between formulas
- and only generate configuration files for external use, for example, Docker, and so on.
-
- .. code-block:: yaml
-
- parameters:
- linux:
- system:
- config:
- pillar:
- jenkins:
- master:
- home: /srv/volumes/jenkins
- approved_scripts:
- - method java.net.URL openConnection
- credentials:
- - type: username_password
- scope: global
- id: test
- desc: Testing credentials
- username: test
- password: test
-
- Netconsole Remote Kernel Logging
- --------------------------------
-
- Netconsole logger can be configured for the configfs-enabled kernels
- (``CONFIG_NETCONSOLE_DYNAMIC`` must be enabled). The configuration
- applies both in runtime (if network is already configured),
- and on-boot after an interface initialization.
-
- .. note::
-
- * Receiver can be located only on the same L3 domain
- (or you need to configure gateway MAC manually).
- * The Receiver MAC is detected only on configuration time.
- * Using broadcast MAC is not recommended.
-
- .. code-block:: yaml
-
- parameters:
- linux:
- system:
- netconsole:
- enabled: true
- port: 514 (optional)
- loglevel: debug (optional)
- target:
- 192.168.0.1:
- interface: bond0
- mac: "ff:ff:ff:ff:ff:ff" (optional)
-
- Check network params on the environment
- ---------------------------------------
-
- Grab nics and nics states
-
- .. code-block:: bash
-
- salt osd001\* net_checks.get_nics
-
- **Example of system output:**
-
- .. code-block:: bash
-
- osd001.domain.com:
- |_
- - bond0
- - None
- - 1e:c8:64:42:23:b9
- - 0
- - 1500
- |_
- - bond1
- - None
- - 3c:fd:fe:27:3b:00
- - 1
- - 9100
- |_
- - fourty1
- - None
- - 3c:fd:fe:27:3b:00
- - 1
- - 9100
- |_
- - fourty2
- - None
- - 3c:fd:fe:27:3b:02
- - 1
- - 9100
-
- Grab 10G nics PCI addresses for hugepages setup
-
- .. code-block:: bash
-
- salt cmp001\* net_checks.get_ten_pci
-
- **Example of system output:**
-
- .. code-block:: bash
-
- cmp001.domain.com:
- |_
- - ten1
- - 0000:19:00.0
- |_
- - ten2
- - 0000:19:00.1
- |_
- - ten3
- - 0000:19:00.2
- |_
- - ten4
- - 0000:19:00.3
-
- Grab ip address for an interface
-
- .. code-block:: bash
-
- salt cmp001\* net_checks.get_ip iface=one4
-
- **Example of system output:**
-
- .. code-block:: bash
-
- cmp001.domain.com:
- 10.200.177.101
-
- Grab ip addresses map
-
- .. code-block:: bash
-
- salt-call net_checks.nodes_addresses
-
- **Example of system output:**
-
- .. code-block:: bash
-
- local:
- |_
- - cid01.domain.com
- |_
- |_
- - pxe
- - 10.200.177.91
- |_
- - control
- - 10.200.178.91
- |_
- - cmn02.domain.com
- |_
- |_
- - storage_access
- - 10.200.181.67
- |_
- - pxe
- - 10.200.177.67
- |_
- - control
- - 10.200.178.67
- |_
- - cmp010.domain.com
- |_
- |_
- - pxe
- - 10.200.177.110
- |_
- - storage_access
- - 10.200.181.110
- |_
- - control
- - 10.200.178.110
- |_
- - vxlan
- - 10.200.179.110
-
- Verify full mesh connectivity
-
- .. code-block:: bash
-
- salt-call net_checks.ping_check
-
- **Example of positive system output:**
-
- .. code-block:: bash
-
- ['PASSED']
- [INFO ] ['PASSED']
- local:
- True
-
- **Example of system output in case of failure:**
-
- .. code-block:: bash
-
- FAILED
- [ERROR ] FAILED
- ['control: 10.0.1.92 -> 10.0.1.224: Failed']
- ['control: 10.0.1.93 -> 10.0.1.224: Failed']
- ['control: 10.0.1.51 -> 10.0.1.224: Failed']
- ['control: 10.0.1.102 -> 10.0.1.224: Failed']
- ['control: 10.0.1.13 -> 10.0.1.224: Failed']
- ['control: 10.0.1.81 -> 10.0.1.224: Failed']
- local:
- False
-
- For this feature to work, please mark addresses with some role.
- Otherwise 'default' role is assumed and mesh would consist of all
- addresses on the environment.
-
- Mesh mark is needed only for interfaces which are enabled and have
- ip address assigned.
-
- Checking dhcp pxe network meaningless, as it is used for salt
- master vs minion communications, therefore treated as checked.
-
- .. code-block:: yaml
-
- parameters:
- linux:
- network:
- interface:
- ens3:
- enabled: true
- type: eth
- proto: static
- address: ${_param:deploy_address}
- netmask: ${_param:deploy_network_netmask}
- gateway: ${_param:deploy_network_gateway}
- mesh: pxe
-
- Check pillars for ip address duplicates
-
- .. code-block:: bash
-
- salt-call net_checks.verify_addresses
-
- **Example of positive system output:**
-
- .. code-block:: bash
-
- ['PASSED']
- [INFO ] ['PASSED']
- local:
- True
-
- **Example of system output in case of failure:**
-
- .. code-block:: bash
-
- FAILED. Duplicates found
- [ERROR ] FAILED. Duplicates found
- ['gtw01.domain.com', 'gtw02.domain.com', '10.0.1.224']
- [ERROR ] ['gtw01.domain.com', 'gtw02.domain.com', '10.0.1.224']
- local:
- False
-
- Generate csv report for the env
-
- .. code-block:: bash
-
- salt -C 'kvm* or cmp* or osd*' net_checks.get_nics_csv \
- | grep '^\ ' | sed 's/\ *//g' | grep -Ev ^server \
- | sed '1 i\server,nic_name,ip_addr,mac_addr,link,mtu,chassis_id,chassis_name,port_mac,port_descr'
-
- **Example of system output:**
-
- .. code-block:: bash
-
- server,nic_name,ip_addr,mac_addr,link,mtu,chassis_id,chassis_name,port_mac,port_descr
- cmp010.domain.com,bond0,None,b4:96:91:10:5b:3a,1,1500,,,,
- cmp010.domain.com,bond0.21,10.200.178.110,b4:96:91:10:5b:3a,1,1500,,,,
- cmp010.domain.com,bond0.22,10.200.179.110,b4:96:91:10:5b:3a,1,1500,,,,
- cmp010.domain.com,bond1,None,3c:fd:fe:34:ad:22,0,1500,,,,
- cmp010.domain.com,bond1.24,10.200.181.110,3c:fd:fe:34:ad:22,0,1500,,,,
- cmp010.domain.com,fourty5,None,3c:fd:fe:34:ad:20,0,9000,,,,
- cmp010.domain.com,fourty6,None,3c:fd:fe:34:ad:22,0,9000,,,,
- cmp010.domain.com,one1,None,b4:96:91:10:5b:38,0,1500,,,,
- cmp010.domain.com,one2,None,b4:96:91:10:5b:39,1,1500,f0:4b:3a:8f:75:40,exnfvaa18-20,548,ge-0/0/22
- cmp010.domain.com,one3,None,b4:96:91:10:5b:3a,1,1500,f0:4b:3a:8f:75:40,exnfvaa18-20,547,ge-0/0/21
- cmp010.domain.com,one4,10.200.177.110,b4:96:91:10:5b:3b,1,1500,f0:4b:3a:8f:75:40,exnfvaa18-20,546,ge-0/0/20
- cmp011.domain.com,bond0,None,b4:96:91:13:6c:aa,1,1500,,,,
- cmp011.domain.com,bond0.21,10.200.178.111,b4:96:91:13:6c:aa,1,1500,,,,
- cmp011.domain.com,bond0.22,10.200.179.111,b4:96:91:13:6c:aa,1,1500,,,,
- ...
-
- Usage
- =====
-
- Set MTU of the eth0 network interface to 1400:
-
- .. code-block:: bash
-
- ip link set dev eth0 mtu 1400
-
- Read more
- =========
-
- * https://www.archlinux.org/
- * http://askubuntu.com/questions/175172/how-do-i-configure-proxies-in-ubuntu-server-or-minimal-cli-ubuntu
-
- Documentation and Bugs
- ======================
-
- * http://salt-formulas.readthedocs.io/
- Learn how to install and update salt-formulas.
-
- * https://github.com/salt-formulas/salt-formula-linux/issues
- In the unfortunate event that bugs are discovered, report the issue to the
- appropriate issue tracker. Use the Github issue tracker for a specific salt
- formula.
-
- * https://launchpad.net/salt-formulas
- For feature requests, bug reports, or blueprints affecting the entire
- ecosystem, use the Launchpad salt-formulas project.
-
- * https://launchpad.net/~salt-formulas-users
- Join the salt-formulas-users team and subscribe to mailing list if required.
-
- * https://github.com/salt-formulas/salt-formula-linux
- Develop the salt-formulas projects in the master branch and then submit pull
- requests against a specific formula.
-
- * #salt-formulas @ irc.freenode.net
- Use this IRC channel in case of any questions or feedback which is always
- welcome.
-
|