* update github.com/alecthomas/chroma v0.8.0 -> v0.8.1 * github.com/blevesearch/bleve v1.0.10 -> v1.0.12 * editorconfig-core-go v2.1.1 -> v2.3.7 * github.com/gliderlabs/ssh v0.2.2 -> v0.3.1 * migrate editorconfig.ParseBytes to Parse * github.com/shurcooL/vfsgen to 0d455de96546 * github.com/go-git/go-git/v5 v5.1.0 -> v5.2.0 * github.com/google/uuid v1.1.1 -> v1.1.2 * github.com/huandu/xstrings v1.3.0 -> v1.3.2 * github.com/klauspost/compress v1.10.11 -> v1.11.1 * github.com/markbates/goth v1.61.2 -> v1.65.0 * github.com/mattn/go-sqlite3 v1.14.0 -> v1.14.4 * github.com/mholt/archiver v3.3.0 -> v3.3.2 * github.com/microcosm-cc/bluemonday 4f7140c49acb -> v1.0.4 * github.com/minio/minio-go v7.0.4 -> v7.0.5 * github.com/olivere/elastic v7.0.9 -> v7.0.20 * github.com/urfave/cli v1.20.0 -> v1.22.4 * github.com/prometheus/client_golang v1.1.0 -> v1.8.0 * github.com/xanzy/go-gitlab v0.37.0 -> v0.38.1 * mvdan.cc/xurls v2.1.0 -> v2.2.0 Co-authored-by: Lauris BH <lauris@nix.lv>
		
			
				
	
	
		
			119 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| // Copyright 2019 The Prometheus Authors
 | |
| // Licensed under the Apache License, Version 2.0 (the "License");
 | |
| // you may not use this file except in compliance with the License.
 | |
| // You may obtain a copy of the License at
 | |
| //
 | |
| // http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing, software
 | |
| // distributed under the License is distributed on an "AS IS" BASIS,
 | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| // See the License for the specific language governing permissions and
 | |
| // limitations under the License.
 | |
| 
 | |
| package procfs
 | |
| 
 | |
| import (
 | |
| 	"bufio"
 | |
| 	"errors"
 | |
| 	"os"
 | |
| 	"regexp"
 | |
| 	"strconv"
 | |
| )
 | |
| 
 | |
| var (
 | |
| 	cpuLineRE  = regexp.MustCompile(`cpu(\d+) (\d+) (\d+) (\d+) (\d+) (\d+) (\d+) (\d+) (\d+) (\d+)`)
 | |
| 	procLineRE = regexp.MustCompile(`(\d+) (\d+) (\d+)`)
 | |
| )
 | |
| 
 | |
| // Schedstat contains scheduler statistics from /proc/schedstat
 | |
| //
 | |
| // See
 | |
| // https://www.kernel.org/doc/Documentation/scheduler/sched-stats.txt
 | |
| // for a detailed description of what these numbers mean.
 | |
| //
 | |
| // Note the current kernel documentation claims some of the time units are in
 | |
| // jiffies when they are actually in nanoseconds since 2.6.23 with the
 | |
| // introduction of CFS. A fix to the documentation is pending. See
 | |
| // https://lore.kernel.org/patchwork/project/lkml/list/?series=403473
 | |
| type Schedstat struct {
 | |
| 	CPUs []*SchedstatCPU
 | |
| }
 | |
| 
 | |
| // SchedstatCPU contains the values from one "cpu<N>" line
 | |
| type SchedstatCPU struct {
 | |
| 	CPUNum string
 | |
| 
 | |
| 	RunningNanoseconds uint64
 | |
| 	WaitingNanoseconds uint64
 | |
| 	RunTimeslices      uint64
 | |
| }
 | |
| 
 | |
| // ProcSchedstat contains the values from /proc/<pid>/schedstat
 | |
| type ProcSchedstat struct {
 | |
| 	RunningNanoseconds uint64
 | |
| 	WaitingNanoseconds uint64
 | |
| 	RunTimeslices      uint64
 | |
| }
 | |
| 
 | |
| // Schedstat reads data from /proc/schedstat
 | |
| func (fs FS) Schedstat() (*Schedstat, error) {
 | |
| 	file, err := os.Open(fs.proc.Path("schedstat"))
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	defer file.Close()
 | |
| 
 | |
| 	stats := &Schedstat{}
 | |
| 	scanner := bufio.NewScanner(file)
 | |
| 
 | |
| 	for scanner.Scan() {
 | |
| 		match := cpuLineRE.FindStringSubmatch(scanner.Text())
 | |
| 		if match != nil {
 | |
| 			cpu := &SchedstatCPU{}
 | |
| 			cpu.CPUNum = match[1]
 | |
| 
 | |
| 			cpu.RunningNanoseconds, err = strconv.ParseUint(match[8], 10, 64)
 | |
| 			if err != nil {
 | |
| 				continue
 | |
| 			}
 | |
| 
 | |
| 			cpu.WaitingNanoseconds, err = strconv.ParseUint(match[9], 10, 64)
 | |
| 			if err != nil {
 | |
| 				continue
 | |
| 			}
 | |
| 
 | |
| 			cpu.RunTimeslices, err = strconv.ParseUint(match[10], 10, 64)
 | |
| 			if err != nil {
 | |
| 				continue
 | |
| 			}
 | |
| 
 | |
| 			stats.CPUs = append(stats.CPUs, cpu)
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return stats, nil
 | |
| }
 | |
| 
 | |
| func parseProcSchedstat(contents string) (stats ProcSchedstat, err error) {
 | |
| 	match := procLineRE.FindStringSubmatch(contents)
 | |
| 
 | |
| 	if match != nil {
 | |
| 		stats.RunningNanoseconds, err = strconv.ParseUint(match[1], 10, 64)
 | |
| 		if err != nil {
 | |
| 			return
 | |
| 		}
 | |
| 
 | |
| 		stats.WaitingNanoseconds, err = strconv.ParseUint(match[2], 10, 64)
 | |
| 		if err != nil {
 | |
| 			return
 | |
| 		}
 | |
| 
 | |
| 		stats.RunTimeslices, err = strconv.ParseUint(match[3], 10, 64)
 | |
| 		return
 | |
| 	}
 | |
| 
 | |
| 	err = errors.New("could not parse schedstat")
 | |
| 	return
 | |
| }
 |