zlmediakit实现rtsp流服务器

本次实现是将内存中的H264数据经过zlmediakit实现为rtsp流。

我是用的是CAPI的方式,将zlmediakit作为一个sdk嵌入到自己的程序中而不是作为一个独立的进进程服务。

1.编译完成zkmedialit后会得到bin include lib三个文件夹如图

其中bin中的MediaServer是作为独立的进程使用的zlmediakit服务,我们这里不用

我们使用lib下的libmk_api.so

下面说一些使用的API以及调用顺序

1.首先包含头文件

#include "mk_mediakit.h"

2.从zkmediakit工程中拷贝demo的配置文件config.ini过来

3.初始化环境,日志以及设置配置文件

cpp 复制代码
  char *ini_path = mk_util_get_exe_dir("config.ini");
    mk_config config = {
            .ini = ini_path,
            .ini_is_path = 1,
            .log_level = 0,
            .log_mask = LOG_CONSOLE,
            .log_file_path = NULL,
            .log_file_days = 0,
            .ssl = NULL,
            .ssl_is_path = 1,
            .ssl_pwd = NULL,
            .thread_num = 0
    };
    mk_env_init(&config);
    mk_free(ini_path);

4.启动各个服务

cpp 复制代码
 mk_http_server_start(80, 0);
    mk_rtsp_server_start(554, 0);
    mk_rtmp_server_start(1935, 0);
    mk_rtc_server_start(atoi(mk_get_option("rtc.port")));

5.监听事件,我这里没有处理所以把回调都设置为空

cpp 复制代码
    mk_events events = {
            .on_mk_media_changed = NULL,
            .on_mk_media_publish = NULL,
            .on_mk_media_play = NULL,
            .on_mk_media_not_found = NULL,
            .on_mk_media_no_reader = NULL,
            .on_mk_http_request = NULL,
            .on_mk_http_access = NULL,
            .on_mk_http_before_access = NULL,
            .on_mk_rtsp_get_realm = NULL,
            .on_mk_rtsp_auth = NULL,
            .on_mk_record_mp4 = NULL,
            .on_mk_shell_login = NULL,
            .on_mk_flow_report = NULL
    };
    mk_events_listen(&events);

6.创建媒体源

cpp 复制代码
 mk_media media = mk_media_create("__defaultVhost__", "live", "stream1", 0, 0, 0);

这么写的话最终rtsp日志为rtsp://ip:554/live/stream1

7.添加视频轨道并设置视频编码参数

cpp 复制代码
    codec_args v_args = {0};
    //创建轨道
    mk_track v_track = mk_track_create(MKCodecH264, &v_args);
    //初始化媒体源的视频轨道
    mk_media_init_track(media, v_track);
    //完成轨道添加,这个可以不写但是会延迟三秒建议写上
    mk_media_init_complete(media);
    //释放资源
    mk_track_unref(v_track);

8.循环网里面塞入H264帧,记得计算dts我这里是25帧所以每一帧dts加40

cpp 复制代码
    int dts = 0;
    while(1)
    {
        //获取H264数据到data 我这里就不写了

        //生成frame data为一帧的264数据 size为数据大小
        mk_frame frame = mk_frame_create(MKCodecH264, dts, dts, data, size, NULL, NULL);
        dts += 40;
        mk_media_input_frame((mk_media) user_data, frame);
        mk_frame_unref(frame);
    }

9.程序结束的时候调用下面销毁资源

cpp 复制代码
    mk_media_release(media);
    mk_stop_all_server();
相关推荐
檀越剑指大厂1 小时前
【Linux系列】服务器 IP 地址查询
linux·服务器·tcp/ip
十五年专注C++开发2 小时前
CMake进阶: externalproject_add用于在构建阶段下载、配置、构建和安装外部项目
linux·c++·windows·cmake·自动化构建
范纹杉想快点毕业2 小时前
《嵌入式 C 语言编码规范与工程实践个人笔记》参考华为C语言规范标准
服务器·c语言·stm32·单片机·华为·fpga开发·51单片机
Skylar_.3 小时前
嵌入式 - Linux软件编程:进程
java·linux·服务器
rannn_1113 小时前
【Linux学习|黑马笔记|Day4】IP地址、主机名、网络请求、下载、端口、进程管理、主机状态监控、环境变量、文件的上传和下载、压缩和解压
linux·笔记·后端·学习
ApeAssistant3 小时前
windows 端口占用解决方案
服务器·后端
長琹3 小时前
9、C 语言内存管理知识点总结
linux·c语言
白书宇3 小时前
5.从零开始写LINUX内核--从实模式到保护模式的过渡实现
linux·汇编·数据库·开源
bkspiderx3 小时前
Nginx 屏蔽服务器名称与版本信息(源码级修改)
运维·服务器·nginx
野生柚子4 小时前
记录学习K8s 集群中OOM Killer的决策基准及执行流程
linux·运维