Skip to content
Snippets Groups Projects
client.go 7.64 KiB
Newer Older
AlexStocks's avatar
AlexStocks committed
/*
 * 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.
 */
fangyincheng's avatar
fangyincheng committed

AlexStocks's avatar
AlexStocks committed
package main

import (
	"context"
AlexStocks's avatar
AlexStocks committed
	"fmt"
	"os"
	"os/signal"
	"syscall"
	"time"
)
pantianying's avatar
pantianying committed
import (
	hessian "github.com/apache/dubbo-go-hessian2"
pantianying's avatar
pantianying committed
)
AlexStocks's avatar
AlexStocks committed

import (
fangyincheng's avatar
fangyincheng committed
	"github.com/apache/dubbo-go/common/logger"
	_ "github.com/apache/dubbo-go/common/proxy/proxy_factory"
	"github.com/apache/dubbo-go/config"
pantianying's avatar
pantianying committed
	"github.com/apache/dubbo-go/protocol/dubbo"
	_ "github.com/apache/dubbo-go/registry/protocol"
	_ "github.com/apache/dubbo-go/filter/impl"
	_ "github.com/apache/dubbo-go/cluster/cluster_impl"
	_ "github.com/apache/dubbo-go/cluster/loadbalance"
	_ "github.com/apache/dubbo-go/registry/zookeeper"
AlexStocks's avatar
AlexStocks committed
)

var (
	survivalTimeout int = 10e9
)

// they are necessary:
// 		export CONF_CONSUMER_FILE_PATH="xxx"
// 		export APP_LOG_CONF_FILE="xxx"
AlexStocks's avatar
AlexStocks committed
func main() {

pantianying's avatar
pantianying committed
	hessian.RegisterJavaEnum(Gender(MAN))
	hessian.RegisterJavaEnum(Gender(WOMAN))
	hessian.RegisterPOJO(&User{})
pantianying's avatar
pantianying committed
	config.Load()

	println("\n\ntest")
	test()
	println("\n\ntest1")
	test1()
	println("\n\ntest2")
	test2()
pantianying's avatar
pantianying committed
	println("\n\ntest3")
pantianying's avatar
pantianying committed
	test3()
	initSignal()
}

func initSignal() {
	signals := make(chan os.Signal, 1)
	// It is not possible to block SIGKILL or syscall.SIGSTOP
	signal.Notify(signals, os.Interrupt, os.Kill, syscall.SIGHUP,
		syscall.SIGQUIT, syscall.SIGTERM, syscall.SIGINT)
	for {
		sig := <-signals
		logger.Infof("get signal %s", sig.String())
		switch sig {
		case syscall.SIGHUP:
			// reload()
		default:
			go time.AfterFunc(time.Duration(survivalTimeout), func() {
				logger.Warnf("app exit now by force...")
				os.Exit(1)
			})

			// 要么fastFailTimeout时间内执行完毕下面的逻辑然后程序退出,要么执行上面的超时函数程序强行退出
			fmt.Println("app exit now...")
			return
		}
	}
}

func println(format string, args ...interface{}) {
	fmt.Printf("\033[32;40m"+format+"\033[0m\n", args...)
}

func test() {
	println("\n\n\necho")
	res, err := userProvider.Echo(context.TODO(), "OK")
fangyincheng's avatar
fangyincheng committed
	println("res: %v\n", res)
fangyincheng's avatar
fangyincheng committed
	time.Sleep(3e9)
AlexStocks's avatar
AlexStocks committed

	println("\n\n\nstart to test dubbo")
	user := &User{}
	err = userProvider.GetUser(context.TODO(), []interface{}{"A003"}, user)
AlexStocks's avatar
AlexStocks committed
	if err != nil {
		panic(err)
AlexStocks's avatar
AlexStocks committed
	}
	println("response result: %v", user)
AlexStocks's avatar
AlexStocks committed

	println("\n\n\nstart to test dubbo - GetUser0")
	ret, err := userProvider.GetUser0("A003", "Moorse")
	if err != nil {
		panic(err)
	}
	println("response result: %v", ret)
fangyincheng's avatar
fangyincheng committed
	println("\n\n\nstart to test dubbo - GetUsers")
	ret1, err := userProvider.GetUsers([]interface{}{[]interface{}{"A002", "A003"}})
fangyincheng's avatar
fangyincheng committed
	if err != nil {
		panic(err)
	}
	println("response result: %v", ret1)

	println("\n\n\nstart to test dubbo - getUser")
	var i int32 = 1
	err = userProvider.GetUser2(context.TODO(), []interface{}{i}, user)
	println("response result: %v", user)
	println("\n\n\nstart to test dubbo - GetUser3")
	err = userProvider.GetUser3()
	if err != nil {
		panic(err)
	println("\n\n\nstart to test dubbo - getErr")
	user = &User{}
	err = userProvider.GetErr(context.TODO(), []interface{}{"A003"}, user)
	if err == nil {
		panic("err is nil")
	println("getErr - error: %v", err)
	println("\n\n\nstart to test dubbo illegal method")
	err = userProvider.GetUser1(context.TODO(), []interface{}{"A003"}, user)
	if err == nil {
		panic("err is nil")
	}
	println("error: %v", err)
}

func test1() {
	println("\n\n\necho")
	res, err := userProvider1.Echo(context.TODO(), "OK")
		panic(err)
	println("res: %v\n", res)
AlexStocks's avatar
AlexStocks committed

AlexStocks's avatar
AlexStocks committed

	println("\n\n\nstart to test dubbo")
	user := &User{}
	err = userProvider1.GetUser(context.TODO(), []interface{}{"A003"}, user)
	if err != nil {
		panic(err)
	}
	println("response result: %v", user)
AlexStocks's avatar
AlexStocks committed

	println("\n\n\nstart to test dubbo - GetUser0")
	ret, err := userProvider1.GetUser0("A003", "Moorse")
	if err != nil {
		panic(err)
AlexStocks's avatar
AlexStocks committed
	}
	println("response result: %v", ret)

	println("\n\n\nstart to test dubbo - GetUsers")
	ret1, err := userProvider1.GetUsers([]interface{}{[]interface{}{"A002", "A003"}})
	if err != nil {
		panic(err)
	}
	println("response result: %v", ret1)

	println("\n\n\nstart to test dubbo - getUser")
	user = &User{}
	var i int32 = 1
	err = userProvider1.GetUser2(context.TODO(), []interface{}{i}, user)
	if err != nil {
		panic(err)
	}
	println("response result: %v", user)

	println("\n\n\nstart to test dubbo - GetUser3")
	err = userProvider1.GetUser3()
	if err != nil {
		panic(err)
	}
	println("succ!")

	println("\n\n\nstart to test dubbo - getErr")
	user = &User{}
	err = userProvider1.GetErr(context.TODO(), []interface{}{"A003"}, user)
	if err == nil {
		panic("err is nil")
	}
	println("getErr - error: %v", err)

	println("\n\n\nstart to test dubbo illegal method")
	err = userProvider1.GetUser1(context.TODO(), []interface{}{"A003"}, user)
	if err == nil {
		panic("err is nil")
	}
	println("error: %v", err)
AlexStocks's avatar
AlexStocks committed
}
func test2() {
	println("\n\n\necho")
	res, err := userProvider2.Echo(context.TODO(), "OK")
	if err != nil {
		panic(err)
	}
	println("res: %v\n", res)

	time.Sleep(3e9)

	println("\n\n\nstart to test dubbo")
	user := &User{}
	err = userProvider2.GetUser(context.TODO(), []interface{}{"A003"}, user)
	if err != nil {
		panic(err)
	}
	println("response result: %v", user)

	println("\n\n\nstart to test dubbo - GetUser0")
	ret, err := userProvider2.GetUser0("A003", "Moorse")
	if err != nil {
		panic(err)
	}
	println("response result: %v", ret)

	println("\n\n\nstart to test dubbo - GetUsers")
	ret1, err := userProvider2.GetUsers([]interface{}{[]interface{}{"A002", "A003"}})
	if err != nil {
		panic(err)
	}
	println("response result: %v", ret1)

	println("\n\n\nstart to test dubbo - getUser")
	user = &User{}
	var i int32 = 1
	err = userProvider2.GetUser2(context.TODO(), []interface{}{i}, user)
	if err != nil {
		panic(err)
	}
	println("response result: %v", user)

	println("\n\n\nstart to test dubbo - GetUser3")
	err = userProvider2.GetUser3()
	if err != nil {
		panic(err)
	}
	println("succ!")

	println("\n\n\nstart to test dubbo - getErr")
	user = &User{}
	err = userProvider2.GetErr(context.TODO(), []interface{}{"A003"}, user)
	if err == nil {
		panic("err is nil")
	}
	println("getErr - error: %v", err)

	println("\n\n\nstart to test dubbo illegal method")
	err = userProvider2.GetUser1(context.TODO(), []interface{}{"A003"}, user)
	if err == nil {
		panic("err is nil")
	}
	println("error: %v", err)
pantianying's avatar
pantianying committed
func test3() {
	var appName = "UserProviderGer"
	var referenceConfig = config.ReferenceConfig{
pantianying's avatar
pantianying committed
		InterfaceName: "com.ikurento.user.UserProvider",
		Cluster:       "failover",
		Registry:      "hangzhouzk",
		Protocol:      dubbo.DUBBO,
pantianying's avatar
pantianying committed
		Generic:       true,
pantianying's avatar
pantianying committed
	}
pantianying's avatar
pantianying committed
	referenceConfig.GenericLoad(appName) //appName is the unique identification of RPCService
pantianying's avatar
pantianying committed

pantianying's avatar
pantianying committed
	time.Sleep(3 * time.Second)
pantianying's avatar
pantianying committed
	println("\n\n\nstart to generic invoke")
pantianying's avatar
pantianying committed
	resp, err := referenceConfig.GetRPCService().(*config.GenericService).Invoke([]interface{}{"GetUser", []string{"java.lang.String"}, []interface{}{"A003"}})
pantianying's avatar
pantianying committed
	if err != nil {
		panic(err)
	}
pantianying's avatar
pantianying committed
	println("res: %v\n", resp)
	println("succ!")