未验证 提交 ce9ca401 编写于 作者: K KubeSphere CI Bot 提交者: GitHub

Merge pull request #3146 from zackzhangkai/kiali-use-pod-2

using Kiali API directly
...@@ -106,6 +106,11 @@ func initializeServicemeshConfig(s *options.ServerRunOptions) { ...@@ -106,6 +106,11 @@ func initializeServicemeshConfig(s *options.ServerRunOptions) {
tracing.JaegerQueryUrl = s.ServiceMeshOptions.JaegerQueryHost tracing.JaegerQueryUrl = s.ServiceMeshOptions.JaegerQueryHost
} }
// Set the kiali query endpoint address
if s.ServiceMeshOptions != nil && len(s.ServiceMeshOptions.KialiQueryHost) != 0 {
tracing.KialiQueryUrl = s.ServiceMeshOptions.KialiQueryHost
}
// Exclude system namespaces // Exclude system namespaces
config.API.Namespaces.Exclude = []string{"istio-system", "kube-.*"} config.API.Namespaces.Exclude = []string{"istio-system", "kube-.*"}
config.InCluster = true config.InCluster = true
......
...@@ -29,9 +29,31 @@ import ( ...@@ -29,9 +29,31 @@ import (
// default jaeger query api endpoint address // default jaeger query api endpoint address
var JaegerQueryUrl = "http://jaeger-query.istio-system.svc:16686" var JaegerQueryUrl = "http://jaeger-query.istio-system.svc:16686"
/*
Use Kiali API directly if config existed in configmap.
Such as:
kubectl -n kubesphere-system get cm kubesphere-config -oyaml
...
kialiQueryHost: http://kiali.istio-system:20001
...
Otherwise, use the API provided by kiali code.
Announce: The API provided by kiali code will deprecated in the future.
*/
var KialiQueryUrl string
// Get app metrics // Get app metrics
func getAppMetrics(request *restful.Request, response *restful.Response) { func getAppMetrics(request *restful.Request, response *restful.Response) {
if len(KialiQueryUrl) == 0 {
handlers.AppMetrics(request, response) handlers.AppMetrics(request, response)
} else {
namespace := request.PathParameter("namespace")
app := request.PathParameter("app")
url := fmt.Sprintf("%s/kiali/api/namespaces/%s/apps/%s/metrics?%s", KialiQueryUrl, namespace, app, request.Request.URL.RawQuery)
getData(response, url)
}
} }
// Get workload metrics // Get workload metrics
...@@ -43,17 +65,35 @@ func getWorkloadMetrics(request *restful.Request, response *restful.Response) { ...@@ -43,17 +65,35 @@ func getWorkloadMetrics(request *restful.Request, response *restful.Response) {
request.Request.URL.RawQuery = fmt.Sprintf("%s&namespaces=%s&workload=%s", request.Request.URL.RawQuery, namespace, workload) request.Request.URL.RawQuery = fmt.Sprintf("%s&namespaces=%s&workload=%s", request.Request.URL.RawQuery, namespace, workload)
} }
if len(KialiQueryUrl) == 0 {
handlers.WorkloadMetrics(request, response) handlers.WorkloadMetrics(request, response)
} else {
url := fmt.Sprintf("%s/kiali/api/namespaces/%s/workloads/%s/metrics?%s", KialiQueryUrl, namespace, workload, request.Request.URL.RawQuery)
getData(response, url)
}
} }
// Get service metrics // Get service metrics
func getServiceMetrics(request *restful.Request, response *restful.Response) { func getServiceMetrics(request *restful.Request, response *restful.Response) {
if len(KialiQueryUrl) == 0 {
handlers.ServiceMetrics(request, response) handlers.ServiceMetrics(request, response)
} else {
namespace := request.PathParameter("namespace")
service := request.PathParameter("service")
url := fmt.Sprintf("%s/kiali/api/namespaces/%s/services/%s/metrics?%s", KialiQueryUrl, namespace, service, request.Request.URL.RawQuery)
getData(response, url)
}
} }
// Get namespace metrics // Get namespace metrics
func getNamespaceMetrics(request *restful.Request, response *restful.Response) { func getNamespaceMetrics(request *restful.Request, response *restful.Response) {
if len(KialiQueryUrl) == 0 {
handlers.NamespaceMetrics(request, response) handlers.NamespaceMetrics(request, response)
} else {
namespace := request.PathParameter("namespace")
url := fmt.Sprintf("%s/kiali/api/namespaces/%s/metrics?%s", KialiQueryUrl, namespace, request.Request.URL.RawQuery)
getData(response, url)
}
} }
// Get service graph for namespace // Get service graph for namespace
...@@ -64,9 +104,15 @@ func getNamespaceGraph(request *restful.Request, response *restful.Response) { ...@@ -64,9 +104,15 @@ func getNamespaceGraph(request *restful.Request, response *restful.Response) {
request.Request.URL.RawQuery = fmt.Sprintf("%s&namespaces=%s", request.Request.URL.RawQuery, namespace) request.Request.URL.RawQuery = fmt.Sprintf("%s&namespaces=%s", request.Request.URL.RawQuery, namespace)
} }
if len(KialiQueryUrl) == 0 {
handlers.GetNamespaceGraph(request, response) handlers.GetNamespaceGraph(request, response)
} else {
url := fmt.Sprintf("%s/kiali/api/namespaces/graph?%s", KialiQueryUrl, request.Request.URL.RawQuery)
getData(response, url)
}
} }
// Deprecated
// Get service graph for namespaces // Get service graph for namespaces
func getNamespacesGraph(request *restful.Request, response *restful.Response) { func getNamespacesGraph(request *restful.Request, response *restful.Response) {
handlers.GraphNamespaces(request, response) handlers.GraphNamespaces(request, response)
...@@ -74,37 +120,65 @@ func getNamespacesGraph(request *restful.Request, response *restful.Response) { ...@@ -74,37 +120,65 @@ func getNamespacesGraph(request *restful.Request, response *restful.Response) {
// Get namespace health // Get namespace health
func getNamespaceHealth(request *restful.Request, response *restful.Response) { func getNamespaceHealth(request *restful.Request, response *restful.Response) {
if len(KialiQueryUrl) == 0 {
handlers.NamespaceHealth(request, response) handlers.NamespaceHealth(request, response)
} else {
namespace := request.PathParameter("namespace")
url := fmt.Sprintf("%s/kiali/api/namespaces/%s/health?%s", KialiQueryUrl, namespace, request.Request.URL.RawQuery)
getData(response, url)
}
} }
// Get workload health // Get workload health
func getWorkloadHealth(request *restful.Request, response *restful.Response) { func getWorkloadHealth(request *restful.Request, response *restful.Response) {
if len(KialiQueryUrl) == 0 {
handlers.WorkloadHealth(request, response) handlers.WorkloadHealth(request, response)
} else {
namespace := request.PathParameter("namespace")
workload := request.PathParameter("workload")
url := fmt.Sprintf("%s/kiali/api/namespaces/%s/workloads/%s/health?%s", KialiQueryUrl, namespace, workload, request.Request.URL.RawQuery)
getData(response, url)
}
} }
// Get app health // Get app health
func getAppHealth(request *restful.Request, response *restful.Response) { func getAppHealth(request *restful.Request, response *restful.Response) {
if len(KialiQueryUrl) == 0 {
handlers.AppHealth(request, response) handlers.AppHealth(request, response)
} else {
namespace := request.PathParameter("namespace")
app := request.PathParameter("app")
url := fmt.Sprintf("%s/kiali/api/namespaces/%s/apps/%s/health?%s", KialiQueryUrl, namespace, app, request.Request.URL.RawQuery)
getData(response, url)
}
} }
// Get service health // Get service health
func getServiceHealth(request *restful.Request, response *restful.Response) { func getServiceHealth(request *restful.Request, response *restful.Response) {
if len(KialiQueryUrl) == 0 {
handlers.ServiceHealth(request, response) handlers.ServiceHealth(request, response)
} else {
namespace := request.PathParameter("namespace")
service := request.PathParameter("service")
url := fmt.Sprintf("%s/kiali/api/namespaces/%s/services/%s/health?%s", KialiQueryUrl, namespace, service, request.Request.URL.RawQuery)
getData(response, url)
}
} }
func getServiceTracing(request *restful.Request, response *restful.Response) { func getServiceTracing(request *restful.Request, response *restful.Response) {
namespace := request.PathParameter("namespace") namespace := request.PathParameter("namespace")
service := request.PathParameter("service") service := request.PathParameter("service")
serviceName := fmt.Sprintf("%s.%s", service, namespace) serviceName := fmt.Sprintf("%s.%s", service, namespace)
url := fmt.Sprintf("%s/api/traces?%s&service=%s", JaegerQueryUrl, request.Request.URL.RawQuery, serviceName) url := fmt.Sprintf("%s/api/traces?%s&service=%s", JaegerQueryUrl, request.Request.URL.RawQuery, serviceName)
getData(response, url)
}
func getData(response *restful.Response, url string) {
resp, err := http.Get(url) resp, err := http.Get(url)
klog.V(4).Infof("Proxy trace request to %s", url) klog.V(4).Infof("Proxy request to %s", url)
if err != nil { if err != nil {
klog.Errorf("query jaeger failed with err %v", err) klog.Errorf("query url %s failed with err %v", url, err)
api.HandleInternalError(response, nil, err) api.HandleInternalError(response, nil, err)
return return
} }
......
...@@ -26,6 +26,9 @@ type Options struct { ...@@ -26,6 +26,9 @@ type Options struct {
// jaeger query service url // jaeger query service url
JaegerQueryHost string `json:"jaegerQueryHost,omitempty" yaml:"jaegerQueryHost"` JaegerQueryHost string `json:"jaegerQueryHost,omitempty" yaml:"jaegerQueryHost"`
// kiali query service url
KialiQueryHost string `json:"kialiQueryHost,omitempty" yaml:"kialiQueryHost"`
// prometheus service url for servicemesh metrics // prometheus service url for servicemesh metrics
ServicemeshPrometheusHost string `json:"servicemeshPrometheusHost,omitempty" yaml:"servicemeshPrometheusHost"` ServicemeshPrometheusHost string `json:"servicemeshPrometheusHost,omitempty" yaml:"servicemeshPrometheusHost"`
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册