-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathansible.cfg
410 lines (308 loc) · 18.9 KB
/
ansible.cfg
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
# ansible will read ANSIBLE_CONFIG, ansible.cfg in the current working directory,
# .ansible.cfg in the home directory or /etc/ansible/ansible.cfg, whichever it finds first
[defaults]
inject_facts_as_vars = False
debug = False
interpreter_python = /usr/bin/python3
# set plugin path directories here, separate with colons
become_plugins ={{ ANSIBLE_HOME ~ "/plugins/become" }}
action_plugins ={{ ANSIBLE_HOME ~ "/plugins/action" }}
cache_plugins ={{ ANSIBLE_HOME ~ "/plugins/cache" }}
callback_plugins ={{ ANSIBLE_HOME ~ "/plugins/callback" }}
cliconf_plugins ={{ ANSIBLE_HOME ~ "/plugins/cliconf" }}
connection_plugins ={{ ANSIBLE_HOME ~ "/plugins/connection" }}
filter_plugins ={{ ANSIBLE_HOME ~ "/plugins/filter" }}
httpapi_plugins ={{ ANSIBLE_HOME ~ "/plugins/httpapi" }}
inventory_plugins ={{ ANSIBLE_HOME ~ "/plugins/inventory" }}
lookup_plugins ={{ ANSIBLE_HOME ~ "/plugins/lookup" }}
netconf_plugins ={{ ANSIBLE_HOME ~ "/plugins/netconf" }}
strategy_plugins ={{ ANSIBLE_HOME ~ "/plugins/strategy" }}
terminal_plugins ={{ ANSIBLE_HOME ~ "/plugins/terminal" }}
test_plugins ={{ ANSIBLE_HOME ~ "/plugins/test" }}
vars_plugins ={{ ANSIBLE_HOME ~ "/plugins/vars" }}
doc_fragment_plugins ={{ ANSIBLE_HOME ~ "/plugins/doc_fragments" }}
fact_path = ~/ansible/facts.d
inventory = ~/ansible/inventory
library = ~/ansible/my_modules
module_utils = ~/ansible/my_module_utils
local_tmp = ~/ansible/tmp
remote_tmp = ~/.ansible/tmp
# additional paths to search for roles in, colon separated
roles_path = ~/ansible/roles
collections_path = ~/ansible
collections_scan_sys_path = False
#fact_caching = ansible.builtin.jsonfile
#fact_caching_connection = ~/ansible/facts
fact_caching = community.general.redis
fact_caching_connection = localhost:6379:0:
###################################
# prefix for ansible facts
# fact_caching_prefix = ""
fact_caching_prefix =
# 10 day expiration time for facts
fact_caching_timeout = 864000
###################################
transport = ssh
forks = 30
remote_port = 60000
remote_user = root
# if set, always use this private key file for authentication, same as if passing --private-key to ansible or ansible-playbook
private_key_file = ~/.ssh/id_ed25519
#poll_interval = 15
#sudo_user = root
#ask_sudo_pass = True
#ask_pass = True
#module_lang = C
#module_set_locale = False
# plays will gather facts by default, which contain information about the remote system.
# smart - gather by default, but don't regather if already gathered
# implicit - gather by default, turn off with gather_facts: False
# explicit - do not gather by default, must say gather_facts: True
gathering = smart
# This only affects the gathering done by a play's gather_facts directive, by default gathering retrieves all facts subsets
# all - gather all subsets
# network - gather min and network facts
# hardware - gather hardware facts (longest facts to retrieve)
# virtual - gather min and virtual facts
# facter - import facts from facter
# ohai - import facts from ohai
# You can combine them using comma (ex: network,virtual); You can negate them using ! (ex: !hardware,!facter,!ohai); A minimal set of facts is always gathered.
gather_subset = all,!facter,!ohai
# some hardware related facts are collected with a maximum timeout of 10 seconds.
# This option lets you increase or decrease that timeout to something more suitable for the environment.
gather_timeout = 30
# uncomment this to disable SSH key host checking
host_key_checking = False
# Use the stdout_callback when running ad-hoc commands.
bin_ansible_callbacks = True
# enable callback plugins, they can output to stdout but cannot be 'stdout' type.
callback_whitelist = ansible.builtin.default, ansible.builtin.minimal, ansible.posix.debug, ansible.posix.profile_tasks, ansible.posix.profile_roles, ansible.posix.timer, community.general.dense
# (list) List of enabled callbacks, not all callbacks need enabling, but many of those shipped with Ansible do as we don't want them activated by default.
# ansible.builtin.minimal
# ansible.builtin.tree
# ansible.posix.json
# ansible.posix.profile_tasks
# ansible.posix.profile_roles
# ansible.posix.timer
# community.general.dense
# community.general.log_plays
callbacks_enabled = ansible.builtin.default, ansible.posix.debug, ansible.posix.profile_tasks, ansible.posix.profile_roles
# change the default callback, you can only have one 'stdout' type enabled at a time. see: ansible-doc -t callback -l
show_task_path_on_failure = True
stdout_callback = ansible.builtin.default
## Ansible ships with some plugins that require whitelisting, this is done to avoid running all of a type by default.
## These setting lists those that you want enabled for your system. Custom plugins should not need this unless plugin author specifies it.
# Determine whether includes in tasks and handlers are "static" by default. As of 2.0, includes are dynamic by default.
# Setting these values to True will make includes behave more like they did in the 1.x versions.
#task_includes_static = True
#handler_includes_static = True
# Controls if a missing handler for a notification event is an error or a warning
#error_on_missing_handler = True
# change this for alternative sudo implementations
#sudo_exe = sudo
# What flags to pass to sudo !!!WARNING: leaving out the defaults might create unexpected behaviours
#sudo_flags = -H -S -n
# SSH timeout
timeout = 10
# logging is off by default unless this path is defined; if so defined, consider logrotate
# log_path = ~/ansible/ansible.log
# default module name for /usr/bin/ansible
#module_name = command
# use this shell for commands executed under sudo; you may need to change this to bin/bash in rare instances if sudo is constrained
executable = /bin/bash
# if inventory variables overlap, does the higher precedence one win or are hash values merged together?
# The default is 'replace' but this can also be set to 'merge'.
hash_behaviour = replace
# by default, variables from roles will be visible in the global variable scope.
# To prevent this, the following option can be enabled, and only tasks and handlers within the role will see the variables there
#private_role_vars = yes
# list any Jinja2 extensions to enable here:
#jinja2_extensions = jinja2.ext.do,jinja2.ext.i18n
jinja2_extensions = jinja2.ext.do,jinja2.ext.loopcontrols,jinja2.ext.debug
# If set, configures the path to the Vault password file as an alternative to specifying --vault-password-file on the command line.
vault_password_file = ~/.ssh/id_ed25519
# format of string {{ ansible_managed }} available within Jinja2 templates indicates to users editing templates files will be replaced.
# replacing {file}, {host} and {uid} and strftime codes with proper values.
# {file}, {host}, {uid}, and the timestamp can all interfere with idempotence in some situations so the default is a static string
#ansible_managed = Ansible managed: {file} modified on %Y-%m-%d %H:%M:%S by {uid} on {host}
ansible_managed = !!!ANSIBLE MANAGED {file}/{host}!!!
# by default, ansible-playbook will display "Skipping [host]" if it determines a task should not be run on a host.
# Set this to "False" if you don't want to see these "Skipping" messages. NOTE: the task header will still be shown regardless of whether or not the task is skipped.
display_skipped_hosts = False
# by default, if a task in a playbook does not include a name: field then ansible-playbook will construct a header that includes the task's action but
# not the task's args. This is a security feature because ansible cannot know if the *module* considers an argument to be no_log at the time that the
# header is printed. If your environment doesn't have a problem securing stdout from ansible-playbook (or you have manually specified no_log in your
# playbook on all of the tasks where you have secret information) then you can safely set this to True to get more informative messages.
display_args_to_stdout = False
# by default (as of 1.3), Ansible will raise errors when attempting to dereference Jinja2 variables that are not set in templates or action lines.
# Uncomment this line to revert the behavior to pre-1.3.
#error_on_undefined_vars = False
# by default (as of 1.6), Ansible may display warnings based on the configuration of the system running ansible itself.
# This may include warnings about 3rd party packages or other conditions that should be resolved if possible. to disable these warnings, set the following value to False:
system_warnings = True
# by default (as of 1.4), Ansible may display deprecation warnings for language features that should no longer be used and will be removed in future versions.
# to disable these warnings, set the following value to False:
deprecation_warnings = False
# (as of 1.8), Ansible can optionally warn when usage of the shell and command module appear to be simplified by using a default Ansible module instead.
# These warnings can be silenced by adjusting the following setting or adding warn=yes or warn=no to the end of the command line parameter string.
# This will for example suggest using the git module instead of shelling out to the git command.
command_warnings = True
# by default, ansible will use the 'linear' strategy but you may want to try another one
# ansible-doc -t strategy -l to see the list of available plugins.
# ansible-doc -t strategy <plugin name> to see plugin-specific specific documentation and examples.
strategy = linear
# don't like cows? that's unfortunate. set to 1 if you don't want cowsay support or export ANSIBLE_NOCOWS=1
nocows = 1
# don't like colors either? set to 1 if you don't want colors, or export ANSIBLE_NOCOLOR=1
nocolor = 1
# retry files; When a playbook fails by default a .retry file will be created in ~/
# You can disable this feature by setting retry_files_enabled to False
# and you can change the location of the files by setting retry_files_save_path
retry_files_enabled = False
retry_files_save_path = ~/ansible/ansible-retry
# prevents logging of task data, off by default
no_log = False
# prevents logging of tasks, but only on the targets, data is still logged on the master/controller
no_target_syslog = False
# controls whether Ansible will raise an error or warning if a task has no choice but to create world readable temporary files to execute a module on
# the remote machine. This option is False by default for security. Users may turn this on to have behaviour more like Ansible prior to 2.1.x. See
# https://docs.ansible.com/ansible/become.html#becoming-an-unprivileged-user for more secure ways to fix this than enabling this option.
allow_world_readable_tmpfiles = True
# controls the compression level of variables sent to worker processes. At the default of 0, no compression is used. This value must be an integer from 0 to 9.
#var_compression_level = 9
# controls what compression method is used for new-style ansible modules when they are sent to the remote system. The compression types depend on having
# support compiled into both the controller's python and the client's python. The names should match with the python Zipfile compression types:
# * ZIP_STORED (no compression. available everywhere)
# * ZIP_DEFLATED (uses zlib, the default)
# These values may be set per host via the ansible_module_compression inventory variable
#module_compression = 'ZIP_DEFLATED'
# This controls the cutoff point (in bytes) on --diff for files set to 0 for unlimited (RAM may suffer!).
#max_diff_size = 1048576
# This controls how ansible handles multiple --tags and --skip-tags arguments on the CLI. If this is True then multiple arguments are merged together. If
# it is False, then the last specified argument is used and the others are ignored. This option will be removed in 2.8.
#merge_multiple_cli_flags = True
# Controls showing custom stats at the end, off by default
#show_custom_stats = True
# Controls which files to ignore when using a directory as inventory with possibly multiple sources (both static and dynamic)
#inventory_ignore_extensions = ~, .orig, .bak, .ini, .cfg, .retry, .pyc, .pyo
# This family of modules use an alternative execution path optimized for network appliances only update this setting if you know how this works, otherwise it can break module execution
#network_group_modules=['eos', 'nxos', 'ios', 'iosxr', 'junos', 'vyos']
# When enabled, this option allows lookups (via variables like {{lookup('foo')}} or when used as a loop with `with_foo`) to return data that is not marked "unsafe".
# This means the data may contain jinja2 templating language which will be run through the templating engine. ENABLING THIS COULD BE A SECURITY RISK
#allow_unsafe_lookups = False
# set default errors for all plays
#any_errors_fatal = False
[inventory]
## enable_plugins = ini, yaml, host_list, script, auto
enable_plugins = ini, host_list
cache = True
# cache_plugin = ansible.builtin.memory
cache_plugin = ansible.builtin.jsonfile
caching_connection = /home/adrian/ansible/inventory_cache/
# ignore these extensions when parsing a directory as inventory source
#ignore_extensions = .pyc, .pyo, .swp, .bak, ~, .rpm, .md, .txt, ~, .orig, .ini, .cfg, .retry
# ignore files matching these patterns when parsing a directory as inventory source
#ignore_patterns=
# If 'true' unparsed inventory sources become fatal errors, they are warnings otherwise.
unparsed_is_failed = True
[privilege_escalation]
#become=True
#become_method=sudo
#become_user=root
#become_ask_pass=False
[paramiko_connection]
# uncomment this line to cause the paramiko connection plugin to not record new host keys encountered. Increases performance on new host additions. Setting works independently of the host key checking setting above.
#record_host_keys=False
# by default, Ansible requests a pseudo-terminal for commands executed under sudo. Uncomment this line to disable this behaviour.
#pty=False
# paramiko will default to looking for SSH keys initially when trying to authenticate to remote devices. This is a problem for some network devices
# that close the connection after a key failure. Uncomment this line to disable the Paramiko look for keys function
#look_for_keys = False
# When using persistent connections with Paramiko, the connection runs in a background process. If the host doesn't already have a valid SSH key, by
# default Ansible will prompt to add the host key. This will cause connections running in background processes to fail. Uncomment this line to have Paramiko automatically add host keys.
host_key_auto_add = True
[ssh_connection]
# ssh arguments to use
# Leaving off ControlPersist will result in poor performance, so use paramiko on older platforms rather than removing it, -C controls compression use
##ssh_args = -C -o ControlMaster=auto -o ControlPersist=120 -o ServerAliveInterval=30 -o ServerAliveCountMax=5 -o ConnectionAttempts=5 -o PreferredAuthentications=publickey
## ssh_args =-C -o PreferredAuthentications=publickey -o ServerAliveInterval=50 -o ServerAliveCountMax=5 -o ConnectionAttempts=5
ssh_args = -F /home/adrian/ansible/config.ansible
# Common extra args for all ssh CLI tools
ssh_common_args =
# Extra exclusive to the 'ssh' CLI
ssh_extra_args =
# The base directory for the ControlPath sockets. This is the "%(directory)s" in the control_path option. Example:
control_path_dir = /tmp
# The path to use for the ControlPath sockets. This defaults to a hashed string of the hostname, port and username (empty string in the config).
control_path = %(directory)s/ans_%%i_%%C.sshsock
# Enabling pipelining reduces the number of SSH operations required to execute a module on the remote server. This can result in a significant
# performance improvement when enabled, however when using "sudo:" you must first disable 'requiretty' in /etc/sudoers
# By default, this option is disabled to preserve compatibility with sudoers configurations that have requiretty (the default on many distros).
pipelining = False
# add -tt to ssh commands to force tty allocation
usetty = no
# Control the mechanism for transferring files (old)
# * smart = try sftp and then try scp [default]
# * True = use scp only
# * False = use sftp only
scp_if_ssh = smart
# Control the mechanism for transferring files (new)
# If set, this will override the scp_if_ssh option
# * sftp = use sftp to transfer files
# * scp = use scp to transfer files
# * piped = use 'dd' over SSH to transfer files
# * smart = try sftp, scp, and piped, in that order [default]
transfer_method = smart
# If False, sftp will not use batch mode to transfer files.
# This may cause some types of file transfer failures impossible to catch however, and should only be disabled if your sftp version has problems with batch mode
#sftp_batch_mode = False
# Number of attempts to connect.
retries = 2
[persistent_connection]
# Configures the persistent connection timeout value in seconds. This value is how long the persistent connection will remain idle before it is destroyed.
# If the connection doesn't receive a request before the timeout value expires, the connection is shutdown. The default value is 30 seconds.
connect_timeout = 30
# Configures the persistent connection retry timeout. This value configures the the retry timeout that ansible-connection will wait to connect
# to the local domain socket. This value must be larger than the ssh timeout (timeout) and less than persistent connection idle timeout (connect_timeout). The default value is 15 seconds.
connect_retry_timeout = 15
# The command timeout value defines the amount of time to wait for a command or RPC call before timing out. The value for the command timeout must
# be less than the value of the persistent connection idle timeout (connect_timeout) The default value is 10 second.
command_timeout = 10
[accelerate]
#accelerate_port = 5099
#accelerate_timeout = 30
#accelerate_connect_timeout = 5.0
# The daemon timeout is measured in minutes. This time is measured from the last activity to the accelerate daemon.
#accelerate_daemon_timeout = 30
# If set to yes, accelerate_multi_key will allow multiple private keys to be uploaded to it, though each user must have access to the system via SSH to add a new key. The default is "no".
#accelerate_multi_key = yes
[selinux]
# file systems that require special treatment when dealing with security context the default behaviour that copies the existing context or uses the user default
# needs to be changed to use the file system dependent context.
#special_context_filesystems=nfs,vboxsf,fuse,ramfs,9p
# Set this to yes to allow libvirt_lxc connections to work without SELinux.
#libvirt_lxc_noseclabel = yes
[colors]
#highlight = white
#verbose = blue
#warn = bright purple
#error = red
#debug = dark gray
#deprecate = purple
#skip = cyan
#unreachable = red
#ok = green
#changed = yellow
#diff_add = green
#diff_remove = red
#diff_lines = cyan
[diff]
# Always print diff when running ( same as always running with -D/--diff )
# always = no
# Set how many context lines to show in diff
# context = 3
[galaxy]
cache_dir = ~/ansible/galaxy_cache
token_path = ~/ansible/galaxy_token
[callback_log_plays]
log_folder = /home/adrian/ansible/host_logs