/
init.go
53 lines (44 loc) · 1.14 KB
/
init.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
package data_access
import (
"fmt"
"github.com/alipay/container-observability-service/pkg/common"
"github.com/olivere/elastic/v7"
"k8s.io/klog"
)
var (
EsClient *elastic.Client
XSearch StorageInterface
)
func NewDBClient(opts *common.DBOptions) (StorageInterface, error) {
switch opts.Driver {
case "mysql":
sqlStorage, err := ProvideSqlStorate(opts.MysqlOptions)
if err != nil {
return nil, err
}
XSearch = sqlStorage
return XSearch, nil
case "elasticsearch":
esStorage, err := ProvideEsStorage(opts.ESOptions)
if err != nil {
klog.Infof("read esStorage err: %s", err.Error())
return nil, err
}
XSearch = esStorage
return XSearch, nil
default:
return nil, fmt.Errorf("unsupported driver: %s", opts.Driver)
}
}
// func InitApi(endPoint string, username string, password string, jaegerQueryAddress string) {
// // TODO: multi storage implement
// // ZSearch
// EsClient, _ = impl.InitZSearch(endPoint, username, password)
// storage = impl.NewZSearchStorage()
// // OceanBase
// // Init jaeger query service
// InitJaegerQuery(jaegerQueryAddress)
// }
// func GetStorage() Storage {
// return storage
// }