1
0
mirror of https://github.com/go-micro/go-micro.git synced 2024-12-30 10:10:44 +02:00

feat(web): add start and stop functions to the web (#2519)

This commit is contained in:
JellyTony 2022-07-01 15:06:27 +08:00 committed by GitHub
parent 87c96bc4d0
commit 96576a612a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 34 additions and 5 deletions

View File

@ -34,6 +34,7 @@ type service struct {
running bool
static bool
exit chan chan error
ex chan bool
}
func newService(opts ...Option) Service {
@ -42,6 +43,7 @@ func newService(opts ...Option) Service {
opts: options,
mux: http.NewServeMux(),
static: true,
ex: make(chan bool),
}
s.srv = s.genSrv()
return s
@ -90,7 +92,7 @@ func (s *service) genSrv() *registry.Service {
}
}
func (s *service) run(exit chan bool) {
func (s *service) run() {
s.RLock()
if s.opts.RegisterInterval <= time.Duration(0) {
s.RUnlock()
@ -104,7 +106,7 @@ func (s *service) run(exit chan bool) {
select {
case <-t.C:
s.register()
case <-exit:
case <-s.ex:
t.Stop()
return
}
@ -440,6 +442,32 @@ func (s *service) Init(opts ...Option) error {
return nil
}
func (s *service) Start() error {
if err := s.start(); err != nil {
return err
}
if err := s.register(); err != nil {
return err
}
// start reg loop
go s.run()
return nil
}
func (s *service) Stop() error {
// exit reg loop
close(s.ex)
if err := s.deregister(); err != nil {
return err
}
return s.stop()
}
func (s *service) Run() error {
if err := s.start(); err != nil {
return err
@ -467,8 +495,7 @@ func (s *service) Run() error {
}
// start reg loop
ex := make(chan bool)
go s.run(ex)
go s.run()
ch := make(chan os.Signal, 1)
if s.opts.Signal {
@ -489,7 +516,7 @@ func (s *service) Run() error {
}
// exit reg loop
close(ex)
close(s.ex)
if err := s.deregister(); err != nil {
return err

View File

@ -16,6 +16,8 @@ type Service interface {
Options() Options
Handle(pattern string, handler http.Handler)
HandleFunc(pattern string, handler func(http.ResponseWriter, *http.Request))
Start() error
Stop() error
Run() error
}