2021-06-10

标题rabbitmq安装,部署

         ## 安裝 rabbitMQ
         我使用的是centos8,安装rabbitmq没有配置文件,全部使用命令配置,可能是因为教程版本和现在有差异,最后都能正常运行

下载rpm软件包

  • wget [https://packages.erlang-solutions.com/erlang-solutions-1.0-1.noarch.rpm]

安装rpm软件包

  • rpm -Uvh erlang-solutions-1.0-1.noarch.rpm

安装epel仓库

  • yum install epel-release

安装erlang

  • yum install erlang

下载rabbitmq

  • wget http://www.rabbitmq.com/releases/rabbitmq-server/v3.6.6/rabbitmq-server-3.6.6-1.el7.noarch.rpm

安装rebbitmq

  • yum install rabbitmq-server-3.6.6-1.el7.noarch.rpm

完成后启动服务:

  • service rabbitmq-server start

可以查看服务状态:

  • service rabbitmq-server status

命令行开启web图形管理

  • rabbitmq-plugins enable rabbitmq_management

测试 ( 返回html代表成功 )

  • curl http://localhost:15672

打开15672端口

  • firewall-cmd --add-port=15672/tcp --permanent

打开5672端口

  • firewall-cmd --add-port=5672/tcp --permanent

设置ip

  • iptables -I INPUT -m tcp -p tcp --dport 15672 -j ACCEPT

保存

  • iptables-save

创建管理用户 ( uname pwd )

  • rabbitmqctl add_user admin admin

设置权限 ( 超级管理员 )

  • rabbitmqctl set_user_tags admin administrator

查看用户列表

  • rabbitmqctl list_users

————————————————
2、命令行操作

rabbitmqctl add_user test passwd
设置该用户为administrator角色:

rabbitmqctl set_user_tags test administrator
设置权限:

rabbitmqctl set_permissions -p ‘/’ test ‘.’ ‘.’ ‘.’
重启rabbitmq服务:

sudo service rabbitmq-server restart
————————————————
3如果需要使用防火墙等,
开启防火墙命令:

systemctl start firewalld.service

重启防火墙命令:

firewall-cmd --reload 或者 service firewalld restart

查看端口列表:

firewall-cmd --permanent --list-port

禁用防火墙

systemctl stop firewalld

设置开机启动

systemctl enable firewalld

停止并禁用开机启动

sytemctl disable firewalld

查看防火墙状态
systemctl status firewalld或者firewall-cmd --state
#/etc/init.d/iptables status
关闭防火墙服务:
#/etc/init.d/iptables stop
————————————————
以上来自网络转载,感谢各位大佬们

在你提到的 SQL 查询中: ```sql select id, stt dt, 1 p from test5 union select id, edt dt, -1 p from test5 ``` 这里的 `p` 是一个人为添加的 **标志字段(或称为权重字段)**,用来表示某个时间点是“主播上线”还是“主播下线”。 --- ### ✅ `p` 字段的作用解释如下: - `p = 1`:表示在该时间点有一个主播 **开始直播(上线)** - `p = -1`:表示在该时间点有一个主播 **结束直播(下线)** 这个技巧常用于解决“**最多重叠区间问题**”,比如求**同一时刻最多有多少个主播在线**。 我们将每个开播时间标记为 +1,关播时间标记为 -1,然后按时间顺序排序,对 `p` 值做累加(前缀和),就可以得到任意时刻正在直播的主播人数。 --- ### 🔍 举个例子说明 原始数据: | id | stt | edt | |------|----------------------|----------------------| |1001|2021-06-14 12:12:12|2021-06-14 18:12:12| |1003|2021-06-14 13:12:12|2021-06-14 16:12:12| 转换后变成事件流(t1): | id | dt | p | |------|----------------------|----| |1001|2021-06-14 12:12:12| 1 | ← 开播 +1 |1003|2021-06-14 13:12:12| 1 | ← 开播 +1 |1003|2021-06-14 16:12:12|-1 | ← 下播 -1 |1001|2021-06-14 18:12:12|-1 | ← 下播 -1 然后我们按照 `dt` 时间排序,并计算累计值(即当前在线主播数): ```text 时间 事件类型 当前人数变化 累计在线人数 2021-06-14 12:12:12 开播(id=1001) +1 1 2021-06-14 13:12:12 开播(id=1003) +1 2 2021-06-14 16:12:12 下播(id=1003) -1 1 2021-06-14 18:12:12 下播(id=1001) -1 0 ``` 所以最高同时在线人数是 **2人**。 --- ### 📌 完整 SQL 思路(以 Hive/MySQL 为例) ```sql -- 第一步:将开播和关播转为带符号的事件流 with events as ( select id, stt as dt, 1 as p from test5 union all select id, edt as dt, -1 as p from test5 ), -- 第二步:按时间排序,注意时间相同时,优先处理上线再处理下线?实际建议:同时间先+1后-1 sorted_events as ( select dt, p from events order by dt, p desc -- 先处理 +1 再处理 -1,防止漏算峰值 ) -- 第三步:使用窗口函数累加 p,找出最大值 select max(online_cnt) as max_concurrent_streamers from ( select dt, sum(p) over (order by dt, p desc rows between unbounded preceding and current row) as online_cnt from sorted_events ) t; ``` > 💡 注意:这里用 `UNION ALL` 比 `UNION` 更高效,因为不需要去重。 --- ### ❗关键点总结 - `p` 是一个虚拟的增量字段,用于统计人数变化。 - 把每一个“开始”看作 +1,“结束”看作 -1,构建时间轴上的变化事件。 - 对这些事件按时间排序并累加 `p`,就能得到每一时刻的在线人数。 - 最大累加值就是平台最高峰同时在线的主播人数。 --- ### ✅ 示例 Python 实现(便于理解逻辑) ```python from datetime import datetime # 模拟数据 data = [ (1001, '2021-06-14 12:12:12', '2021-06-14 18:12:12'), (1003, '2021-06-14 13:12:12', '2021-06-14 16:12:12'), (1004, '2021-06-14 13:15:12', '2021-06-14 20:12:12'), (1002, '2021-06-14 15:12:12', '2021-06-14 16:12:12'), (1005, '2021-06-14 15:18:12', '2021-06-14 20:12:12'), (1001, '2021-06-14 20:12:12', '2021-06-14 23:12:12'), (1006, '2021-06-14 21:12:12', '2021-06-14 23:15:12'), (1007, '2021-06-14 22:12:12', '2021-06-14 23:10:12'), ] events = [] for row in data: _id, stt_str, edt_str = row stt = datetime.strptime(stt_str, '%Y-%m-%d %H:%M:%S') edt = datetime.strptime(edt_str, '%Y-%m-%d %H:%M:%S') events.append((stt, 1)) events.append((edt, -1)) # 排序:先按时间,再按 +1 在前、-1 在后 events.sort(key=lambda x: (x[0], -x[1])) online = 0 max_online = 0 for time, delta in events: online += delta if online > max_online: max_online = online print("平台最高峰同时在线主播人数:", max_online) ``` 输出结果为: ``` 平台最高峰同时在线主播人数: 4 ``` (你可以验证:在 `2021-06-14 15:18:12 ~ 16:12:12` 之间有 4 位主播同时在线) --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值