mirror of https://github.com/k3s-io/k3s
commit
8d31a576a0
|
@ -0,0 +1,7 @@
|
|||
all: resource_consumer
|
||||
|
||||
resource_consumer:
|
||||
go build
|
||||
|
||||
clean:
|
||||
rm -f resource-consumer
|
|
@ -0,0 +1,31 @@
|
|||
/*
|
||||
Copyright 2015 The Kubernetes Authors All rights reserved.
|
||||
|
||||
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 main
|
||||
|
||||
import (
|
||||
"flag"
|
||||
"fmt"
|
||||
"log"
|
||||
"net/http"
|
||||
)
|
||||
|
||||
var port = flag.Int("port", 8080, "Port number.")
|
||||
|
||||
func main() {
|
||||
var resourceConsumerHandler ResourceConsumerHandler
|
||||
log.Fatal(http.ListenAndServe(fmt.Sprintf(":%d", *port), resourceConsumerHandler))
|
||||
}
|
|
@ -0,0 +1,113 @@
|
|||
/*
|
||||
Copyright 2015 The Kubernetes Authors All rights reserved.
|
||||
|
||||
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 main
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"net/http"
|
||||
"net/url"
|
||||
"strconv"
|
||||
)
|
||||
|
||||
const (
|
||||
unknownFunction = "unknown function"
|
||||
incorrectFunctionArgument = "incorrect function argument"
|
||||
notGivenFunctionArgument = "not given function argument"
|
||||
consumeCPUAddress = "/ConsumeCPU"
|
||||
consumeMemAddress = "/ConsumeMem"
|
||||
getCurrentStatusAddress = "/GetCurrentStatus"
|
||||
milicoresQuery = "milicores"
|
||||
megabytesQuery = "megabytes"
|
||||
durationSecQuery = "durationSec"
|
||||
)
|
||||
|
||||
type ResourceConsumerHandler struct{}
|
||||
|
||||
func (handler ResourceConsumerHandler) ServeHTTP(w http.ResponseWriter, req *http.Request) {
|
||||
// parsing raw query
|
||||
query, err := url.ParseQuery(req.URL.RawQuery)
|
||||
if err != nil {
|
||||
http.Error(w, err.Error(), http.StatusBadRequest)
|
||||
return
|
||||
}
|
||||
// handle consumeCPU
|
||||
if req.URL.Path == consumeCPUAddress {
|
||||
handler.handleConsumeCPU(w, query)
|
||||
return
|
||||
}
|
||||
// handle consumeMem
|
||||
if req.URL.Path == consumeMemAddress {
|
||||
handler.handleConsumeMem(w, query)
|
||||
return
|
||||
}
|
||||
// handle getCurrentStatus
|
||||
if req.URL.Path == getCurrentStatusAddress {
|
||||
handler.handleGetCurrentStatus(w)
|
||||
return
|
||||
}
|
||||
http.Error(w, unknownFunction, http.StatusNotFound)
|
||||
}
|
||||
|
||||
func (handler ResourceConsumerHandler) handleConsumeCPU(w http.ResponseWriter, query url.Values) {
|
||||
// geting string data for consumeCPU
|
||||
durationSecString := query.Get(durationSecQuery)
|
||||
milicoresString := query.Get(milicoresQuery)
|
||||
if durationSecString == "" || milicoresString == "" {
|
||||
http.Error(w, notGivenFunctionArgument, http.StatusBadRequest)
|
||||
return
|
||||
} else {
|
||||
// convert data (strings to ints) for consumeCPU
|
||||
durationSec, durationSecError := strconv.Atoi(durationSecString)
|
||||
milicores, milicoresError := strconv.Atoi(milicoresString)
|
||||
if durationSecError != nil || milicoresError != nil {
|
||||
http.Error(w, incorrectFunctionArgument, http.StatusBadRequest)
|
||||
return
|
||||
}
|
||||
ConsumeCPU(milicores, durationSec)
|
||||
fmt.Fprintln(w, consumeCPUAddress[1:])
|
||||
fmt.Fprintln(w, milicores, milicoresQuery)
|
||||
fmt.Fprintln(w, durationSec, durationSecQuery)
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
func (handler ResourceConsumerHandler) handleConsumeMem(w http.ResponseWriter, query url.Values) {
|
||||
// geting string data for consumeMem
|
||||
durationSecString := query.Get(durationSecQuery)
|
||||
megabytesString := query.Get(megabytesQuery)
|
||||
if durationSecString == "" || megabytesString == "" {
|
||||
http.Error(w, notGivenFunctionArgument, http.StatusBadRequest)
|
||||
return
|
||||
} else {
|
||||
// convert data (strings to ints) for consumeMem
|
||||
durationSec, durationSecError := strconv.Atoi(durationSecString)
|
||||
megabytes, megabytesError := strconv.Atoi(megabytesString)
|
||||
if durationSecError != nil || megabytesError != nil {
|
||||
http.Error(w, incorrectFunctionArgument, http.StatusBadRequest)
|
||||
return
|
||||
}
|
||||
ConsumeMem(megabytes, durationSec)
|
||||
fmt.Fprintln(w, consumeMemAddress[1:])
|
||||
fmt.Fprintln(w, megabytes, megabytesQuery)
|
||||
fmt.Fprintln(w, durationSec, durationSecQuery)
|
||||
}
|
||||
}
|
||||
|
||||
func (handler ResourceConsumerHandler) handleGetCurrentStatus(w http.ResponseWriter) {
|
||||
GetCurrentStatus()
|
||||
fmt.Fprint(w, getCurrentStatusAddress[1:])
|
||||
}
|
|
@ -0,0 +1,36 @@
|
|||
/*
|
||||
Copyright 2015 The Kubernetes Authors All rights reserved.
|
||||
|
||||
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 main
|
||||
|
||||
import (
|
||||
"github.com/golang/glog"
|
||||
)
|
||||
|
||||
func ConsumeCPU(milicores int, durationSec int) {
|
||||
glog.Infof("ConsumeCPU milicores: %v, durationSec: %v", milicores, durationSec)
|
||||
// not implemented
|
||||
}
|
||||
|
||||
func ConsumeMem(megabytes int, durationSec int) {
|
||||
glog.Infof("ConsumeMem megabytes: %v, durationSec: %v", megabytes, durationSec)
|
||||
// not implemented
|
||||
}
|
||||
|
||||
func GetCurrentStatus() {
|
||||
glog.Infof("GetCurrentStatus")
|
||||
// not implemented
|
||||
}
|
Loading…
Reference in New Issue