- 博客(167)
- 资源 (5)
- 收藏
- 关注
原创 Java 17 下 Spring Boot 与 Pulsar 队列集成实战:生产者与消费者实现指南
SpringBoot集成Pulsar队列方案对比摘要 SpringBoot集成Pulsar队列提供两种主流方案:官方pulsar-client和社区starter。官方方案(pulsar-client 3.3.1)功能全面,支持最新特性,适合对功能完整性要求高的项目;社区starter方案(pulsar-spring-boot-starter)则简化了配置流程,更适合快速集成场景。两种方案均需Java17和SpringBoot3.3.12环境支持。 官方方案需手动配置客户端连接,通过Schema.JSON实
2025-06-26 14:05:52
392
原创 深度剖析 Apache Pulsar:架构、优势与选型指南
Apache Pulsar是一款云原生分布式消息流平台,采用独特的"存储计算分离"架构,兼具消息队列、流处理和存储能力。其核心优势包括分层架构(无状态Broker+BookKeeper存储)、多租户隔离、百万级Topic支持、流批一体等特性。相比Kafka、RabbitMQ等消息系统,Pulsar在扩展性、可靠性、功能丰富度方面表现突出,尤其适合金融交易、实时数仓、物联网等场景。选型时,若需超大规模扩展、强一致性或流批一体,Pulsar是理想选择;而对生态成熟度要求高或轻量级场景,Kaf
2025-06-26 13:57:15
666
原创 SpringBoot 数据库连接池与 ManticoreSearch 兼容性测试
本文介绍了Spring Boot使用不同数据库连接池与Manticoresearch交互的方法,包括HikariCP、Druid、Tomcat JDBC、Apache DBCP2和C3P0的兼容性测试结果。测试表明Tomcat JDBC、DBCP2与Manticoresearch兼容性较好,而HikariCP和Druid存在兼容性问题。文章详细分析了各连接池特点,并对性能、监控功能等核心区别进行了总结,最后给出选择建议:对于Manticoresearch交互场景,推荐使用Tomcat JDBC
2025-06-25 18:20:32
1184
原创 深入探究Manticoresearch Java API:新增与查询文档实战
本文介绍了如何在Java项目中集成高性能搜索引擎Manticoresearch并实现文档操作。Manticoresearch是Sphinx Search的改进版本,具有显著的性能优势。集成时需在pom.xml中添加Maven依赖,版本为8.0.0。文章详细展示了新增文档和两种查询方式:SQL查询通过UtilsApi执行SQL语句并解析结果;API查询通过SearchApi构建查询请求。这两种方式各具特点,开发者可根据需求选择使用。Manticoresearch以其优异的性能和易用性,为全文搜索应用提供了高效
2025-06-25 18:16:05
415
原创 OpenSIPS 邂逅 Kafka:构建高效 VoIP 消息处理架构
摘要:本文介绍了OpenSIPS与Kafka集成的使用场景和操作步骤。主要应用场景包括异步日志处理、事件监控、分布式消息队列集成、计费数据分析等9个方面。实现步骤涵盖模块引入、数据组装发送、消息消费和故障转移机制。通过配置event_kafka模块,可将SIP信令日志、CDR等数据发送至Kafka队列,并支持异常情况下的故障转移方案(采用event_virtual/event_flatstore备份机制)。该方案有效实现了VoIP系统与其他服务的异步解耦。
2025-06-24 18:13:24
750
原创 Docker 助力:零基础极速部署 Apache Superset
Apache Superset快速部署指南 环境准备:需安装Docker和Docker Compose 获取代码:通过git克隆官方仓库,可指定版本(如4.1.2或3.0.4) 启动服务:使用docker-compose-non-dev.yml启动生产环境 部署过程:自动完成数据库迁移、管理员账户设置、权限配置等初始化 访问服务:默认端口8088,可通过web界面操作 版本管理:通过TAG环境变量指定特定版本 资源清理:使用docker compose down命令停止服务 整个部署流程简便,适合快速搭建可
2025-06-24 18:04:50
536
原创 使用 nvm 管理 Node.js 和 npm 版本
本文介绍了如何在 macOS 上使用 nvm(Node Version Manager)管理 Node.js 和 npm 的版本。nvm 是一个基于 Shell 的工具,能够方便地安装、切换和管理多个 Node.js 版本。文章详细讲解了 nvm 的安装步骤,包括检查是否已安装、通过 curl 安装、重新加载配置文件以及验证安装。此外,还介绍了如何使用 nvm 安装特定版本的 Node.js、设置默认版本、切换版本以及通过指定镜像源加速下载。最后,文章总结了常用命令,帮助开发者快速上手 nvm,提升开发效率
2025-05-19 09:25:43
1172
原创 将关系型数据从MySQL迁移到Manticore Search
将MySQL历史数据同步到Manticore Search的常见方法包括使用SQL导入、ETL工具和自定义脚本。SQL导入是最主流的方法,涉及导出MySQL数据、转换SQL文件以适应Manticore的语法要求,并通过Manticore的mysql客户端导入数据。此方法需注意时间类型数据的转换和时区问题。ETL工具如Logstash提供数据同步支持,适用于需要复杂转换的场景。自定义脚本方法最为复杂,适用于处理特殊数据类型如MVA,但可能对MySQL性能造成影响。选择合适的方法需根据具体需求和环境。
2025-05-19 09:20:16
1097
原创 ManticoreSearch-查询利器极速上手指南
本学习提纲旨在指导开发者掌握Manticore Search及其与Java客户端的集成开发。首先,通过初步了解Manticore Search的基本架构和安装配置,开发者可以熟悉其与MySQL协议的兼容性。接着,学习数据导入与索引构建,掌握从数据库导入数据的方法和SQL插入语法。在Java客户端连接部分,开发者将学习如何使用JDBC连接Manticore,并编写Java程序执行SQL查询。此外,提纲还涵盖了查询优化与高级功能,包括全文搜索、过滤、排序、分页等,以及性能调优技巧。最后,部署与监控部分指导开发者
2025-05-16 18:47:56
1047
原创 零基础玩转Apache Superset可视化部署
根据官方Quick Start Guide,部署Apache Superset的步骤如下:首先确认系统已安装Docker和Docker Compose,然后通过Git获取Superset代码并切换到指定版本。使用Docker Compose启动服务,选择生产环境配置文件docker-compose-non-dev.yml,并可通过设置环境变量TAG指定版本。启动后,系统将拉取镜像、创建容器并依次启动服务,包括数据库、缓存、定时任务等。初始化阶段包括数据库迁移、管理员用户设置、角色权限配置和示例数据加载。
2025-05-16 18:43:11
1101
原创 SpringAI-开启 Java AI 新纪元
谁说Java 做不了AI。与 ChatModel、Message、ChatMemory 等原子 API 相比,使用 ChatClient 可以将与 LLM 及其他组件交互的复杂性隐藏在背后,因为基于 LLM 的应用程序通常要多个组件协同工作(例如,提示词模板、聊天记忆、LLM Model、输出解析器、RAG 组件:嵌入模型和存储),并且通常涉及多个交互,因此协调它们会让编码变得繁琐。这意味着,就像欧几里得几何中平面上的点可以根据其坐标的远近关系而接近或远离一样,在语义空间中,点的接近程度反映了意义的相似性。
2025-02-12 18:48:36
1369
原创 DeepSeek-Ollama实现本地化无烦恼
DeepSeek 很火爆,网页总会出现“系统繁忙”,除了去不同的平台入口寻求额外帮助,还可以本地化部署,独享性能。
2025-02-12 18:43:46
1080
原创 DeepSeek-手把手教你接入VSCode(Continue)
提前在 deepseek 开放平台注册账号并登录,获取 DeepSeek API 密钥:注册 DeepSeek 账号并获取 API 密钥。右键点击代码,选择 Continue 菜单中的 Explain Code 或 Generate Code。打开 VSCode,进入 Extensions 视图(快捷键:Ctrl+Shift+X)。在 API Key 字段中,输入从 DeepSeek 获取的 API 密钥。点击 Install 安装插件,安装完成后重启 VSCode。在 VSCode 中打开一个代码文件。
2025-02-08 14:19:36
16200
6
原创 DeepSeek-手把手教你接入IDEA(codeGPT)
如果能更新,尽量选择新的版本,因为 deepseek 与IDEA的版本有兼容对应关系,IDEA如果偏旧,可能无法体验到新版的配置项。将AI接入IDEA编辑器肯定不仅仅是为了chat,很重要的是在编码方面,提供补全、提示、注释、测试方法等快捷操作,接下来配置编码方面。在 API Key 字段中,输入从 DeepSeek 获取的 API 密钥。代码解释:右键选择代码,使用 Explain Code 功能获取代码解释。配置后,即可在右侧菜单栏中看到对应功能,通过对话可以实现API的调用。
2025-02-08 14:01:48
18005
23
原创 OpenSIPS-Dispatcher模块详解:优化SIP流量分发的利器
在 OpenSIPS 中,dispatcher 模块用于实现负载均衡和故障转移。通过 dispatcher 模块,你可以将 SIP 请求分发到一组后端服务器(如媒体服务器、代理服务器等),并根据配置的算法和策略动态调整分发逻辑。
2025-02-08 13:29:28
1135
原创 OpenSIPS-由浅入深编译更多可选模块
接上篇,是采取全默认的方式体验OpenSIPS,那么我需要额外的模块怎么办呢?可选的有哪些?流程在第一篇文章中已经介绍了,这边主要是操作一下接入一个db_mysql的组件是如何操作的。
2025-01-27 11:40:59
735
原创 OpenSIPS-从安装部署开始认识一个组件
OpenSIPS 一个多功能、多用途的信令 SIP 服务器,可供运营商、电信公司或 ITSP 用于Class4/5 住宅平台、中继/批发、企业/虚拟 PBX 解决方案、会话边界控制器、应用服务器、前端负载均衡器、IMS 平台、呼叫中心等解决方案
2025-01-27 10:49:47
1639
原创 sysbench-强大的性能基准测试工具黑马
sysbench是一个模块化的、跨平台的基准测试工具,主要用于评估系统性能和数据库性能。它最初设计用于 CPU、内存、线程和文件 I/O 的基准测试,但后来扩展了对数据库操作的支持,成为评估数据库性能的强大工具。它可以支持多种数据库管理系统(DBMS),如 MySQL、PostgreSQL 和 MariaDB,并且可以通过编写自定义 Lua 脚本来支持其他类型的数据库
2025-01-26 17:29:41
1128
原创 Kamailio-Sngrep 短小精悍的利器
一个sip的抓包小工具,在GitHub上竟然能够积累1K的star,看来还是有点东西,当然官方的友链也是发挥了重要作用首先,有能力的宝子可以自行查看但是对于本章要讲的SIP信令的抓包,也就是Wireshark、tcpdump,以及前面讲到过较为系统的Homer,如果嫌弃Wireshark笨重、tcpdump原始,那么就一起来看看这款短小精悍的sngrep。官方自己定义:是一款可以在命令行终端展示SIP电话消息流的工具,它能够支持实时的抓取并展现SIP包,也可以用来做一个pcap的阅读器。
2024-10-18 13:08:04
1268
2
原创 Kamailio-HTable 不得不看的万年缓存技术
在程序开发的时候我们都知道,缓存可以存放临时的数据、高性能需求的数据,典型的就是Redis,使用高效的Hash数据结构提供极致的性能需求,而不是依赖数据库。那么在Kamailio这边,也有一些这样的需求,比如黑白名单、访问频次、业务静态属性等,Htable出现了。
2024-10-18 11:39:26
1148
原创 Kamailio-基于Homer与heplify的SIP信令监控-3
Homer登录页、默认密码,首页看板 、会话flow sequence查询、信令内容查看、会话统计、自定义查询等
2024-09-14 08:52:54
729
原创 Kamailio-基于Homer与heplify的SIP信令监控-2
heplify 是一个终端采集工具,主要将数据推送到 heplify-server 使用。heplify server是一个接受数据的服务,数据来自heplify,需要一个其启动的IP端口地址。homerr是一个api server,并提供UI 展示的能力。
2024-09-14 08:44:08
1333
3
原创 Kamailio-基于Homer与heplify的SIP信令监控-1
接,对Kamailio的一个基础监控有了一定的概念,但是光看数字如果发现问题,要如何回顾解决呢?生产环境不能随时随地抓包来确定链路的正常与否。这个时候 Sipcapture 公司推出了Homer这个开源软件,目前。因为这一整套有专业公司维护,因此这一套还被称为:Sipcapture HEP Stack。下面将分三个章节来介绍整个Homer的部署安装配置、Kamailio的配置、Homer页面的查询与操作。
2024-09-13 13:41:51
1443
原创 Kamailio-基于Zabbix+Kamcli的SIP指标监控
Kamailio 是一个开源的 Session Initiation Protocol (SIP) 服务器,它主要用于建立和管理实时通信会话,如语音和视频通话,与opensips这个产品是同根同源的存在。Kamcli是一个github小众开源工具,与zabbix agent联动,将kamailio自身统计数据上报并展示。
2024-09-13 13:34:15
1341
原创 Kamailio-超强dispatcher负载均衡模块
Kamailio 负载均衡的功能主要依靠 Dispatcher 模块完成。单台VOIP服务的性能不能满足业务需求了,需要扩展至多个节点,那么Kamailio将如何进行请求的代理呢?多个后端VOIP服务有不可用,转过去的请求全部失败,那么Kamailio可以如何保障整体流程的健壮性?依赖负载均衡的基础功能,还可以实现AB测试、区分权重、通道量分发等业务相关逻辑
2024-09-12 15:09:12
1697
原创 Kamailio-神仙SIPp压力测试工具
SIPp是一个短小精悍的脚本工具,可以支持模拟客户端与服务端的模式,对于生产压测、功能测试都有一定帮助。
2024-09-12 14:59:24
1490
原创 RediSearch-Redis的高性能全文搜索
RediSearch是Redis Labs开发的一个模块,它为Redis添加了高性能的全文搜索功能。RediSearch使Redis具备了全文搜索的能力,这对于需要在大量文本数据中进行高效搜索的应用非常有用。它支持复杂的查询语法,例如布尔查询、短语匹配、模糊匹配等,这使得Redis成为一个更加强大的数据处理工具。
2024-08-21 13:53:16
1351
1
原创 Kamailio-Web管理页面Siremis的安装与部署
siremis 是针对于 Kamailio 的web管理接口,使用PHP书写,更新至2020年,相对不是太新但是是官方友链的以下就采用如有疑问请参看以下开始介绍操作步骤。
2024-07-03 09:46:45
1619
原创 Kamailio-SIP代理服务器单节点的安装与部署
使用背景:存在 Freeswitch 等语音网关应用服务,期望实现负载均衡、前置处理的功能,类似于Web应用服务的Nginx的角色Kamailio和OpenSIPS由于其灵活性、高性能和强大的路由能力,在开源SIP服务器领域尤其受到欢迎。基于以上背景,从头开始学习并了解Kamailio.
2024-07-02 16:17:38
2451
原创 Kamailio-SIP基础知识
SIP 代表会话发起协议(Session Initiation Protocol),基于HTTP协议。包括用户代理、代理服务、注册服务和重定向服务,这通常都是逻辑上的概念。电话不是直接呼通,而是抵达一个或多个代理服务,代理服务可以记录双方的地址、会话认证、账户认证以及其他很重要的功能,大大提升了对话的安全性和功能性,比如呼叫转移、会话路由等等。这层代理也可以是有状态和无状态的。
2024-07-02 16:14:20
969
原创 SpringBoot + Druid + Sqlite 文件数据库初体验
一次以外的机会接触到了SQLite这样一个轻量型的嵌入式数据库组件,对于日常使用的可能都是传统RDBMS,或者当下更为流行NoSQL和大数据存储。对于这样一个的 SQL 数据库引擎,主要是面向嵌入式或者终端类的使用场景,或者是说开箱即用、小型项目的场景。
2024-05-11 11:18:03
1591
原创 Skywalking系列之日志分析语言LAL的配置与解析
SkyWalking中的LAL的语法就能够实现,通过正则等形式,结合groovy语法,匹配出指定字段进行提取,实现从文本中摘出所需要的字段进行聚合统计。主要包含2块概念:Layer, Filter,Filter模块是一组 parser, extractor 和 sink。如果对Filebeat、Fluentd、Logstash 有了解的,就能很快上手。
2024-05-11 11:12:26
1405
原创 Kubernetes-05-容器健康检测
关于健康检测这边,会具体讲述K8S自身如何对Pod进行健康存活检测,如何可以对应用进行存活和健康检测。让应用在K8S上实现完美的无缝切换,实现更为安全、零停服的版本滚动升级K8S默认的健康检测,主要监测Pod启动的进程,进程退出返回码非0就是代表故障,需要根据重启策略执行restartPolicy: 默认Always,可选OnFailure但是经常应用程序的故障场景是,比如内存溢出,系统进程还在但无法对外提供服务了,这种情况K8S的默认规则就无法识别,需要使用Liveness探测。
2024-03-29 18:50:34
1006
原创 ClickHouse11-ClickHouse中文件引擎与物化视图的组合拳
物化视图(Materialized View)是一种特殊类型的表它能够根据定义在其上的SQL查询结果自动更新数据它并不存储查询表达式本身,而是实际计算和存储了该查询的结果集当源表有新的数据插入、修改或满足特定条件时,物化视图会实时或者按照配置的策略执行预定义的聚合或其他计算,并将结果写入到物化视图对应的表中。
2024-03-27 13:49:25
685
原创 ClickHouse10-ClickHouse中Kafka表引擎
Kafka表引擎也是一种常见的表引擎,在很多大数据量的场景下,会从源通过Kafka将数据输送到ClickHouse,Kafka作为输送的方式,ClickHouse作为存储引擎与查询引擎,大数据量的数据可以得到快速的、高压缩的存储。
2024-03-27 13:36:24
1790
原创 ClickHouse06-ClickHouse中基础的增删改查
使用数据库,最基础的学习都是增、删、改、查,然后才会去了解基础函数和高阶函数,今天就来看看大火的 ClickHouse 中简单的增删改查怎么写?
2024-03-26 08:48:12
1536
原创 ActiveMQ-04如何搭建一个完美的ActiveMQ集群
集群架构是一个很大的话题,官网就给我们介绍了几种。客户端:队列消费者集群-Queue Consumer Clusters,服务端:Broker集群 - Broker Clusters,服务端:Master-Slave 主从集群,Broker-Cluster+Master Slave的组合
2024-03-26 08:39:58
2030
72
原创 ClickHouse04-ClickHouse基础数据类型与函数
以下通过与 MySQL 和 PostgreSQL 横向对比一下ClickHouse常见的数据结构:整型、浮点型、布尔型、字符型、时间类型、枚举、空间数据。嵌套数据型、聚合数据型、其他特殊的数据结构。时间日期函数、JSON函数、字符串操作类函数、UDF 用户自定义函数
2024-03-25 14:07:17
1683
原创 ClickHouse03-小白如何快速搭建ClickHouse集群
普通测试通常使用ClickHouse单节点就可以了,但是生产环境不免需要考虑多活、负载等高可用问题,集群就成了基础需求两种选择均可。ZooKeeper方式搭建CK集群,docker-compose部署,ClickHouse-Keeper方式搭建CK集群
2024-03-25 13:34:51
2554
ClickHouse系统自带仪表盘指标SQL
2024-05-11
无限强度加密local-policy.jar/US-export-policy.jar
2022-12-27
HFS+文件系统报告——文件系统
2017-02-23
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人