clean up and finish aerospike refactor & readme
This commit is contained in:
		
							parent
							
								
									0be69b8a44
								
							
						
					
					
						commit
						5f14ad9fa1
					
				
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							|  | @ -72,18 +72,17 @@ func (a *Aerospike) gatherServer(hostport string, acc telegraf.Accumulator) erro | |||
| 	nodes := c.GetNodes() | ||||
| 	for _, n := range nodes { | ||||
| 		tags := map[string]string{ | ||||
| 			"node_name":      n.GetName(), | ||||
| 			"aerospike_host": hostport, | ||||
| 		} | ||||
| 		fields := make(map[string]interface{}) | ||||
| 		fields := map[string]interface{}{ | ||||
| 			"node_name": n.GetName(), | ||||
| 		} | ||||
| 		stats, err := as.RequestNodeStats(n) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		for k, v := range stats { | ||||
| 			if iv, err := strconv.ParseInt(v, 10, 64); err == nil { | ||||
| 				fields[strings.Replace(k, "-", "_", -1)] = iv | ||||
| 			} | ||||
| 			fields[strings.Replace(k, "-", "_", -1)] = parseValue(v) | ||||
| 		} | ||||
| 		acc.AddFields("aerospike_node", fields, tags, time.Now()) | ||||
| 
 | ||||
|  | @ -94,9 +93,13 @@ func (a *Aerospike) gatherServer(hostport string, acc telegraf.Accumulator) erro | |||
| 		namespaces := strings.Split(info["namespaces"], ";") | ||||
| 
 | ||||
| 		for _, namespace := range namespaces { | ||||
| 			nTags := copyTags(tags) | ||||
| 			nTags := map[string]string{ | ||||
| 				"aerospike_host": hostport, | ||||
| 			} | ||||
| 			nTags["namespace"] = namespace | ||||
| 			nFields := make(map[string]interface{}) | ||||
| 			nFields := map[string]interface{}{ | ||||
| 				"node_name": n.GetName(), | ||||
| 			} | ||||
| 			info, err := as.RequestNodeInfo(n, "namespace/"+namespace) | ||||
| 			if err != nil { | ||||
| 				continue | ||||
|  | @ -107,9 +110,7 @@ func (a *Aerospike) gatherServer(hostport string, acc telegraf.Accumulator) erro | |||
| 				if len(parts) < 2 { | ||||
| 					continue | ||||
| 				} | ||||
| 				if iv, err := strconv.ParseInt(parts[1], 10, 64); err == nil { | ||||
| 					nFields[strings.Replace(parts[0], "-", "_", -1)] = iv | ||||
| 				} | ||||
| 				nFields[strings.Replace(parts[0], "-", "_", -1)] = parseValue(parts[1]) | ||||
| 			} | ||||
| 			acc.AddFields("aerospike_namespace", nFields, nTags, time.Now()) | ||||
| 		} | ||||
|  | @ -117,6 +118,16 @@ func (a *Aerospike) gatherServer(hostport string, acc telegraf.Accumulator) erro | |||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func parseValue(v string) interface{} { | ||||
| 	if parsed, err := strconv.ParseInt(v, 10, 64); err == nil { | ||||
| 		return parsed | ||||
| 	} else if parsed, err := strconv.ParseBool(v); err == nil { | ||||
| 		return parsed | ||||
| 	} else { | ||||
| 		return v | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func copyTags(m map[string]string) map[string]string { | ||||
| 	out := make(map[string]string) | ||||
| 	for k, v := range m { | ||||
|  |  | |||
|  | @ -1,18 +1,18 @@ | |||
| # Ceph Storage Input Plugin | ||||
| 
 | ||||
| Collects performance metrics from the MON and OSD nodes in a Ceph storage cluster.   | ||||
| Collects performance metrics from the MON and OSD nodes in a Ceph storage cluster. | ||||
| 
 | ||||
| The plugin works by scanning the configured SocketDir for OSD and MON socket files.  When it finds | ||||
| a MON socket, it runs **ceph --admin-daemon $file perfcounters_dump**. For OSDs it runs **ceph --admin-daemon $file perf dump**  | ||||
| a MON socket, it runs **ceph --admin-daemon $file perfcounters_dump**. For OSDs it runs **ceph --admin-daemon $file perf dump** | ||||
| 
 | ||||
| The resulting JSON is parsed and grouped into collections, based on top-level key.  Top-level keys are | ||||
| used as collection tags, and all sub-keys are flattened. For example: | ||||
| 
 | ||||
| ``` | ||||
|  {  | ||||
|    "paxos": {  | ||||
|  { | ||||
|    "paxos": { | ||||
|      "refresh": 9363435, | ||||
|      "refresh_latency": {  | ||||
|      "refresh_latency": { | ||||
|        "avgcount": 9363435, | ||||
|        "sum": 5378.794002000 | ||||
|      } | ||||
|  | @ -50,7 +50,7 @@ Would be parsed into the following metrics, all of which would be tagged with co | |||
| 
 | ||||
| ### Measurements & Fields: | ||||
| 
 | ||||
| All fields are collected under the **ceph** measurement and stored as float64s. For a full list of fields, see the sample perf dumps in ceph_test.go.  | ||||
| All fields are collected under the **ceph** measurement and stored as float64s. For a full list of fields, see the sample perf dumps in ceph_test.go. | ||||
| 
 | ||||
| 
 | ||||
| ### Tags: | ||||
|  | @ -95,7 +95,7 @@ All measurements will have the following tags: | |||
|     - throttle-objecter_ops | ||||
|     - throttle-osd_client_bytes | ||||
|     - throttle-osd_client_messages | ||||
|   | ||||
| 
 | ||||
| 
 | ||||
| ### Example Output: | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue