grafana-config.yml.j2 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387
  1. ##################### Grafana Configuration Defaults #####################
  2. #
  3. # Do not modify this file in grafana installs
  4. #
  5. # possible values : production, development
  6. app_mode = production
  7. # instance name, defaults to HOSTNAME environment variable value or hostname if HOSTNAME var is empty
  8. instance_name = ${HOSTNAME}
  9. #################################### Paths ###############################
  10. [paths]
  11. # Path to where grafana can store temp files, sessions, and the sqlite3 db (if that is used)
  12. #
  13. data = data
  14. #
  15. # Directory where grafana can store logs
  16. #
  17. logs = data/log
  18. #
  19. # Directory where grafana will automatically scan and look for plugins
  20. #
  21. plugins = data/plugins
  22. #################################### Server ##############################
  23. [server]
  24. # Protocol (http, https, socket)
  25. protocol = http
  26. # The ip address to bind to, empty will bind to all interfaces
  27. http_addr =
  28. # The http port to use
  29. http_port = 3000
  30. # The public facing domain name used to access grafana from a browser
  31. domain = localhost
  32. # Redirect to correct domain if host header does not match domain
  33. # Prevents DNS rebinding attacks
  34. enforce_domain = false
  35. # The full public facing url
  36. root_url = %(protocol)s://%(domain)s:%(http_port)s/
  37. # Log web requests
  38. router_logging = false
  39. # the path relative working path
  40. static_root_path = public
  41. # enable gzip
  42. enable_gzip = false
  43. # https certs & key file
  44. cert_file = /etc/tls/private/tls.crt
  45. cert_key = /etc/tls/private/tls.key
  46. # Unix socket path
  47. socket = /tmp/grafana.sock
  48. #################################### Database ############################
  49. [database]
  50. # You can configure the database connection by specifying type, host, name, user and password
  51. # as separate properties or as on string using the url property.
  52. # Either "mysql", "postgres" or "sqlite3", it's your choice
  53. type = sqlite3
  54. host = 127.0.0.1:3306
  55. name = grafana
  56. user = root
  57. # If the password contains # or ; you have to wrap it with triple quotes. Ex """#password;"""
  58. password =
  59. # Use either URL or the previous fields to configure the database
  60. # Example: mysql://user:secret@host:port/database
  61. url =
  62. # Max idle conn setting default is 2
  63. max_idle_conn = 2
  64. # Max conn setting default is 0 (mean not set)
  65. max_open_conn =
  66. # For "postgres", use either "disable", "require" or "verify-full"
  67. # For "mysql", use either "true", "false", or "skip-verify".
  68. ssl_mode = disable
  69. ca_cert_path =
  70. client_key_path =
  71. client_cert_path =
  72. server_cert_name =
  73. # For "sqlite3" only, path relative to data_path setting
  74. path = grafana.db
  75. #################################### Session #############################
  76. [session]
  77. # Either "memory", "file", "redis", "mysql", "postgres", "memcache", default is "file"
  78. provider = file
  79. # Provider config options
  80. # memory: not have any config yet
  81. # file: session dir path, is relative to grafana data_path
  82. # redis: config like redis server e.g. `addr=127.0.0.1:6379,pool_size=100,db=grafana`
  83. # postgres: user=a password=b host=localhost port=5432 dbname=c sslmode=disable
  84. # mysql: go-sql-driver/mysql dsn config string, examples:
  85. # `user:password@tcp(127.0.0.1:3306)/database_name`
  86. # `user:password@unix(/var/run/mysqld/mysqld.sock)/database_name`
  87. # memcache: 127.0.0.1:11211
  88. provider_config = sessions
  89. # Session cookie name
  90. cookie_name = grafana_sess
  91. # If you use session in https only, default is false
  92. cookie_secure = false
  93. # Session life time, default is 86400
  94. session_life_time = 86400
  95. gc_interval_time = 86400
  96. #################################### Data proxy ###########################
  97. [dataproxy]
  98. # This enables data proxy logging, default is false
  99. logging = false
  100. #################################### Analytics ###########################
  101. [analytics]
  102. # Server reporting, sends usage counters to stats.grafana.org every 24 hours.
  103. # No ip addresses are being tracked, only simple counters to track
  104. # running instances, dashboard and error counts. It is very helpful to us.
  105. # Change this option to false to disable reporting.
  106. reporting_enabled = true
  107. # Set to false to disable all checks to https://grafana.com
  108. # for new versions (grafana itself and plugins), check is used
  109. # in some UI views to notify that grafana or plugin update exists
  110. # This option does not cause any auto updates, nor send any information
  111. # only a GET request to https://grafana.com to get latest versions
  112. check_for_updates = true
  113. # Google Analytics universal tracking code, only enabled if you specify an id here
  114. google_analytics_ua_id =
  115. # Google Tag Manager ID, only enabled if you specify an id here
  116. google_tag_manager_id =
  117. #################################### Security ############################
  118. [security]
  119. # default admin user, created on startup
  120. admin_user = admin
  121. # default admin password, can be changed before first start of grafana, or in profile settings
  122. admin_password = admin
  123. # used for signing
  124. secret_key = SW2YcwTIb9zpOOhoPsMm
  125. # Auto-login remember days
  126. login_remember_days = 7
  127. cookie_username = grafana_user
  128. cookie_remember_name = grafana_remember
  129. # disable gravatar profile images
  130. disable_gravatar = false
  131. # data source proxy whitelist (ip_or_domain:port separated by spaces)
  132. data_source_proxy_whitelist =
  133. [snapshots]
  134. # snapshot sharing options
  135. external_enabled = true
  136. external_snapshot_url = https://snapshots-origin.raintank.io
  137. external_snapshot_name = Publish to snapshot.raintank.io
  138. # remove expired snapshot
  139. snapshot_remove_expired = true
  140. # remove snapshots after 90 days
  141. snapshot_TTL_days = 90
  142. #################################### Users ####################################
  143. [users]
  144. # disable user signup / registration
  145. allow_sign_up = true
  146. # Allow non admin users to create organizations
  147. allow_org_create = true
  148. # Set to true to automatically assign new users to the default organization (id 1)
  149. auto_assign_org = true
  150. # Default role new users will be automatically assigned (if auto_assign_org above is set to true)
  151. auto_assign_org_role = Admin
  152. # Require email validation before sign up completes
  153. verify_email_enabled = false
  154. # Background text for the user field on the login page
  155. login_hint = email or username
  156. # Default UI theme ("dark" or "light")
  157. default_theme = dark
  158. # External user management
  159. external_manage_link_url =
  160. external_manage_link_name =
  161. external_manage_info =
  162. [auth]
  163. # Set to true to disable (hide) the login form, useful if you use OAuth
  164. disable_login_form = true
  165. # Set to true to disable the signout link in the side menu. useful if you use auth.proxy
  166. disable_signout_menu = true
  167. #################################### Anonymous Auth ######################
  168. [auth.anonymous]
  169. # enable anonymous access
  170. enabled = true
  171. # specify organization name that should be used for unauthenticated users
  172. org_name = Main Org.
  173. # specify role for unauthenticated users
  174. org_role = Admin
  175. #################################### Github Auth #########################
  176. [auth.github]
  177. enabled = false
  178. allow_sign_up = true
  179. client_id = some_id
  180. client_secret = some_secret
  181. scopes = user:email
  182. auth_url = https://github.com/login/oauth/authorize
  183. token_url = https://github.com/login/oauth/access_token
  184. api_url = https://api.github.com/user
  185. team_ids =
  186. allowed_organizations =
  187. #################################### Google Auth #########################
  188. [auth.google]
  189. enabled = false
  190. allow_sign_up = true
  191. client_id = some_client_id
  192. client_secret = some_client_secret
  193. scopes = https://www.googleapis.com/auth/userinfo.profile https://www.googleapis.com/auth/userinfo.email
  194. auth_url = https://accounts.google.com/o/oauth2/auth
  195. token_url = https://accounts.google.com/o/oauth2/token
  196. api_url = https://www.googleapis.com/oauth2/v1/userinfo
  197. allowed_domains =
  198. hosted_domain =
  199. #################################### Grafana.com Auth ####################
  200. # legacy key names (so they work in env variables)
  201. [auth.grafananet]
  202. enabled = false
  203. allow_sign_up = true
  204. client_id = some_id
  205. client_secret = some_secret
  206. scopes = user:email
  207. allowed_organizations =
  208. [auth.grafana_com]
  209. enabled = false
  210. allow_sign_up = true
  211. client_id = some_id
  212. client_secret = some_secret
  213. scopes = user:email
  214. allowed_organizations =
  215. #################################### Generic OAuth #######################
  216. [auth.generic_oauth]
  217. name = OAuth
  218. enabled = false
  219. allow_sign_up = true
  220. client_id = some_id
  221. client_secret = some_secret
  222. scopes = user:email
  223. auth_url =
  224. token_url =
  225. api_url =
  226. team_ids =
  227. allowed_organizations =
  228. #################################### Basic Auth ##########################
  229. [auth.basic]
  230. enabled = false
  231. #################################### Auth Proxy ##########################
  232. [auth.proxy]
  233. enabled = true
  234. header_name = X-WEBAUTH-USER
  235. header_property = username
  236. auto_sign_up = true
  237. ldap_sync_ttl = 60
  238. whitelist =
  239. #################################### Auth LDAP ###########################
  240. [auth.ldap]
  241. enabled = false
  242. config_file = /etc/grafana/ldap.toml
  243. allow_sign_up = true
  244. #################################### SMTP / Emailing #####################
  245. [smtp]
  246. enabled = false
  247. host = localhost:25
  248. user =
  249. # If the password contains # or ; you have to wrap it with trippel quotes. Ex """#password;"""
  250. password =
  251. cert_file =
  252. key_file =
  253. skip_verify = false
  254. from_address = admin@grafana.localhost
  255. from_name = Grafana
  256. ehlo_identity =
  257. [emails]
  258. welcome_email_on_sign_up = false
  259. templates_pattern = emails/*.html
  260. #################################### Logging ##########################
  261. [log]
  262. # Either "console", "file", "syslog". Default is console and file
  263. # Use space to separate multiple modes, e.g. "console file"
  264. mode = console file
  265. # Either "debug", "info", "warn", "error", "critical", default is "info"
  266. level = error
  267. # optional settings to set different levels for specific loggers. Ex filters = sqlstore:debug
  268. filters =
  269. # For "console" mode only
  270. [log.console]
  271. level =
  272. # log line format, valid options are text, console and json
  273. format = console
  274. # For "file" mode only
  275. [log.file]
  276. level =
  277. # log line format, valid options are text, console and json
  278. format = text
  279. # This enables automated log rotate(switch of following options), default is true
  280. log_rotate = true
  281. # Max line number of single file, default is 1000000
  282. max_lines = 1000000
  283. # Max size shift of single file, default is 28 means 1 << 28, 256MB
  284. max_size_shift = 28
  285. # Segment log daily, default is true
  286. daily_rotate = true
  287. # Expired days of log file(delete after max days), default is 7
  288. max_days = 7
  289. [log.syslog]
  290. level =
  291. # log line format, valid options are text, console and json
  292. format = text
  293. # Syslog network type and address. This can be udp, tcp, or unix. If left blank, the default unix endpoints will be used.
  294. network =
  295. address =
  296. # Syslog facility. user, daemon and local0 through local7 are valid.
  297. facility =
  298. # Syslog tag. By default, the process' argv[0] is used.
  299. tag =
  300. #################################### AMQP Event Publisher ################
  301. [event_publisher]
  302. enabled = false
  303. rabbitmq_url = amqp://localhost/
  304. exchange = grafana_events
  305. #################################### Dashboard JSON files ################
  306. [dashboards.json]
  307. enabled = false
  308. path = /var/lib/grafana/dashboards
  309. #################################### Usage Quotas ########################
  310. [quota]
  311. enabled = false
  312. #### set quotas to -1 to make unlimited. ####
  313. # limit number of users per Org.
  314. org_user = 10
  315. # limit number of dashboards per Org.
  316. org_dashboard = 100
  317. # limit number of data_sources per Org.
  318. org_data_source = 10
  319. # limit number of api_keys per Org.
  320. org_api_key = 10
  321. # limit number of orgs a user can create.
  322. user_org = 10
  323. # Global limit of users.
  324. global_user = -1
  325. # global limit of orgs.
  326. global_org = -1
  327. # global limit of dashboards
  328. global_dashboard = -1
  329. # global limit of api_keys
  330. global_api_key = -1
  331. # global limit on number of logged in users.
  332. global_session = -1
  333. #################################### Alerting ############################
  334. [alerting]
  335. # Disable alerting engine & UI features
  336. enabled = true
  337. # Makes it possible to turn off alert rule execution but alerting UI is visible
  338. execute_alerts = true
  339. #################################### Internal Grafana Metrics ############
  340. # Metrics available at HTTP API Url /api/metrics
  341. [metrics]
  342. enabled = true
  343. interval_seconds = 10
  344. # Send internal Grafana metrics to graphite
  345. [metrics.graphite]
  346. # Enable by setting the address setting (ex localhost:2003)
  347. address =
  348. prefix = prod.grafana.%(instance_name)s.
  349. [grafana_net]
  350. url = https://grafana.com
  351. [grafana_com]
  352. url = https://grafana.com
  353. #################################### Distributed tracing ############
  354. [tracing.jaeger]
  355. # jaeger destination (ex localhost:6831)
  356. address =
  357. # tag that will always be included in when creating new spans. ex (tag1:value1,tag2:value2)
  358. always_included_tag =
  359. # Type specifies the type of the sampler: const, probabilistic, rateLimiting, or remote
  360. sampler_type = const
  361. # jaeger samplerconfig param
  362. # for "const" sampler, 0 or 1 for always false/true respectively
  363. # for "probabilistic" sampler, a probability between 0 and 1
  364. # for "rateLimiting" sampler, the number of spans per second
  365. # for "remote" sampler, param is the same as for "probabilistic"
  366. # and indicates the initial sampling rate before the actual one
  367. # is received from the mothership
  368. sampler_param = 1
  369. #################################### External Image Storage ##############
  370. [external_image_storage]
  371. # You can choose between (s3, webdav, gcs)
  372. provider =
  373. [external_image_storage.s3]
  374. bucket_url =
  375. bucket =
  376. region =
  377. path =
  378. access_key =
  379. secret_key =
  380. [external_image_storage.webdav]
  381. url =
  382. username =
  383. password =
  384. public_url =
  385. [external_image_storage.gcs]
  386. key_file =
  387. bucket =