Add mktxp
This commit is contained in:
		
							
								
								
									
										21
									
								
								argocd/applications/monitoring-mktxp.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								argocd/applications/monitoring-mktxp.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| --- | ||||
| apiVersion: argoproj.io/v1alpha1 | ||||
| kind: Application | ||||
| metadata: | ||||
|   name: monitoring-mktxp | ||||
|   namespace: argocd | ||||
| spec: | ||||
|   project: k-space.ee | ||||
|   source: | ||||
|     # also depends on git@git.k-space.ee:secretspace/kube.git | ||||
|     repoURL: git@git.k-space.ee:k-space/kube.git | ||||
|     targetRevision: HEAD | ||||
|     path: monitoring-mktxp | ||||
|   destination: | ||||
|     server: 'https://kubernetes.default.svc' | ||||
|     namespace: monitoring-mktxp | ||||
|   syncPolicy: | ||||
|     automated: | ||||
|       prune: true | ||||
|     syncOptions: | ||||
|       - CreateNamespace=true | ||||
							
								
								
									
										10
									
								
								monitoring-mktxp/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								monitoring-mktxp/README.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| # MikroTik exporter [`mktxp`](https://github.com/akpw/mktxp) | ||||
|  | ||||
| ## Deployment | ||||
| With ArgoCD. Render it locally: | ||||
|  | ||||
| ```sh | ||||
| kustomize build . | ||||
| ``` | ||||
|  | ||||
| Uses same netpoller user as mikrotik-exporter. | ||||
							
								
								
									
										33
									
								
								monitoring-mktxp/_mktxp.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								monitoring-mktxp/_mktxp.conf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| # https://github.com/akpw/mktxp/blob/main/mktxp/cli/config/_mktxp.conf | ||||
| ## Copyright (c) 2020 Arseniy Kuznetsov | ||||
| ## | ||||
| ## This program is free software; you can redistribute it and/or | ||||
| ## modify it under the terms of the GNU General Public License | ||||
| ## as published by the Free Software Foundation; either version 2 | ||||
| ## of the License, or (at your option) any later version. | ||||
| ## | ||||
| ## This program is distributed in the hope that it will be useful, | ||||
| ## but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| ## GNU General Public License for more details. | ||||
|  | ||||
| [MKTXP] | ||||
|     listen = '*:49090'         # Space separated list of socket addresses to listen to, both IPV4 and IPV6 | ||||
|     socket_timeout = 5 | ||||
|  | ||||
|     initial_delay_on_failure = 120 | ||||
|     max_delay_on_failure = 900 | ||||
|     delay_inc_div = 5 | ||||
|  | ||||
|     bandwidth = False                # Turns metrics bandwidth metrics collection on / off | ||||
|     bandwidth_test_interval = 600    # Interval for collecting bandwidth metrics | ||||
|     minimal_collect_interval = 5     # Minimal metric collection interval | ||||
|  | ||||
|     verbose_mode = False             # Set it on for troubleshooting | ||||
|  | ||||
|     fetch_routers_in_parallel = True   # Fetch metrics from multiple routers in parallel / sequentially | ||||
|     max_worker_threads = 3              # Max number of worker threads that can fetch routers (parallel fetch only) | ||||
|     max_scrape_duration = 30            # Max duration of individual routers' metrics collection (parallel fetch only) | ||||
|     total_max_scrape_duration = 90      # Max overall duration of all metrics collection (parallel fetch only) | ||||
|  | ||||
|     compact_default_conf_values = False  # Compact mktxp.conf, so only specific values are kept on the individual routers' level | ||||
							
								
								
									
										56
									
								
								monitoring-mktxp/deployment.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								monitoring-mktxp/deployment.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | ||||
| apiVersion: apps/v1 | ||||
| kind: Deployment | ||||
| metadata: | ||||
|   name: mktxp-exporter | ||||
| spec: | ||||
|   replicas: 1 | ||||
|   selector: | ||||
|     matchLabels: &selectorLabels | ||||
|       app.kubernetes.io/name: mktxp-exporter | ||||
|   template: | ||||
|     metadata: | ||||
|       labels: *selectorLabels | ||||
|     spec: | ||||
|       containers: | ||||
|       - name: mktxp-exporter | ||||
|         image: ghcr.io/akpw/mktxp:latest | ||||
|         args: | ||||
|           - --cfg-dir | ||||
|           - /mktxp-config | ||||
|           - export | ||||
|         resources: | ||||
|           limits: | ||||
|             memory: "512Mi" | ||||
|             cpu: "500m" | ||||
|         volumeMounts: | ||||
|           - name: mktxp-config | ||||
|             mountPath: /mktxp-config | ||||
|           - name: mktxp-credentials | ||||
|             mountPath: /mktxp-credentials | ||||
|         ports: | ||||
|         - containerPort: 49090 | ||||
|           name: metrics | ||||
|       volumes: | ||||
|         - name: mktxp-config | ||||
|           configMap: | ||||
|             name: mktxp-config | ||||
|         - name: mktxp-credentials | ||||
|           secret: | ||||
|             secretName: mktxp-credentials | ||||
|       nodeSelector: | ||||
|         node-role.kubernetes.io/control-plane: '' | ||||
|       tolerations: | ||||
|         - key: node-role.kubernetes.io/control-plane | ||||
|           operator: Equal | ||||
|           effect: NoSchedule | ||||
| --- | ||||
| apiVersion: monitoring.coreos.com/v1 | ||||
| kind: PodMonitor | ||||
| metadata: | ||||
|   name: mktxp-exporter | ||||
| spec: | ||||
|   selector: | ||||
|     matchLabels: | ||||
|       app.kubernetes.io/name: mktxp-exporter | ||||
|   podMetricsEndpoints: | ||||
|     - port: metrics | ||||
							
								
								
									
										14
									
								
								monitoring-mktxp/kustomization.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								monitoring-mktxp/kustomization.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| apiVersion: kustomize.config.k8s.io/v1beta1 | ||||
| kind: Kustomization | ||||
|  | ||||
| namespace: monitoring-mktxp | ||||
|  | ||||
| configMapGenerator: | ||||
|   - name: mktxp-config | ||||
|     files: | ||||
|       - _mktxp.conf | ||||
|       - mktxp.conf | ||||
|  | ||||
| resources: | ||||
|  - ./deployment.yaml #TODO: https://github.com/kubernetes-sigs/kustomize/issues/4517 make upstream PR for better/native kustomize support | ||||
|  - ssh://git@git.k-space.ee/secretspace/kube/monitoring-mktxp | ||||
							
								
								
									
										104
									
								
								monitoring-mktxp/mktxp.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								monitoring-mktxp/mktxp.conf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,104 @@ | ||||
| # https://github.com/akpw/mktxp/blob/main/mktxp/cli/config/mktxp.conf | ||||
| ## Copyright (c) 2020 Arseniy Kuznetsov | ||||
| ## | ||||
| ## This program is free software; you can redistribute it and/or | ||||
| ## modify it under the terms of the GNU General Public License | ||||
| ## as published by the Free Software Foundation; either version 2 | ||||
| ## of the License, or (at your option) any later version. | ||||
| ## | ||||
| ## This program is distributed in the hope that it will be useful, | ||||
| ## but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| ## GNU General Public License for more details. | ||||
|  | ||||
| [router] | ||||
|         hostname = 172.23.0.1 | ||||
| [sw_mgmt] | ||||
|         hostname = 172.23.0.100 | ||||
| [sw_core01] | ||||
|         hostname = 100.102.1.111 | ||||
| [sw_core02] | ||||
|         hostname = 100.102.1.112 | ||||
| [sw_server_poe] | ||||
|         hostname = 100.102.1.114 | ||||
| [sw_server_ha] | ||||
|         hostname = 100.102.1.115 | ||||
| [sw_chaos] | ||||
|         hostname = 100.102.1.121 | ||||
| [sw_kitchen] | ||||
|         hostname = 100.102.1.131 | ||||
| [sw_cyber] | ||||
|         hostname = 100.102.1.141 | ||||
| [sw_asocial] | ||||
|         hostname = 100.102.1.151 | ||||
|  | ||||
| [default] | ||||
|     # this affects configuration of all routers, unless overloaded on their specific levels | ||||
|  | ||||
|     enabled = True          # turns metrics collection for this RouterOS device on / off | ||||
|     hostname = localhost    # RouterOS IP address | ||||
|     port = 8728             # RouterOS IP Port | ||||
|  | ||||
|     username = username     # RouterOS user, needs to have 'read' and 'api' permissions | ||||
|     password = password | ||||
|     credentials_file = "/mktxp-credentials/default.yaml"   # To use an external file in YAML format for both username and password, specify the path here | ||||
|  | ||||
|     use_ssl = False                 # enables connection via API-SSL servis | ||||
|     no_ssl_certificate = False      # enables API_SSL connect without router SSL certificate | ||||
|     ssl_certificate_verify = False  # turns SSL certificate verification on / off | ||||
|     ssl_ca_file = ""                # path to the certificate authority file to validate against, leave empty to use system store | ||||
|     plaintext_login = True          # for legacy RouterOS versions below 6.43 use False | ||||
|  | ||||
|     health = True                   # System Health metrics | ||||
|     installed_packages = True       # Installed packages | ||||
|     dhcp = True                     # DHCP general metrics | ||||
|     dhcp_lease = True               # DHCP lease metrics | ||||
|  | ||||
|     connections = True              # IP connections metrics | ||||
|     connection_stats = False        # Open IP connections metrics | ||||
|  | ||||
|     interface = True                # Interfaces traffic metrics | ||||
|  | ||||
|     route = True                    # IPv4 Routes metrics | ||||
|     pool = True                     # IPv4 Pool metrics | ||||
|     firewall = False                 # IPv4 Firewall rules traffic metrics | ||||
|     neighbor = True                 # IPv4 Reachable Neighbors | ||||
|     dns = False                     # DNS stats | ||||
|  | ||||
|     ipv6_route = True              # IPv6 Routes metrics | ||||
|     ipv6_pool = True               # IPv6 Pool metrics | ||||
|     ipv6_firewall = False           # IPv6 Firewall rules traffic metrics | ||||
|     ipv6_neighbor = True           # IPv6 Reachable Neighbors | ||||
|  | ||||
|     poe = True                      # POE metrics | ||||
|     monitor = True                  # Interface monitor metrics | ||||
|     netwatch = True                 # Netwatch metrics | ||||
|     public_ip = True                # Public IP metrics | ||||
|     wireless = True                 # WLAN general metrics | ||||
|     wireless_clients = True         # WLAN clients metrics | ||||
|     capsman = True                  # CAPsMAN general metrics | ||||
|     capsman_clients = True          # CAPsMAN clients metrics | ||||
|  | ||||
|     eoip = False                    # EoIP status metrics | ||||
|     gre = False                     # GRE status metrics | ||||
|     ipip = False                    # IPIP status metrics | ||||
|     lte = False                     # LTE signal and status metrics (requires additional 'test' permission policy on RouterOS v6) | ||||
|     ipsec = False                   # IPSec active peer metrics | ||||
|     switch_port = False             # Switch Port metrics | ||||
|  | ||||
|     kid_control_assigned = False    # Allow Kid Control metrics for connected devices with assigned users | ||||
|     kid_control_dynamic = False     # Allow Kid Control metrics for all connected devices, including those without assigned user | ||||
|  | ||||
|     user = True                     # Active Users metrics | ||||
|     queue = True                    # Queues metrics | ||||
|  | ||||
|     bfd = False                     # BFD sessions metrics | ||||
|     bgp = True                     # BGP sessions metrics | ||||
|     routing_stats = True           # Routing process stats | ||||
|     certificate = False             # Certificates metrics | ||||
|  | ||||
|     remote_dhcp_entry = None        # An MKTXP entry to provide for remote DHCP info / resolution | ||||
|     remote_capsman_entry = None     # An MKTXP entry to provide for remote capsman info | ||||
|  | ||||
|     use_comments_over_names = True  # when available, forces using comments over the interfaces names | ||||
|     check_for_updates = False       # check for available ROS updates | ||||
| @@ -341,7 +341,6 @@ kind: PodMonitor | ||||
| metadata: | ||||
|   name: node-exporter | ||||
| spec: | ||||
|  | ||||
|   selector: | ||||
|     matchLabels: | ||||
|       app: node-exporter | ||||
|   | ||||
		Reference in New Issue
	
	Block a user