consumer.go 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. package rabbitMQ
  2. import (
  3. "github.com/streadway/amqp"
  4. "strings"
  5. )
  6. func NewConsumer(exchange Exchange) (*Consumer, error) {
  7. conn, err := NewConnect(exchange.Dns)
  8. if err != nil {
  9. return nil, err
  10. }
  11. channel, err := conn.Channel()
  12. if err != nil {
  13. return nil, err
  14. }
  15. consumer := &Consumer{
  16. conn: conn,
  17. channel: channel,
  18. }
  19. return consumer, nil
  20. }
  21. func (c *Consumer) Subscribe(queueName string) (<-chan amqp.Delivery, error) {
  22. return c.channel.Consume(queueName, "", true, false, false, false, nil)
  23. }
  24. func (c *Consumer) SubscribeMulti(queueNames ...string) error {
  25. exchange := "topic_logs"
  26. err := c.channel.ExchangeDeclare(exchange, "topic", true, false, false, false, nil)
  27. if err != nil {
  28. println(err.Error())
  29. return err
  30. }
  31. for _, queueName := range queueNames {
  32. q, err := c.channel.QueueDeclare(queueName, true, false, false, false, nil)
  33. if err != nil {
  34. println(err.Error())
  35. return err
  36. }
  37. bindingKey := strings.Join([]string{queueName, "*"}, ".")
  38. err = c.channel.QueueBind(q.Name, bindingKey, exchange, false, nil)
  39. if err != nil {
  40. println(err.Error())
  41. return err
  42. }
  43. }
  44. c.queues = queueNames
  45. return nil
  46. }
  47. func (c *Consumer) HandlerMulti(process func(body []byte)) error {
  48. for _, queue := range c.queues {
  49. msgs, err := c.channel.Consume(queue, "", true, false, false, false, nil)
  50. if err != nil {
  51. println(err.Error())
  52. return err
  53. }
  54. go func() {
  55. for msg := range msgs {
  56. func(msg amqp.Delivery) {
  57. process(msg.Body)
  58. }(msg)
  59. }
  60. }()
  61. }
  62. return nil
  63. }
  64. func (c *Consumer) Handler(queueName string, handler func(body []byte) error) error {
  65. ch, err := c.channel.Consume(queueName, "", true, false, false, false, nil)
  66. if err != nil {
  67. return err
  68. }
  69. for delivery := range ch {
  70. delivery := delivery
  71. go func() {
  72. err := handler(delivery.Body)
  73. if err != nil {
  74. println(err.Error())
  75. //return c.channel.Ack()
  76. }
  77. }()
  78. }
  79. return nil
  80. }
  81. func (c *Consumer) Close() {
  82. c.channel.Close()
  83. c.conn.Close()
  84. }