| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 | package mainimport (	"context"	"flag"	"fmt"	"github.com/longjoy/micro-go-course/section11/user/dao"	"github.com/longjoy/micro-go-course/section11/user/endpoint"	"github.com/longjoy/micro-go-course/section11/user/redis"	"github.com/longjoy/micro-go-course/section11/user/service"	"github.com/longjoy/micro-go-course/section11/user/transport"	"log"	"net/http"	"os"	"os/signal"	"strconv"	"syscall")func main()  {	var (		// 服务地址和服务名		servicePort = flag.Int("service.port", 10086, "service port")		//waitTime = flag.Int("wait.time", 10, "wait time")		mysqlAddr = flag.String("mysql.addr", "127.0.0.1", "mysql addr")		mysqlPort = flag.String("mysql.port", "3306", "mysql port")		redisAddr = flag.String("redis.addr", "127.0.0.1", "redis addr")		redisPort = flag.String("redis.port", "6379", "redis port")	)	flag.Parse()	ctx := context.Background()	errChan := make(chan error)	err := dao.InitMysql(*mysqlAddr, *mysqlPort, "root", "123456", "user")	if err != nil{		log.Fatal(err)	}	err = redis.InitRedis(*redisAddr, *redisPort, "" )	if err != nil{		log.Fatal(err)	}	userService := service.MakeUserServiceImpl(&dao.UserDAOImpl{})	userEndpoints := &endpoint.UserEndpoints{		endpoint.MakeRegisterEndpoint(userService),		endpoint.MakeLoginEndpoint(userService),	}	r := transport.MakeHttpHandler(ctx, userEndpoints)	go func() {		errChan <- http.ListenAndServe(":"  + strconv.Itoa(*servicePort), r)	}()	go func() {		// 监控系统信号,等待 ctrl + c 系统信号通知服务关闭		c := make(chan os.Signal, 1)		signal.Notify(c, syscall.SIGINT, syscall.SIGTERM)		errChan <- fmt.Errorf("%s", <-c)	}()	error := <-errChan	log.Println(error)}
 |