consumer.go 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  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. return nil
  45. }
  46. func (c *Consumer) Handler(queueName string, handler func(body []byte) error) error {
  47. ch, err := c.channel.Consume(queueName, "", true, false, false, false, nil)
  48. if err != nil {
  49. return err
  50. }
  51. for delivery := range ch {
  52. delivery := delivery
  53. go func() {
  54. err := handler(delivery.Body)
  55. if err != nil {
  56. println(err.Error())
  57. //return c.channel.Ack()
  58. }
  59. }()
  60. }
  61. return nil
  62. }
  63. func (c *Consumer) Close() {
  64. c.channel.Close()
  65. c.conn.Close()
  66. }