You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

client.go 962 B

2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. package coordinator
  2. import (
  3. "sync"
  4. "gitlink.org.cn/cloudream/common/pkgs/mq"
  5. stgmq "gitlink.org.cn/cloudream/storage/common/pkgs/mq"
  6. )
  7. type Client struct {
  8. rabbitCli *mq.RabbitMQTransport
  9. }
  10. func NewClient(cfg mq.Config) (*Client, error) {
  11. rabbitCli, err := mq.NewRabbitMQTransport(cfg, stgmq.COORDINATOR_QUEUE_NAME, "")
  12. if err != nil {
  13. return nil, err
  14. }
  15. return &Client{
  16. rabbitCli: rabbitCli,
  17. }, nil
  18. }
  19. func (c *Client) Close() {
  20. c.rabbitCli.Close()
  21. }
  22. type Pool interface {
  23. Acquire() (*Client, error)
  24. Release(cli *Client)
  25. }
  26. type pool struct {
  27. mqcfg mq.Config
  28. shared *Client
  29. lock sync.Mutex
  30. }
  31. func NewPool(mqcfg mq.Config) Pool {
  32. return &pool{
  33. mqcfg: mqcfg,
  34. }
  35. }
  36. func (p *pool) Acquire() (*Client, error) {
  37. p.lock.Lock()
  38. defer p.lock.Unlock()
  39. if p.shared == nil {
  40. var err error
  41. p.shared, err = NewClient(p.mqcfg)
  42. if err != nil {
  43. return nil, err
  44. }
  45. }
  46. return p.shared, nil
  47. }
  48. func (p *pool) Release(cli *Client) {
  49. }

本项目旨在将云际存储公共基础设施化,使个人及企业可低门槛使用高效的云际存储服务(安装开箱即用云际存储客户端即可,无需关注其他组件的部署),同时支持用户灵活便捷定制云际存储的功能细节。