RabbitMQ调用API删除队列

项目中需要实现清空RabbitMQ里面的队列,就写了这篇文章
首先,管理端是能实现删除某个队列的功能的,所以我们通过F12看一下管理端调用的是什么接口,这里也可以使用fiddler来代理,监控待用的api,两种方式都是可以的
在这里插入图片描述
我们点击删除以后,可以捕捉到调用的api是http://192.168.1.123:15672/api/queues/%2F/worker_wh,而且用的Method请求方式是Delete
在这里插入图片描述
随后我们进到管理端api页面,在里面我们可以找到这个接口以及它的具体描述,描述主要包含下面信息

  • 前面的X代表的是可以执行什么方式调用api,我们需要的这个api就可以delete,put,get
  • 后面描述我们主要看delete的信息, 如果在api的参数中添加了if-empty=true 或者 if-unused=true,当队列里面如果有消息没有消费掉或者有人正在使用,则会阻碍我们删除这个队列,不过我们不加就没关系
  • 还有就是我们url中的/%2F这边也给出了解释,许多 URI 需要虚拟主机的名称作为路径的一部分,因为名称仅唯一标识虚拟主机中的对象。由于默认虚拟主机称为“/”,因此需要将其编码为/%2F
    在这里插入图片描述在这里插入图片描述
    接下里我们开始用postman调用api,这里会发现返回401,这里意思是没有认证信息
    在这里插入图片描述
    我们需要在Authorization里面选择Basic Auth,然后填入我们管理端的用户名和密码,调用如下,成功删除了队列
    在这里插入图片描述
    点击右边的代码按钮,选择c#我们可以看到c#的代码如下
    在这里插入图片描述
    把下面代码赋值粘贴到我们的程序里面,这里我们做了一些删减和增加
            string UserNameAndPassword = "admin:123456";
            var client = new RestClient("http://192.168.1.123:15672/api/queues/%2F/worker_wh");
            var request = new RestRequest("", Method.Delete);
            request.AddHeader("Authorization", "Basic "+ Convert.ToBase64String(Encoding.UTF8.GetBytes(UserNameAndPassword)));
            var body = @"";
            request.AddParameter("text/plain", body, ParameterType.RequestBody);
            RestResponse response = client.Execute(request);
            Console.WriteLine(response.Content);

主要将两个点

  • 第一个需要引用RestSharp的Package,最新的类库里面可能构造函数或者属性有变化,自己判断修改
  • 第二个如何获取Authorization,它其实是两个部分组成,一个是“Basic ”(此处有空格),一个是Base64编码的用户名和密码,字符串UserNameAndPassword里面的形式是“用户名:密码”,读者按照自己管理端的用户名密码来改变即可
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Golang 中调用 RabbitMQ 的消息队列监控 API 可以使用标准的 `net/http` 包来发送 HTTP 请求并处理响应。以下是一个简单的示例代码,用于获取 RabbitMQ队列信息: ```go package main import ( "encoding/json" "fmt" "io/ioutil" "net/http" ) type QueueInfo struct { Name string `json:"name"` Messages int `json:"messages"` Consumers int `json:"consumers"` } func main() { // RabbitMQ API URL url := "http://localhost:15672/api/queues" // 创建 HTTP 客户端 client := &http.Client{} // 创建 HTTP 请求 req, err := http.NewRequest("GET", url, nil) if err != nil { fmt.Println("创建请求失败:", err) return } // 设置 Basic Auth 认证(如果需要) req.SetBasicAuth("username", "password") // 发送请求并获取响应 resp, err := client.Do(req) if err != nil { fmt.Println("发送请求失败:", err) return } defer resp.Body.Close() // 读取响应内容 body, err := ioutil.ReadAll(resp.Body) if err != nil { fmt.Println("读取响应失败:", err) return } // 解析 JSON 响应 var queues []QueueInfo err = json.Unmarshal(body, &queues) if err != nil { fmt.Println("解析响应失败:", err) return } // 输出队列信息 for _, queue := range queues { fmt.Printf("队列名称: %s\n", queue.Name) fmt.Printf("消息数量: %d\n", queue.Messages) fmt.Printf("消费者数量: %d\n", queue.Consumers) fmt.Println("----------------------") } } ``` 请注意,上述代码中的 `url` 变量需要根据你的 RabbitMQ 配置进行相应调整。如果 RabbitMQ 设置了用户名和密码的认证,你需要使用 `SetBasicAuth` 方法设置 Basic Auth 认证信息。 该示例代码发送一个 HTTP GET 请求到 RabbitMQ 的 `/api/queues` 接口,获取所有队列的信息,并将其解析为 `QueueInfo` 结构体。然后,你可以根据需要处理和使用这些队列信息。 希望这个示例能帮助到你。如果有任何其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值