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: | metadata: | ||||||
|   name: node-exporter |   name: node-exporter | ||||||
| spec: | spec: | ||||||
|  |  | ||||||
|   selector: |   selector: | ||||||
|     matchLabels: |     matchLabels: | ||||||
|       app: node-exporter |       app: node-exporter | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user