mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-31 08:29:33 +08:00 
			
		
		
		
	* Code adaptation k8s: service discovery and registration adaptation, configuration adaptation * Initial submission of the help charts script for openim API * change the help charts script * change the help charts script * change helm chart codes * change dockerfiles script * change chart script:add configmap mounts * change chart script:change repository * change chart script:msggateway add one service * change config.yaml * roll back some config values * change chart script:change Ingress rule with a rewrite annotation * add mysql charts scrible * change chart script:add mysql.config.yaml * add nfs provisioner charts * change chart script:add nfs.config.yaml * add ingress-nginx charts * change chart script:add ingress-nginx.config.yaml * add redis &mongodb charts * add kafka&minio charts * change chart script:change redis.values.yaml * change chart script:add redis.config.yaml * change chart script:change redis.config.yaml * change chart script:change mongodb.value.yaml * change chart script:change mongodb.value.yaml * change chart script:add mongodb.config.yaml * change chart script:change minio.values.yaml * change chart script:add minio.config.yaml * change chart script:change kafka.values.yaml * change chart script:add kafka.config.yaml * change chart script:change services.config.yaml * bug fix:Delete websocket's Port restrictions * bug fix:change port value * change chart script:Submit a stable version script * fix bug:Implement option interface * fix bug:change K8sDR.Register * change config.yaml * change chats script:minio service add ingress * change chats script:minio service add ingress * change chats script:kafka.replicaCount=3& change minio.api ingress * delete change chats script * change config.yaml * change openim.yaml * merge go.sum * Add monitoring function and struct for Prometheus on gin and GRPC * Add GRPC and gin server monitoring logic * Add GRPC and gin server monitoring logic2 * Add GRPC and gin server monitoring logic3 * Add GRPC and gin server monitoring logic4 * Add GRPC and gin server monitoring logic5 * Add GRPC and gin server monitoring logic6 * Add GRPC and gin server monitoring logic7 * delete:old monitoring code * add for test * fix bug:change packname * fix bug:delete getPromPort funciton * fix bug:delete getPromPort funciton * fix bug:change logs * fix bug:change registerName logic in GetGrpcCusMetrics function * add getPrometheus url api * fix:config path logic * fix:prometheus enable function * fix:prometheus enable function * fix:transfer Multi process monitoring logic * del:del not using manifest * fix:openim-msgtransfer.sh * fix:openim-msgtransfer.sh --------- Co-authored-by: lin.huang <lin.huang@apulis.com> Co-authored-by: Xinwei Xiong <3293172751@qq.com>
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package prom_metrics
 | |
| 
 | |
| import (
 | |
| 	grpc_prometheus "github.com/grpc-ecosystem/go-grpc-prometheus"
 | |
| 	config2 "github.com/openimsdk/open-im-server/v3/pkg/common/config"
 | |
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/ginPrometheus"
 | |
| 	"github.com/prometheus/client_golang/prometheus"
 | |
| 	"github.com/prometheus/client_golang/prometheus/collectors"
 | |
| )
 | |
| 
 | |
| func NewGrpcPromObj(cusMetrics []prometheus.Collector) (*prometheus.Registry, *grpc_prometheus.ServerMetrics, error) {
 | |
| 	////////////////////////////////////////////////////////
 | |
| 	reg := prometheus.NewRegistry()
 | |
| 	grpcMetrics := grpc_prometheus.NewServerMetrics()
 | |
| 	grpcMetrics.EnableHandlingTimeHistogram()
 | |
| 	cusMetrics = append(cusMetrics, grpcMetrics, collectors.NewGoCollector())
 | |
| 	reg.MustRegister(cusMetrics...)
 | |
| 	return reg, grpcMetrics, nil
 | |
| }
 | |
| 
 | |
| func GetGrpcCusMetrics(registerName string) []prometheus.Collector {
 | |
| 	switch registerName {
 | |
| 	case config2.Config.RpcRegisterName.OpenImMessageGatewayName:
 | |
| 		return []prometheus.Collector{OnlineUserGauge}
 | |
| 	case config2.Config.RpcRegisterName.OpenImMsgName:
 | |
| 		return []prometheus.Collector{SingleChatMsgProcessSuccessCounter, SingleChatMsgProcessFailedCounter, GroupChatMsgProcessSuccessCounter, GroupChatMsgProcessFailedCounter}
 | |
| 	case "Transfer":
 | |
| 		return []prometheus.Collector{MsgInsertRedisSuccessCounter, MsgInsertRedisFailedCounter, MsgInsertMongoSuccessCounter, MsgInsertMongoFailedCounter, SeqSetFailedCounter}
 | |
| 	case config2.Config.RpcRegisterName.OpenImPushName:
 | |
| 		return []prometheus.Collector{MsgOfflinePushFailedCounter}
 | |
| 	case config2.Config.RpcRegisterName.OpenImAuthName:
 | |
| 		return []prometheus.Collector{UserLoginCounter}
 | |
| 	default:
 | |
| 		return nil
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func GetGinCusMetrics(name string) []*ginPrometheus.Metric {
 | |
| 	switch name {
 | |
| 	case "Api":
 | |
| 		return []*ginPrometheus.Metric{ApiCustomCnt}
 | |
| 	default:
 | |
| 		return []*ginPrometheus.Metric{ApiCustomCnt}
 | |
| 	}
 | |
| }
 |