wvp-gb28181-pro搭建流媒体服务器,内存占用过高问题

直接给出解决办法,端口暴露的太多了,暴露了500个端口导致从3g---->11g

遇到的问题,直接使用镜像《648540858/wvp_pro:latest》在宿主机上运行,如我下面的博客

https://blog.csdn.net/weixin_41012767/article/details/137112338?spm=1001.2014.3001.5502

docker run  --env WVP_IP="自己电脑的ip" -it -p 18080:18080 -p 30000-30500:30000-30500/udp -p 30000-30500:30000-30500/tcp -p 80:80 -p 5060:5060 -p 5060:5060/udp 648540858/wvp_pro

 可以看暴露了1000个端口

为了解决内存过高的问题加了以下解决办法

1.限制java的运行的堆栈 

-Xms128m -Xmx256m

2.增加了docker的内存限制

方案一:
version: '3.7'
services:zxcloudserver:image: 648540858/wvp_proprivileged: truelogging:driver: "json-file"options:max-size: "10m"max-file: "3"restart: alwayscontainer_name: xxxxdeploy:resources:limits:memory: 5g
方案二:
version: 'xxx'
services:zxcloudserver:image: 648540858/wvp_proprivileged: truelogging:driver: "json-file"options:max-size: "10m"max-file: "3"restart: alwayscontainer_name: xxxxmem_limit: 5g

 限制截图

 实际上限制是起来作用,但是宿主机内存还是很高,最后尝试改端口发现了,端口开多了内存占用非常高

------------------------------------分割线----------------------------------------------------------------------------------

以下是我使用的wvp记录跟上面没关系

1.将docker内部的这三个文件拷贝出来

root@4d1dfa5b7c08:/opt# tree -L 2
.
├── assist #这个是wvp-GB28181-pro的辅助录像程序,它提供了录像控制和录像合并下载接口。它可以与ZLMediaKit一起使用,为WVP-PRO提供国标28181的媒体部分的实现,并支持各种视频流格式的分发
│   ├── config
│   ├── logs
│   ├── nohup.out
│   └── wvp-pro-assist-1.0.0-20211119095941.jar
├── media #这个是ZLMediaKit
│   ├── api_tester_h264_media_server
│   ├── api_tester_pusher
│   ├── api_tester_server
│   ├── api_tester_websocket
│   ├── bom
│   ├── config.ini #重点 ZLMediaKit的配置文件
│   ├── default.pem
│   ├── ffmpeg
│   ├── libflv.a
│   ├── libjsoncpp.a
│   ├── libmk_api.so
│   ├── libmov.a
│   ├── libmpeg.a
│   ├── libzlmediakit.a
│   ├── libzltoolkit.a
│   ├── log
│   ├── MediaServer
│   ├── tab
│   ├── test_bench_proxy
│   ├── test_bench_pull
│   ├── test_bench_push
│   ├── test_httpApi
│   ├── test_httpClient
│   ├── test_pusher
│   ├── test_pusherMp4
│   ├── test_rtcp
│   ├── test_rtp
│   ├── test_server
│   ├── test_sortor
│   ├── test_wsClient
│   ├── test_wsServer
│   └── www
└── wvp├── config #wvp的配置文件里面是application.yml├── logs├── run.sh #重点 wvp的镜像的运行脚本├── static #wvp的前端└── wvp-pro-2.0-11190958.jar11 directories, 33 files

软件的脚本如下,不需要辅助录像,可以注释掉内置的redis,和assist

#!/bin/bash
echo "----REDIS_HOST--------"+${REDIS_HOST}echo  "------WVP_IP-----"${WVP_IP}
echo  "------WVP_CONFIG----1-----"${WVP_CONFIG}
#redis-server --daemonize yes --bind 0.0.0.0
cd /opt/assist
nohup java ${ASSIST_JVM_CONFIG} -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/assist/heapdump/ -jar *.jar --userSettings.record=/opt/media/www/record/  &
nohup /opt/media/MediaServer -d -m 3 &cd /opt/wvp
echo  "------WVP_CONFIG----2-----"+${WVP_CONFIG}
if [${WVP_CONFIG}]; thenjava  ${WVP_JVM_CONFIG} -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/wvp/heapdump/ -jar *.jar --spring.config.location=/opt/wvp/config/application.yml --media.record-assist-port=18081 ${WVP_CONFIG}
elsejava  ${WVP_JVM_CONFIG} -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/opt/wvp/heapdump/ -jar *.jar --spring.config.location=/opt/wvp/config/application.yml --media.record-assist-port=18081 --media.ip=127.0.0.1 --media.hook-ip=127.0.0.1 --media.sdp-ip=${WVP_IP} --sip.ip=${WVP_IP} --media.stream-ip=${WVP_IP}fi

 wvp的application.yml的内容如下

spring:# REDIS数据库配置redis:# [必须修改] Redis服务器IP, REDIS安装在本机的,使用127.0.0.1host: ${REDIS_HOST}# [必须修改] 端口号port: ${REDIS_PORT}# [可选] 数据库 DBdatabase: ${REDIS_DATABASE}# [可选] 访问密码,若你的redis服务器没有设置密码,就不需要用密码去连接password: ${REDIS_PASSWORD}# [可选] 超时时间timeout: 10000# [可选] jdbc数据库配置, 项目使用sqlite作为数据库,一般不需要配置datasource:# 使用mysql 打开23-28行注释, 删除29-36行# name: wvp# url: jdbc:mysql://127.0.0.1:3306/wvp?useUnicode=true&characterEncoding=UTF8&rewriteBatchedStatements=true# username:# password:# type: com.alibaba.druid.pool.DruidDataSource# driver-class-name: com.mysql.cj.jdbc.Drivername: eioturl: jdbc:sqlite::resource:wvp.sqliteusername:password:type: com.alibaba.druid.pool.DruidDataSourcedriver-class-name:  org.sqlite.JDBCmax-active: 1min-idle: 1# [可选] WVP监听的HTTP端口, 网页和接口调用都是这个端口
server:port: 18080# 作为28181服务器的配置
sip:# [必须修改] 本机的IPip: ${WVP_HOST}# [可选] 28181服务监听的端口port: 5060# 根据国标6.1.2中规定,domain宜采用ID统一编码的前十位编码。国标附录D中定义前8位为中心编码(由省级、市级、区级、基层编号组成,参照GB/T 2260-2007)# 后两位为行业编码,定义参照附录D.3# 3701020049标识山东济南历下区 信息行业接入# [可选]domain: ${WVP_DOMAIN:4401020049}# [可选]id: ${WVP_ID:44010200492000000001}# [可选] 默认设备认证密码,后续扩展使用设备单独密码, 移除密码将不进行校验password: ${WVP_PWD:admin123}#zlm 默认服务器配置
media:# [必须修改] zlm服务器的内网IPip: 127.0.0.1# [必须修改] zlm服务器的http.porthttp-port: 8088# [可选] zlm服务器的hook.admin_params=secretsecret: 035c73f7-bb6b-4889-a715-d9eb2d1925cc# 启用多端口模式, 多端口模式使用端口区分每路流,兼容性更好。 单端口使用流的ssrc区分, 点播超时建议使用多端口测试rtp:# [可选] 是否启用多端口模式, 开启后会在portRange范围内选择端口用于媒体流传输enable: true# [可选] 在此范围内选择端口用于媒体流传输,port-range: 30000,3005 # 端口范围# [可选] 国标级联在此范围内选择端口发送媒体流,send-port-range: 30000,30005 # 端口范围# 录像辅助服务, 部署此服务可以实现zlm录像的管理与下载, 0 表示不使用record-assist-port: 18081sdp-ip: ${WVP_HOST}stream-ip: ${WVP_HOST}
# [可选] 日志配置, 一般不需要改
logging:file:name: logs/wvp.logmax-history: 30max-size: 10MBtotal-size-cap: 30MBlevel:com.genersoft.iot: debugcom.genersoft.iot.vmp.storager.dao: infocom.genersoft.iot.vmp.gb28181: info# [根据业务需求配置]
user-settings:# 推流直播是否录制record-push-live: falseauto-apply-play: false# 在线文档: swagger-ui(生产环境建议关闭)
swagger-ui:enabled: true# 版本信息, 不需修改
version:version: "@project.version@"description: "@project.description@"artifact-id: "@project.artifactId@"

assist的配置如下

spring:# REDIS数据库配置redis:# [必须修改] Redis服务器IP, REDIS安装在本机的,使用127.0.0.1host: ${REDIS_HOST:127.0.0.1}# [必须修改] 端口号port: ${REDIS_PORT:6379}# [可选] 数据库 DBdatabase: 0# [可选] 访问密码,若你的redis服务器没有设置密码,就不需要用密码去连接password: ${REDIS_PASSWORD:}# [可选] 超时时间timeout: 10000# [可选] WVP监听的HTTP端口, 网页和接口调用都是这个端口
server:port: 18081# [可选] HTTPS配置, 默认不开启ssl:# [可选] 是否开启HTTPS访问enabled: false# [可选] 证书文件路径,放置在resource/目录下即可,修改xxx为文件名key-store: classpath:xxx.jks# [可选] 证书密码key-password: password# [可选] 证书类型, 默认为jks,根据实际修改key-store-type: JKS# [根据业务需求配置]
userSettings:# [必选 ] zlm配置的录像路径record: /media/lin/Server/ZLMediaKit/dev/ZLMediaKit/release/linux/Debug/www/record# [可选 ] 录像保存时长(单位: 天)每天晚12点自动对过期文件执行清理recordDay: 7# [必选 ] ffmpeg路径ffmpeg: /usr/bin/ffmpeg# [必选 ] ffprobe路径, 一般安装ffmpeg就会自带, 一般跟ffmpeg在同一目录,用于查询文件的信息ffprobe: /usr/bin/ffprobe# [可选] 日志配置, 一般不需要改
logging:file:name: logs/wvp.logmax-history: 30max-size: 10MBtotal-size-cap: 300MBlevel:root: WARNtop:panll:assist: info

 config.ini的配置如下:

; auto-generated by mINI class {[api]
apiDebug=0
defaultSnap=./www/logo.png
secret=035c73f7-bb6b-4889-a715-d9eb2d1925cc
snapRoot=./www/snap/[ffmpeg]
bin=/usr/bin/ffmpeg
cmd=%s -fflags nobuffer -i %s -c:a aac -strict -2 -ar 44100 -ab 48k -c:v libx264  -f flv %s
log=./ffmpeg/ffmpeg.log
snap=%s -i %s -y -f mjpeg -t 0.001 %s[general]
addMuteAudio=1
enableVhost=0
enable_audio=0
flowThreshold=1024
fmp4_demand=0
hls_demand=0
maxStreamWaitMS=15000
mediaServerId=KyYeBTLafedkuipC
mergeWriteMS=0
modifyStamp=0
publishToHls=0
publishToMP4=0
resetWhenRePlay=1
rtmp_demand=0
rtsp_demand=0
streamNoneReaderDelayMS=18000
ts_demand=0[hls]
broadcastRecordTs=0
deleteDelaySec=0
fileBufSize=65536
filePath=./www
segDur=2
segNum=3
segRetain=5[hook]
admin_params=secret=035c73f7-bb6b-4889-a715-d9eb2d1925cc
alive_interval=30.000000
enable=1
on_flow_report=
on_http_access=
on_play=http://127.0.0.1:18080/index/hook/on_play
on_publish=http://127.0.0.1:18080/index/hook/on_publish
on_record_mp4=http://127.0.0.1:18081/api/record/on_record_mp4
on_record_ts=
on_rtsp_auth=
on_rtsp_realm=
on_server_keepalive=
on_server_started=http://127.0.0.1:18080/index/hook/on_server_started
on_shell_login=http://127.0.0.1:18080/index/hook/on_shell_login
on_stream_changed=http://127.0.0.1:18080/index/hook/on_stream_changed
on_stream_none_reader=http://127.0.0.1:18080/index/hook/on_stream_none_reader
on_stream_not_found=http://127.0.0.1:18080/index/hook/on_stream_not_found
timeoutSec=20[http]
charSet=utf-8
dirMenu=1
keepAliveSecond=15
maxReqSize=40960
notFound=<html><head><title>404 Not Found</title></head><body bgcolor="white"><center><h1>您访问的资源不存在!</h1></center><hr><center>ZLMediaKit(git hash:1cba3f4,branch:master,build time:Nov 19 2021 18:00:38)</center></body></html>
port=8088
rootPath=./www
sendBufSize=65536
sslport=443
virtualPath=[multicast]
addrMax=239.255.255.255
addrMin=239.0.0.0
udpTTL=64[record]
appName=record
fastStart=0
fileBufSize=65536
filePath=./www
fileRepeat=0
fileSecond=3600
sampleMS=500[rtmp]
handshakeSecond=15
keepAliveSecond=15
modifyStamp=0
port=1935
sslport=19350[rtp]
audioMtuSize=600
rtpMaxSize=10
videoMtuSize=1400[rtp_proxy]
dumpDir=
port=10000
timeoutSec=15[rtsp]
authBasic=0
directProxy=1
handshakeSecond=15
keepAliveSecond=15
port=554
sslport=332[shell]
maxReqSize=1024
port=9000; } ---

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/21728.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

FASTGPT:可视化开发、运营和使用的AI原生应用

近年来&#xff0c;随着人工智能&#xff08;AI&#xff09;技术的迅猛发展&#xff0c;AI的应用逐渐渗透到各行各业。作为一种全新的开发模式&#xff0c;AI原生应用正逐步成为行业的焦点。在这方面&#xff0c;FASTGPT无疑是一款颇具代表性的产品。本文将详细介绍FASTGPT的设…

Appium自动化环境搭建保姆级教程

APP自动化测试运行环境比较复杂&#xff0c;稍微不注意安装就会失败。我见过不少朋友&#xff0c;装了1个星期&#xff0c;Appium 的运行环境还没有搭好的。 搭建环境本身不是一个有难度的工作&#xff0c;但是 Appium 安装过程中确实存在不少隐藏的比较深的坑&#xff0c;如果…

用友NC pagesServlet SQL注入致RCE漏洞复现(XVE-2024-13067)

0x01 产品简介 用友NC是由用友公司开发的一套面向大型企业和集团型企业的管理软件产品系列。这一系列产品基于全球最新的互联网技术、云计算技术和移动应用技术,旨在帮助企业创新管理模式、引领商业变革。 0x02 漏洞概述 用友NC /portal/pt/servlet/pagesServlet/doPost接口…

操作系统入门系列-MIT6.828(操作系统工程)学习笔记(三)---- xv6初探与实验一(Lab: Xv6 and Unix utilities)

系列文章目录 操作系统入门系列-MIT6.S081&#xff08;操作系统&#xff09;学习笔记&#xff08;一&#xff09;---- 操作系统介绍与接口示例 操作系统入门系列-MIT6.828&#xff08;操作系统工程&#xff09;学习笔记&#xff08;二&#xff09;----课程实验环境搭建&#x…

RocketMQ相关知识知多少

一、RocketMQ的定义 官网网址&#xff1a;领域模型概述 | RocketMQ Apache RocketMQ 自诞生以来&#xff0c;因其架构简单、业务功能丰富、具备极强可扩展性等特点被众多企业开发者以及云厂商广泛采用。历经十余年的大规模场景打磨&#xff0c;RocketMQ 已经成为业内共识的金…

Flink的简单学习二

一 Flink的核心组件 1.1 client 1.将数据流程图DataFlow发送给JobManager。 1.2 JobManager 1.收集client的DataFlow图&#xff0c;将图分解成一个个的task任务&#xff0c;并返回状态更新数据给client 2.JobManager负责作业调度&#xff0c;收集TaskManager的Heartbeat和…

三、基于图像分类预训练编码及图神经网络的预测模型 【框图+源码】

背景&#xff1a; 抽时间补充&#xff0c;先挖个坑。 一、模型结构 二、源码

美团一面:什么是CAS?有什么优缺点?我说你说的是AtomicInteger吗?

引言 传统的并发控制手段&#xff0c;如使用synchronized关键字或者ReentrantLock等互斥锁机制&#xff0c;虽然能够有效防止资源的竞争冲突&#xff0c;但也可能带来额外的性能开销&#xff0c;如上下文切换、锁竞争导致的线程阻塞等。而此时就出现了一种乐观锁的策略&#x…

企业数字化转型的测度难题:基于大语言模型的新方法与新发现

《经济研究》新文章《企业数字化转型的测度难题&#xff1a;基于大语言模型的新方法与新发现》运用机器学习和大语言模型构造一套新的企业数字化转型指标。理论分析和数据交叉验证均表明&#xff0c;构建的指标相对已有方法更准确&#xff1a; 1.第一步&#xff1a;选择“管理…

17.Redis之主从复制

1.主从复制是怎么回事&#xff1f; 分布式系统, 涉及到一个非常关键的问题: 单点问题 单点问题&#xff1a;如果某个服务器程序, 只有一个节点(只搞一个物理服务器, 来部署这个服务器程序) 1.可用性问题,如果这个机器挂了,意味着服务就中断了~ 2.性能/支持的并发量也是比较有限…

【HarmonyOS】鸿蒙系统中应用权限等级介绍、定义、申请授权讲解

【HarmonyOS】鸿蒙系统中应用权限等级介绍、定义、申请授权讲解 针对权限等级&#xff0c;相对于主体来说&#xff0c;会有不同的细分概念。 一、权限APL等级&#xff1a; 首先在鸿蒙系统中&#xff0c;对于权限本身&#xff0c;分为三个等级&#xff1a;normal&#xff0c;s…

SQL面试问题集

目录 Q.左连接和右连接的区别 Q.union 和 union all的区别 1、取结果的交集 2、获取结果后的操作 Q.熟悉开窗函数吗&#xff1f;讲一下row_number和dense_rank的区别。 Q.hive行转列怎么操作的 Q.要求手写的题主要考了聚合函数和窗口函数&#xff0c;row_number()&#…

同一个tomcat不同端口运行不同项目

第一步&#xff1a;修改 server.xml 文件 修改 tomcat 安装目录下 conf/server.xml 文件&#xff0c;需要几个端口就添加几个 Service 节点。 配置 2 个端口&#xff1a;9131 和 9133&#xff0c;于是增加两个 Service 节点。 每个 Service 节点的 name 属性值要设置不同的值…

【MATLAB】雷达信号处理程序源码 雷达系统仿真代码 matlab SAR

【MATLAB】雷达信号处理程序源码 雷达系统仿真代码 matlab SAR 包含以下所有源码,内容如下&#xff1a;&#xff1a; 1、 MATGPR R3探地雷达数据处理 MATLAB 程序 2、 python 雷达图像识别 3、 SAR 雷达回波仿真 matlab 4、 SAR 雷达影像处理源码 5、 STFT 处理 IPIX 雷达…

数据分析常用模型合集(三)同期群、逻辑树、假设检验等

前面两篇文章&#xff0c;我们将比较大、较为系统的分析方法作了一个介绍&#xff0c;本文是最后一篇&#xff0c;将剩余的一些讲一讲。 数据分析常用模型合集&#xff08;二&#xff09;RARRA模型、RFM模型-CSDN博客 剩下的一些模型&#xff0c;其实不应叫做模型&#xff0c;…

qt+ffmpeg 实现音视频播放(四)之音视频同步

在处理音视频数据时&#xff0c;解码音频的数据往往会比解码视频的数据比较慢&#xff0c;所以我们在播放音视频时&#xff0c;音频和视频的数据会出现渐渐对不上的情况。尤其在播放时间越长的时候&#xff0c;这种对不上的现象越明显。 为了解决这一问题&#xff0c;人们想出…

在windows操作系统上安装MariaDB

最近收到关于数据库在哪里看的评论&#xff0c;所以就一不做二不休&#xff0c;把安装数据库的步骤写一篇文章吧。 这篇文章介绍如何在windows上完成MariaDB-10.6.5版本的安装&#xff0c;对应MySQL-8.x版本。 第一步&#xff1a;下载安装包 通过以下网盘链接下载MariaDB-10.6…

国产信创CPU之飞腾CPU剖析

CPU&#xff1a;信创根基&#xff0c;国之重器 国产CPU已形成自主架构、x86、ARM三大阵营。自主阵营中&#xff0c;龙芯、申威分别基于MIPS和Alpha推出loong ISA和SW-64。ARM阵营以鲲鹏、飞腾为代表&#xff0c;利用ARM IP授权开发处理器。x86阵营由海光、兆芯等主导&#xff…

【Linux】操作系统中的文件系统管理:磁盘结构、逻辑存储与文件访问机制

文章目录 前言&#xff1a;1. 磁盘机械结构2. 磁盘物理结构3. 磁盘的逻辑存储3. 1. 文件名呢&#xff1f;3.2 对文件的增删查改与 路径3.3. 文件 4. 软硬链接4.1. 操作观察现象4.2. 软硬链接的原理4.3. 软硬链接的应用场景 总结 前言&#xff1a; 在现代操作系统中&#xff0c…

基于Springboot+vue实现的汽车服务管理系统

作者主页&#xff1a;Java码库 主营内容&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app等设计与开发。 收藏点赞不迷路 关注作者有好处 文末获取源码 技术选型 【后端】&#xff1a;Java 【框架】&#xff1a;spring…