Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Refact seri #755

Merged
merged 75 commits into from
Sep 13, 2020
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
75 commits
Select commit Hold shift + click to select a range
ddfad7f
consul service discovery
Aug 4, 2020
e0d492d
consul service discovery
Aug 4, 2020
0520f48
consul service discovery (not test yet)
Aug 6, 2020
34f5d8a
consul ttl check
Aug 7, 2020
5716195
consul service discovery unit test
Aug 7, 2020
d0d1e3d
test panic error
Aug 8, 2020
322fae2
unit test TestConsulServiceDiscovery_Destroy repaired
Aug 8, 2020
47bab04
unit test repaired
Aug 8, 2020
e321256
clean code
Aug 8, 2020
f3c63b5
add log
Aug 9, 2020
2693201
remove hc-log
Aug 9, 2020
0ddcd72
unit test error repaired
Aug 10, 2020
0f839ff
use pointer type *MockEventDispatcher
Aug 11, 2020
5965e74
Merge remote-tracking branch 'origin/develop' into develop
Aug 11, 2020
8040566
optimized code for consul service discovery
Aug 13, 2020
77eb76e
Merge remote-tracking branch 'origin/develop' into develop
Aug 13, 2020
fdc4f7c
optimized
Aug 17, 2020
e238478
optimized
Aug 17, 2020
d5dfaf9
suit consul
Aug 29, 2020
c135d03
Merge remote-tracking branch 'origin/develop' into develop
Aug 29, 2020
4e2ac21
optimize code and adapt to other unit test
Aug 29, 2020
55dfc25
fix bug
Aug 29, 2020
9a644a6
etcdv3 lease
Aug 31, 2020
ce86820
add file service discovery config file
cityiron Aug 31, 2020
5ff6870
delete unused code
Sep 2, 2020
ebf3cc6
concurrency problem fixed
Sep 4, 2020
04d7ac9
Merge remote-tracking branch 'origin/develop' into develop
Sep 5, 2020
262bf06
Merge remote-tracking branch 'origin/develop' into develop
Sep 5, 2020
678f505
file system service discovery perfect
cityiron Sep 6, 2020
112e1a9
TestNewFileSystemServiceDiscoveryAndDestroy add prepareData()
cityiron Sep 6, 2020
eed3a47
Merge branch 'develop' of https://github.com/apache/dubbo-go into dev…
Sep 7, 2020
f3ce3a3
Merge branch 'develop' into feature/file_service_discovery
cityiron Sep 7, 2020
3ecffc7
update config_center file test
cityiron Sep 7, 2020
934ad5c
remove callback add
cityiron Sep 7, 2020
a94ead8
sort import and change dynamic_configuration.go#RemoveConfig comment
cityiron Sep 7, 2020
d210989
revert modifications on this pr,thus submitted this modification on…
Sep 8, 2020
78611fd
fix impl_test mockDataListener use
cityiron Sep 8, 2020
a8782ae
delete the method 'Init' of interface ServiceDiscovery
Sep 8, 2020
b8a20bd
delete unused code
Sep 9, 2020
b3aab08
delete unused code
Sep 9, 2020
fa65371
format else and length
cityiron Sep 9, 2020
2fa6522
optimized some code
Sep 9, 2020
2297303
registry string from constant
cityiron Sep 10, 2020
f818c7e
delete not used map
cityiron Sep 10, 2020
d294b14
Ftr: add sentinel-golang(https://github.com/alibaba/sentinel-golang) …
louyuting Sep 10, 2020
668764a
refine sentinel-go filter
louyuting Sep 11, 2020
6a4eb87
refine imports
louyuting Sep 11, 2020
ec2110c
refine logger
louyuting Sep 11, 2020
77e59d1
fix concurrency problems
Sep 12, 2020
24e8293
use rwlock
Sep 12, 2020
282a8ad
Merge pull request #732 from DogBaoBao/feature/file_service_discovery
AlexStocks Sep 12, 2020
b52639d
ci: Perfect reminder information.
sdttttt Sep 12, 2020
8df776e
ci: Switch to test environment.
sdttttt Sep 12, 2020
f94ba81
fix: Notify message.
sdttttt Sep 12, 2020
494bcd6
Update go.yml
sdttttt Sep 12, 2020
2d896fe
fix: workflow syntax problom.
sdttttt Sep 12, 2020
40bd33f
Update go.yml
sdttttt Sep 12, 2020
1ae651c
Update go.yml
sdttttt Sep 12, 2020
ab5f5c6
Update go.yml
sdttttt Sep 12, 2020
503489e
fix: workflow syntex problom....
sdttttt Sep 12, 2020
f3852ca
ci: Enhance reminder message.
sdttttt Sep 12, 2020
b4a14da
Update go.yml
sdttttt Sep 12, 2020
71d8434
Update go.yml
sdttttt Sep 12, 2020
12dbd7f
ci: Fix syntax and Add comments.
sdttttt Sep 12, 2020
631562b
Update go.yml
sdttttt Sep 13, 2020
bff0898
Update go.yml
sdttttt Sep 13, 2020
7662982
refactor repeated code
Sep 13, 2020
e84a2cf
Merge pull request #753 from sdttttt/sdttttt-patch-1
AlexStocks Sep 13, 2020
57601bc
Merge pull request #748 from louyuting/feature/sentinel-integration
AlexStocks Sep 13, 2020
02b0a82
refactor code
Sep 13, 2020
bc43a00
refactor code
Sep 13, 2020
fc15617
refactor code
Sep 13, 2020
69b77b6
Merge pull request #701 from zhangshen023/develop
AlexStocks Sep 13, 2020
e18e1ab
rename file:O go.yml -> github-actions.yml
AlexStocks Sep 13, 2020
48d746f
feat: resolve go.mod conflict
Sep 13, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Ftr: add sentinel-golang(https://github.com/alibaba/sentinel-golang) …
…flow control/circuit breaker
  • Loading branch information
louyuting committed Sep 10, 2020
commit d294b14aeb6fca9ff9c5130c13a6c1a478027e12
226 changes: 226 additions & 0 deletions filter/filter_impl/sentinel_filter.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,226 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 filter_impl

import (
"bytes"
"context"
"fmt"
)

import (
sentinel "github.com/alibaba/sentinel-golang/api"
"github.com/alibaba/sentinel-golang/core/base"
)

import (
"github.com/apache/dubbo-go/common"
"github.com/apache/dubbo-go/common/constant"
"github.com/apache/dubbo-go/common/extension"
"github.com/apache/dubbo-go/filter"
"github.com/apache/dubbo-go/protocol"
)

func init() {
extension.SetFilter(SentinelProviderFilterName, GetSentinelProviderFilter)
extension.SetFilter(SentinelConsumerFilterName, GetSentinelConsumerFilter)
}

func GetSentinelConsumerFilter() filter.Filter {
return &SentinelConsumerFilter{}
}

func GetSentinelProviderFilter() filter.Filter {
return &SentinelProviderFilter{}
}

type SentinelProviderFilter struct{}

func (d *SentinelProviderFilter) Invoke(ctx context.Context, invoker protocol.Invoker, invocation protocol.Invocation) protocol.Result {
methodResourceName := getResourceName(invoker, invocation, getProviderPrefix())
interfaceResourceName := ""
if getInterfaceGroupAndVersionEnabled() {
interfaceResourceName = getColonSeparatedKey(invoker.GetUrl())
} else {
interfaceResourceName = invoker.GetUrl().Service()
}
var (
interfaceEntry *base.SentinelEntry
methodEntry *base.SentinelEntry
b *base.BlockError
)
interfaceEntry, b = sentinel.Entry(interfaceResourceName, sentinel.WithResourceType(base.ResTypeRPC), sentinel.WithTrafficType(base.Inbound))
if b != nil {
// interface blocked
return sentinelDubboProviderFallback(ctx, invoker, invocation, b)
}
ctx = context.WithValue(ctx, InterfaceEntryKey, interfaceEntry)

methodEntry, b = sentinel.Entry(methodResourceName, sentinel.WithResourceType(base.ResTypeRPC),
sentinel.WithTrafficType(base.Inbound), sentinel.WithArgs(invocation.Arguments()...))
if b != nil {
// method blocked
return sentinelDubboProviderFallback(ctx, invoker, invocation, b)
}
ctx = context.WithValue(ctx, MethodEntryKey, methodEntry)
return invoker.Invoke(ctx, invocation)
}

func (d *SentinelProviderFilter) OnResponse(ctx context.Context, result protocol.Result, _ protocol.Invoker, _ protocol.Invocation) protocol.Result {
if methodEntry := ctx.Value(MethodEntryKey); methodEntry != nil {
e := methodEntry.(*base.SentinelEntry)
sentinel.TraceError(e, result.Error())
e.Exit()
}
if interfaceEntry := ctx.Value(InterfaceEntryKey); interfaceEntry != nil {
e := interfaceEntry.(*base.SentinelEntry)
sentinel.TraceError(e, result.Error())
e.Exit()
}
return result
}

type SentinelConsumerFilter struct{}

func (d *SentinelConsumerFilter) Invoke(ctx context.Context, invoker protocol.Invoker, invocation protocol.Invocation) protocol.Result {
methodResourceName := getResourceName(invoker, invocation, getConsumerPrefix())
interfaceResourceName := ""
if getInterfaceGroupAndVersionEnabled() {
interfaceResourceName = getColonSeparatedKey(invoker.GetUrl())
} else {
interfaceResourceName = invoker.GetUrl().Service()
}
var (
interfaceEntry *base.SentinelEntry
methodEntry *base.SentinelEntry
b *base.BlockError
)

interfaceEntry, b = sentinel.Entry(interfaceResourceName, sentinel.WithResourceType(base.ResTypeRPC), sentinel.WithTrafficType(base.Outbound))
if b != nil {
// interface blocked
return sentinelDubboConsumerFallback(ctx, invoker, invocation, b)
}
ctx = context.WithValue(ctx, InterfaceEntryKey, interfaceEntry)

methodEntry, b = sentinel.Entry(methodResourceName, sentinel.WithResourceType(base.ResTypeRPC),
sentinel.WithTrafficType(base.Outbound), sentinel.WithArgs(invocation.Arguments()...))
if b != nil {
// method blocked
return sentinelDubboConsumerFallback(ctx, invoker, invocation, b)
}
ctx = context.WithValue(ctx, MethodEntryKey, methodEntry)

return invoker.Invoke(ctx, invocation)
}

func (d *SentinelConsumerFilter) OnResponse(ctx context.Context, result protocol.Result, _ protocol.Invoker, _ protocol.Invocation) protocol.Result {
if methodEntry := ctx.Value(MethodEntryKey); methodEntry != nil {
e := methodEntry.(*base.SentinelEntry)
sentinel.TraceError(e, result.Error())
e.Exit()
}
if interfaceEntry := ctx.Value(InterfaceEntryKey); interfaceEntry != nil {
e := interfaceEntry.(*base.SentinelEntry)
sentinel.TraceError(e, result.Error())
e.Exit()
}
return result
}

var (
sentinelDubboConsumerFallback = getDefaultDubboFallback()
sentinelDubboProviderFallback = getDefaultDubboFallback()
)

type DubboFallback func(context.Context, protocol.Invoker, protocol.Invocation, *base.BlockError) protocol.Result

func SetDubboConsumerFallback(f DubboFallback) {
sentinelDubboConsumerFallback = f
}
func SetDubboProviderFallback(f DubboFallback) {
sentinelDubboProviderFallback = f
}
func getDefaultDubboFallback() DubboFallback {
return func(ctx context.Context, invoker protocol.Invoker, invocation protocol.Invocation, blockError *base.BlockError) protocol.Result {
result := &protocol.RPCResult{}
result.SetResult(nil)
result.SetError(blockError)
return result
}
}

const (
SentinelProviderFilterName = "sentinel-provider"
SentinelConsumerFilterName = "sentinel-consumer"

DefaultProviderPrefix = "dubbo:provider:"
DefaultConsumerPrefix = "dubbo:consumer:"

MethodEntryKey = "$$sentinelMethodEntry"
InterfaceEntryKey = "$$sentinelInterfaceEntry"
)

// Currently, a ConcurrentHashMap mechanism is missing.
// All values are filled with default values first.

func getResourceName(invoker protocol.Invoker, invocation protocol.Invocation, prefix string) string {
var (
buf bytes.Buffer
interfaceResource string
)
buf.WriteString(prefix)
if getInterfaceGroupAndVersionEnabled() {
interfaceResource = getColonSeparatedKey(invoker.GetUrl())
} else {
interfaceResource = invoker.GetUrl().Service()
}
buf.WriteString(interfaceResource)
buf.WriteString(":")
buf.WriteString(invocation.MethodName())
buf.WriteString("(")
isFirst := true
for _, v := range invocation.ParameterTypes() {
if !isFirst {
buf.WriteString(",")
}
buf.WriteString(v.Name())
isFirst = false
}
buf.WriteString(")")
return buf.String()
}

func getConsumerPrefix() string {
return DefaultConsumerPrefix
}

func getProviderPrefix() string {
return DefaultProviderPrefix
}

func getInterfaceGroupAndVersionEnabled() bool {
return true
}

func getColonSeparatedKey(url common.URL) string {
return fmt.Sprintf("%s:%s:%s",
url.Service(),
url.GetParam(constant.GROUP_KEY, ""),
url.GetParam(constant.VERSION_KEY, ""))
}
75 changes: 75 additions & 0 deletions filter/filter_impl/sentinel_filter_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 filter_impl

import (
"context"
"testing"
)

import (
"github.com/stretchr/testify/assert"
)

import (
"github.com/apache/dubbo-go/common"
"github.com/apache/dubbo-go/protocol"
"github.com/apache/dubbo-go/protocol/invocation"
)

func TestConsumerFilter_Invoke(t *testing.T) {
f := GetSentinelConsumerFilter()
url, err := common.NewURL("dubbo://127.0.0.1:20000/UserProvider?anyhost=true&" +
"application=BDTService&category=providers&default.timeout=10000&dubbo=dubbo-provider-golang-1.0.0&" +
"environment=dev&interface=com.ikurento.user.UserProvider&ip=192.168.56.1&methods=GetUser%2C&" +
"module=dubbogo+user-info+server&org=ikurento.com&owner=ZX&pid=1447&revision=0.0.1&" +
"side=provider&timeout=3000&timestamp=1556509797245&bean.name=UserProvider")
assert.NoError(t, err)
mockInvoker := protocol.NewBaseInvoker(url)
mockInvocation := invocation.NewRPCInvocation("hello", []interface{}{"OK"}, make(map[string]interface{}))
result := f.Invoke(context.TODO(), mockInvoker, mockInvocation)
assert.NoError(t, result.Error())
}

func TestProviderFilter_Invoke(t *testing.T) {
f := GetSentinelProviderFilter()
url, err := common.NewURL("dubbo://127.0.0.1:20000/UserProvider?anyhost=true&" +
"application=BDTService&category=providers&default.timeout=10000&dubbo=dubbo-provider-golang-1.0.0&" +
"environment=dev&interface=com.ikurento.user.UserProvider&ip=192.168.56.1&methods=GetUser%2C&" +
"module=dubbogo+user-info+server&org=ikurento.com&owner=ZX&pid=1447&revision=0.0.1&" +
"side=provider&timeout=3000&timestamp=1556509797245&bean.name=UserProvider")
assert.NoError(t, err)
mockInvoker := protocol.NewBaseInvoker(url)
mockInvocation := invocation.NewRPCInvocation("hello", []interface{}{"OK"}, make(map[string]interface{}))
result := f.Invoke(context.TODO(), mockInvoker, mockInvocation)
assert.NoError(t, result.Error())
}

func TestGetResourceName(t *testing.T) {
url, err := common.NewURL("dubbo://127.0.0.1:20000/UserProvider?anyhost=true&" +
"version=1.0.0&group=myGroup&" +
"application=BDTService&category=providers&default.timeout=10000&dubbo=dubbo-provider-golang-1.0.0&" +
"environment=dev&interface=com.ikurento.user.UserProvider&ip=192.168.56.1&methods=GetUser%2C&" +
"module=dubbogo+user-info+server&org=ikurento.com&owner=ZX&pid=1447&revision=0.0.1&" +
"side=provider&timeout=3000&timestamp=1556509797245&bean.name=UserProvider")
assert.NoError(t, err)
mockInvoker := protocol.NewBaseInvoker(url)
methodResourceName := getResourceName(mockInvoker,
invocation.NewRPCInvocation("hello", []interface{}{"OK"}, make(map[string]interface{})), "prefix_")
assert.Equal(t, "prefix_com.ikurento.user.UserProvider:myGroup:1.0.0:hello()", methodResourceName)
}
21 changes: 6 additions & 15 deletions go.mod
Original file line number Diff line number Diff line change
@@ -1,18 +1,15 @@
module github.com/apache/dubbo-go

require (
github.com/Microsoft/go-winio v0.4.13 // indirect
github.com/NYTimes/gziphandler v1.1.1 // indirect
github.com/RoaringBitmap/roaring v0.4.23
github.com/Workiva/go-datastructures v1.0.50
github.com/afex/hystrix-go v0.0.0-20180502004556-fa1af6a1f4f5
github.com/alibaba/sentinel-golang v0.6.1
github.com/apache/dubbo-getty v1.3.10
github.com/apache/dubbo-go-hessian2 v1.6.0-rc1.0.20200906044240-6c1fb5c3bd44
github.com/coreos/bbolt v1.3.3 // indirect
github.com/coreos/etcd v3.3.13+incompatible
github.com/coreos/go-systemd v0.0.0-20190719114852-fd7a80b32e1f // indirect
github.com/coreos/etcd v3.3.25+incompatible
github.com/creasty/defaults v1.3.0
github.com/docker/go-connections v0.4.0 // indirect
github.com/dubbogo/go-zookeeper v1.0.1
github.com/dubbogo/gost v1.9.1
github.com/elazarl/go-bindata-assetfs v1.0.0 // indirect
Expand All @@ -21,22 +18,16 @@ require (
github.com/ghodss/yaml v1.0.1-0.20190212211648-25d852aebe32 // indirect
github.com/go-co-op/gocron v0.1.1
github.com/go-resty/resty/v2 v2.1.0
github.com/golang/groupcache v0.0.0-20190702054246-869f871628b6 // indirect
github.com/golang/mock v1.3.1
github.com/golang/protobuf v1.3.2
github.com/google/go-cmp v0.3.1 // indirect
github.com/grpc-ecosystem/go-grpc-middleware v1.0.1-0.20190118093823-f849b5445de4 // indirect
github.com/grpc-ecosystem/grpc-gateway v1.9.5 // indirect
github.com/golang/protobuf v1.4.0
github.com/grpc-ecosystem/grpc-opentracing v0.0.0-20180507213350-8e809c8a8645
github.com/hashicorp/consul v1.8.0
github.com/hashicorp/consul/api v1.5.0
github.com/hashicorp/go-raftchunking v0.6.3-0.20191002164813-7e9e8525653a // indirect
github.com/hashicorp/golang-lru v0.5.3 // indirect
github.com/hashicorp/vault/api v1.0.5-0.20191108163347-bdd38fca2cff // indirect
github.com/hashicorp/vault/sdk v0.1.14-0.20191112033314-390e96e22eb2
github.com/jinzhu/copier v0.0.0-20190625015134-976e0346caa8
github.com/magiconair/properties v1.8.1
github.com/mitchellh/hashstructure v1.0.0 // indirect
github.com/mitchellh/mapstructure v1.2.3
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd
github.com/nacos-group/nacos-sdk-go v1.0.0
Expand All @@ -45,14 +36,12 @@ require (
github.com/pkg/errors v0.9.1
github.com/prometheus/client_golang v1.1.0
github.com/satori/go.uuid v1.2.1-0.20181028125025-b2ce2384e17b
github.com/shirou/gopsutil v2.19.9+incompatible // indirect
github.com/stretchr/objx v0.2.0 // indirect
github.com/stretchr/testify v1.5.1
github.com/zouyx/agollo/v3 v3.4.4
go.etcd.io/bbolt v1.3.4 // indirect
go.uber.org/atomic v1.6.0
go.uber.org/zap v1.15.0
google.golang.org/grpc v1.23.0
google.golang.org/grpc v1.26.0
gopkg.in/yaml.v2 v2.2.8
k8s.io/api v0.16.9
k8s.io/apimachinery v0.16.9
Expand All @@ -64,3 +53,5 @@ require (
go 1.13

replace launchpad.net/gocheck => github.com/go-check/check v0.0.0-20140225173054-eb6ee6f84d0a

replace github.com/envoyproxy/go-control-plane => github.com/envoyproxy/go-control-plane v0.8.0
Loading