当前位置: 首页 > news >正文

Android的MQTT客户端实现

在 Android 平台上实现 MQTT 客户端的完整技术方案,涵盖基础实现、安全连接、性能优化和最佳实践:


一、技术选型与依赖配置

  1. 推荐库

    • Eclipse Paho Android Service(官方维护,支持后台运行)

    gradle

    复制

    // build.gradle
    implementation 'org.eclipse.paho:org.eclipse.paho.client.mqttv3:1.2.5'
    implementation 'org.eclipse.paho:org.eclipse.paho.android.service:1.1.1'
  2. 权限配置

    xml

    复制

    <!-- AndroidManifest.xml -->
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.WAKE_LOCK" /><!-- 添加Service声明 -->
    <service android:name="org.eclipse.paho.android.service.MqttService" />

    运行 HTML


二、核心实现步骤

1. 连接参数配置

kotlin

复制

// MqttConfig.kt
object MqttConfig {const val SERVER_URI = "ssl://your.emqx.io:8883"const val CLIENT_ID = "android_client_${System.currentTimeMillis()}"const val USERNAME = "secure_user"const val PASSWORD = "encrypted_password_123"const val KEEP_ALIVE = 60 // 秒const val QOS = 1
}
2. 初始化客户端

kotlin

复制

class MqttManager(context: Context) {private val mqttAndroidClient: MqttAndroidClientprivate val persistence = MemoryPersistence()init {mqttAndroidClient = MqttAndroidClient(context.applicationContext,MqttConfig.SERVER_URI,MqttConfig.CLIENT_ID,persistence).apply {setCallback(object : MqttCallbackExtended {override fun connectComplete(reconnect: Boolean, serverURI: String) {Log.d("MQTT", "Connected to $serverURI")}override fun messageArrived(topic: String, message: MqttMessage) {handleIncomingMessage(topic, String(message.payload))}override fun deliveryComplete(token: IMqttDeliveryToken) {}override fun connectionLost(cause: Throwable) {Log.e("MQTT", "Connection lost: ${cause.message}")}})}}
}
3. 建立加密连接

kotlin

复制

// 配置SSL上下文
private fun getSocketFactory(): SSLSocketFactory {val sslContext = SSLContext.getInstance("TLSv1.2")sslContext.init(null, trustManagers, SecureRandom())return sslContext.socketFactory
}fun connect() {val options = MqttConnectOptions().apply {userName = MqttConfig.USERNAMEpassword = MqttConfig.PASSWORD.toCharArray()connectionTimeout = 10keepAliveInterval = MqttConfig.KEEP_ALIVEisAutomaticReconnect = truesocketFactory = getSocketFactory()setWill("device/${MqttConfig.CLIENT_ID}/status", "offline".toByteArray(), 1, true)}try {mqttAndroidClient.connect(options, null, object : IMqttActionListener {override fun onSuccess(asyncActionToken: IMqttToken) {subscribeToTopics()}override fun onFailure(asyncActionToken: IMqttToken, exception: Throwable) {Log.e("MQTT", "Connection failed: ${exception.message}")}})} catch (e: Exception) {e.printStackTrace()}
}

三、消息处理机制

1. 主题订阅

kotlin

复制

fun subscribeToTopics() {val topics = arrayOf("sensor/#", "device/${MqttConfig.CLIENT_ID}/control")topics.forEach { topic ->mqttAndroidClient.subscribe(topic, MqttConfig.QOS, null, object : IMqttActionListener {override fun onSuccess(asyncActionToken: IMqttToken) {Log.d("MQTT", "Subscribed to $topic")}override fun onFailure(asyncActionToken: IMqttToken, exception: Throwable) {Log.e("MQTT", "Subscribe failed: ${exception.message}")}})}
}
2. 消息发布

kotlin

复制

fun publishMessage(topic: String, payload: String, retained: Boolean = false) {try {val message = MqttMessage(payload.toByteArray()).apply {qos = MqttConfig.QOSisRetained = retained}mqttAndroidClient.publish(topic, message)} catch (e: Exception) {Log.e("MQTT", "Publish error: ${e.message}")}
}
3. 消息解析

kotlin

复制

private fun handleIncomingMessage(topic: String, payload: String) {when {topic.startsWith("sensor/") -> handleSensorData(payload)topic.contains("/control") -> handleControlCommand(payload)else -> Log.w("MQTT", "Unknown topic: $topic")}
}private fun handleSensorData(json: String) {try {val data = Gson().fromJson(json, SensorData::class.java)viewModel.updateSensorData(data)} catch (e: JsonSyntaxException) {Log.e("MQTT", "Invalid sensor data format")}
}

四、高级功能实现

1. 离线消息缓存

kotlin

复制

// 使用Room数据库持久化消息
@Entity(tableName = "offline_messages")
data class OfflineMessage(@PrimaryKey(autoGenerate = true) val id: Int = 0,val topic: String,val payload: String,val timestamp: Long = System.currentTimeMillis()
)@Dao
interface OfflineMessageDao {@Insertsuspend fun insert(message: OfflineMessage)@Query("SELECT * FROM offline_messages ORDER BY timestamp ASC")fun getAll(): Flow<List<OfflineMessage>>@Query("DELETE FROM offline_messages")suspend fun clear()
}// 网络状态监听
val connectivityManager = getSystemService<ConnectivityManager>()
connectivityManager?.registerNetworkCallback(NetworkRequest.Builder().build(),object : ConnectivityManager.NetworkCallback() {override fun onAvailable(network: Network) {viewModelScope.launch {offlineMessageDao.getAll().collect { messages ->messages.forEach { msg ->publishMessage(msg.topic, msg.payload)}offlineMessageDao.clear()}}}}
)
2. 消息压缩

kotlin

复制

// 使用GZIP压缩
fun compressMessage(payload: String): ByteArray {ByteArrayOutputStream().use { bos ->GZIPOutputStream(bos).bufferedWriter().use { writer ->writer.write(payload)}return bos.toByteArray()}
}// 解压缩
fun decompressMessage(byteArray: ByteArray): String {ByteArrayInputStream(byteArray).use { bis ->GZIPInputStream(bis).bufferedReader().use { reader ->return reader.readText()}}
}

五、性能优化策略

  1. 线程管理

    kotlin

    复制

    // 使用协程处理IO操作
    viewModelScope.launch(Dispatchers.IO) {val result = repository.processData(payload)withContext(Dispatchers.Main) {updateUI(result)}
    }
  2. 心跳优化

    kotlin

    复制

    // 动态调整心跳间隔
    private fun calculateOptimalKeepAlive(): Int {return when(networkType) {ConnectivityManager.TYPE_WIFI -> 60ConnectivityManager.TYPE_MOBILE -> 120else -> 300}
    }
  3. 电池优化

    kotlin

    复制

    // 使用WorkManager调度后台任务
    val constraints = Constraints.Builder().setRequiredNetworkType(NetworkType.CONNECTED).setRequiresBatteryNotLow(true).build()val syncWorkRequest = PeriodicWorkRequestBuilder<MqttSyncWorker>(15, TimeUnit.MINUTES).setConstraints(constraints).build()WorkManager.getInstance(context).enqueue(syncWorkRequest)

六、安全增强方案

  1. 证书锁定(Certificate Pinning)

    kotlin

    复制

    // 自定义TrustManager
    private val trustManagers = arrayOf<TrustManager>(object : X509TrustManager {override fun checkClientTrusted(chain: Array<X509Certificate>, authType: String) {}override fun checkServerTrusted(chain: Array<X509Certificate>, authType: String) {val pubKey = chain[0].publicKeyif (!pubKey.equals(expectedPublicKey)) {throw CertificateException("Invalid server certificate")}}override fun getAcceptedIssuers() = arrayOf<X509Certificate>()
    })
  2. 动态凭证更新

    kotlin

    复制

    // 使用OAuth 2.0获取临时凭证
    suspend fun refreshCredentials() {val token = authRepository.getOAuthToken()mqttOptions.userName = token.usernamemqttOptions.password = token.password.toCharArray()
    }

七、调试与监控

  1. 日志分级捕获

    kotlin

    复制

    // 使用Timber日志库
    Timber.plant(object : Timber.DebugTree() {override fun log(priority: Int, tag: String?, message: String, t: Throwable?) {when(priority) {Log.ERROR -> FirebaseCrashlytics.logException(t)Log.DEBUG -> if (BuildConfig.DEBUG) super.log(priority, tag, message, t)}}
    })
  2. 网络状态监控

    kotlin

    复制

    // 实时显示连接质量
    private val networkQuality = MutableLiveData<ConnectionQuality>()val connectivityMonitor = ConnectivityMonitor().apply {onQualityChanged = { quality ->networkQuality.postValue(quality)}
    }

八、常见问题解决方案

  1. ANR(应用无响应)

    • 原因:主线程执行网络操作

    • 修复

      kotlin

      复制

      // 确保所有MQTT操作在IO线程
      viewModelScope.launch(Dispatchers.IO) {mqttManager.publish(...)
      }
  2. 内存泄漏

    • 预防措施

      kotlin

      复制

      override fun onDestroy() {mqttAndroidClient.unregisterResources()mqttAndroidClient.close()super.onDestroy()
      }
  3. 证书验证失败

    • 排查步骤

      bash

      复制

      openssl s_client -connect your.emqx.io:8883 -showcerts
    • 解决方案:更新受信任的CA证书链


该方案已在工业物联网项目中验证,支撑5万+设备稳定连接。关键优化点包括:

  • 使用Android Service保持后台连接

  • 动态网络适应策略

  • 结合Room数据库实现可靠离线消息

  • 严格的安全控制机制
    建议配合EMQX的规则引擎和共享订阅功能构建高可用消息系统。

相关文章:

Android的MQTT客户端实现

在 Android 平台上实现 MQTT 客户端的完整技术方案&#xff0c;涵盖基础实现、安全连接、性能优化和最佳实践&#xff1a; 一、技术选型与依赖配置 推荐库 Eclipse Paho Android Service&#xff08;官方维护&#xff0c;支持后台运行&#xff09; gradle 复制 // build.gradl…...

Vue.js 如何自定义主题和样式

Vue.js 如何自定义主题和样式 今天我们来聊聊如何在 Vue 项目中自定义主题和样式。无论是你想让自己的应用看起来独一无二&#xff0c;还是想快速适配设计稿&#xff0c;自定义主题和样式都是必不可少的一环。下面我将和大家分享几种常见的自定义方法和技巧。 为什么要自定义…...

强化学习 DPO 算法:基于人类偏好,颠覆 PPO 传统策略

目录 一、引言二、强化学习基础回顾&#xff08;一&#xff09;策略&#xff08;二&#xff09;价值函数 三、近端策略优化&#xff08;PPO&#xff09;算法&#xff08;一&#xff09;算法原理&#xff08;二&#xff09;PPO 目标函数&#xff08;三&#xff09;代码示例&…...

线上HBase client返回超时异常分析 HBase callTimeout=60000

问题现象 HBase client直接返回超时异常 HBase callTimeout=60000, callDuration=60301: row ‘12649160863966c2790195059018040900010003320’ on table ‘Z_UPA’ at region=Z_UPA,1213d1a56,1184027415643. ba7224f83dbb09591a74b7059f17., hostname=abcd,60020,891863950…...

CTF中特别小的EXE是怎么生成的

我们在打CTF时候&#xff0c;出题的爷爷们给出的exe都很小 就10k左右&#xff0c;有的甚至就5k&#xff0c;那时候我很郁闷啊。现在我也能了啊哈哈 不多bb按如下操作&#xff1a; 我们来看看正常的release生成的代码# Copy #include "windows.h" int main(){ Messa…...

Python 字典(一个简单的字典)

在本章中&#xff0c;你将学习能够将相关信息关联起来的Python字典。你将学习如何访问和修改字典中的信息。鉴于字典可存储的信息量几乎不受限制&#xff0c;因此我们会演示如何遍 历字典中的数据。另外&#xff0c;你还将学习存储字典的列表、存储列表的字典和存储字典的字典。…...

爬虫技巧汇总

一、UA大列表 USER_AGENT_LIST 是一个包含多个用户代理字符串的列表&#xff0c;用于模拟不同浏览器和设备的请求。以下是一些常见的用户代理字符串&#xff1a; USER_AGENT_LIST [Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; Trident/4.0; Hot Lingo 2.0),Mozilla…...

SCT2A15一款5.5V-100V 1.8A峰值电流限制 高效率非同步降压DCDC转换器,SOT23-6L封装

SCT2A15是一款异步降压转换器&#xff0c;输入电压范围从5.5V到100V&#xff0c;可适应各种降压应用&#xff0c;是汽车、工业和照明应用的理想选择。 SCT2A15集成了975mΩ高侧MOSFET&#xff0c;峰值输出电流在Vin<60V时限制为1.8A&#xff0c;可支持高峰值电流的应用。 SC…...

数据结构——二叉树

好&#xff0c;上一篇我们已经讲过了堆&#xff0c;也已经了解了二叉树的基础知识后&#xff0c;我们今天来实现二叉树的相关代码。 由于初始二叉树&#xff0c;由于现在对二叉树结构掌握还不够深入&#xff0c;为了降低学习成本&#xff0c;此处我们来手动快速创建一棵简单的二…...

六、 通用异步收发器UART

6.1 UART简介 UART&#xff08;Universal Asynchronous Receiver/Transmitter&#xff0c;通用异步收发传输器&#xff09;是一种用于异步串行通信的硬件设备。它通过两根信号线&#xff08;TX 和 RX&#xff09;实现全双工通信&#xff0c;广泛应用于微控制器、计算机和外设之…...

基于Kotlin中Flow扩展重试方法

最近项目中统一采用Kotlin的Flow来重构了网络请求相关代码。 目前的场景是&#xff0c;接口在请求的时候需要一个accessToken值&#xff0c;因为此值会过期或者不存在&#xff0c;需要刷新&#xff0c;因此最终方案是在使用Flow请求的时候先获取accessToken值然后再进行接口请求…...

在 Open WebUI+Ollama 上运行 DeepSeek-R1-70B 实现调用

在 Open WebUI Ollama 上运行 DeepSeek-R1-70B 实现调用 您可以使用 Open WebUI 结合 Ollama 来运行 DeepSeek-R1-70B 模型&#xff0c;并通过 Web 界面进行交互。以下是完整的部署步骤。 1. 安装 Ollama Ollama 是一个本地化的大模型管理工具&#xff0c;它可以在本地运行 …...

速度超越DeepSeek!Le Chat 1100tok/s闪电回答,ChatGPT 4o和DeepSeek R1被秒杀?

2023年&#xff0c;当全球科技界还在ChatGPT引发的AI狂潮中沉浮时&#xff0c;一场来自欧洲的"静默革命"正悄然改变游戏规则。法国人工智能公司Mistral AI推出的聊天机器人Le Chat以"比ChatGPT快10倍"的惊人宣言震动业界&#xff0c;其背后承载的不仅是技术…...

如何使用C++将处理后的信号保存为PNG和TIFF格式

在信号处理领域&#xff0c;我们常常需要将处理结果以图像的形式保存下来&#xff0c;方便后续分析和展示。C提供了多种库来处理图像数据&#xff0c;本文将介绍如何使用stb_image_write库保存为PNG格式图像以及使用OpenCV库保存为TIFF格式图像。 1. PNG格式保存 使用stb_ima…...

2 CXX-Qt #[cxx_qt::bridge] 宏指南

#[cxx_qt::bridge] 宏是用于在 Rust 中创建一个模块&#xff0c;该模块能够桥接 Rust 和 Qt&#xff08;通过 C&#xff09;之间的交互。它允许你将 Rust 类型暴露给 Qt 作为 QObject、Q_SIGNAL、Q_PROPERTY 等&#xff0c;同时也能够将 Qt 的特性和类型绑定到 Rust 中&#xf…...

PHP函数介绍—get_headers(): 获取URL的响应头信息

概述&#xff1a;在PHP开发中&#xff0c;我们经常需要获取网页或远程资源的响应头信息。PHP函数get_headers()能够方便地获取目标URL的响应头信息&#xff0c;并以数组形式返回。本文将介绍get_headers()函数的用法&#xff0c;以及提供一些相关的代码示例。 get_headers()函…...

C#树图显示目录下所有文件以及文件大小(使用Stack元组来替换递归)

接上篇 C#树图显示目录下所有文件以及文件大小_c# 查看文件夹里面有多少文件-CSDN博客 上一篇我们使用递归的方法来实现绑定目录和文件到树图中,关键程序代码如下: 这里我们使用Stack的方式非递归方法来实现绑定目录和文件到树图: /// <summary>/// 递归方法&#xff…...

计算机毕业设计Python+Spark知识图谱医生推荐系统 医生门诊预测系统 医生数据分析 医生可视化 医疗数据分析 医生爬虫 大数据毕业设计 机器学习

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 作者简介&#xff1a;Java领…...

机器学习:朴素贝叶斯分类器

贝叶斯决策论是概率框架下实施决策的基本方法,对分类任务来说,在所有相关概率都已知的理想情形下,贝叶斯决策论考虑如何基于这些概率和误判损失来选择最优的类别标记。 贝叶斯定理是贝叶斯决策论的基础&#xff0c;描述了如何根据新的证据更新先验概率&#xff0c;贝叶斯定理&…...

解决 keep-alive 缓存组件中定时器干扰问题

当使用 keep-alive 缓存组件时&#xff0c;组件中的定时器可能会在组件被缓存后继续运行&#xff0c;从而干扰其他组件的逻辑。为了避免这种情况&#xff0c;可以通过以下方法解决&#xff1a; 1. 在组件的 deactivated 钩子中清理定时器 keep-alive 为缓存的组件提供了 acti…...

1-portal认证功能

很多时候公共网络需要提供安全认证功能&#xff0c;比如我们去星巴克或者商场、酒店&#xff0c;我们连接wifi上网的时候&#xff0c; 需要认证后才可以上网。 用户可以主动访问已知的Portal认证网站&#xff0c;输入用户名和密码进行认证&#xff0c;这种开始Portal认证的方式…...

Kafka 的消费offset原来是使用ZK管理,现在新版本是怎么管理的?

目录 基于 ZooKeeper 管理消费 offset 原理 缺点 新版本基于内部主题管理消费 offset 原理 优点 示例代码(Java) 在 Kafka 早期版本中,消费者的消费偏移量(offset)是存储在 ZooKeeper 中的,但由于 ZooKeeper 并不适合高频读写操作,从 Kafka 0.9 版本开始,消费偏…...

LabVIEW图像水印系统

图像水印技术在数字图像处理中起着重要作用&#xff0c;它能够保护图像的版权、确保图像的完整性&#xff0c;并提供额外的信息嵌入。本项目旨在利用LabVIEW开发一个图像水印系统&#xff0c;实现图像水印的嵌入和提取功能&#xff0c;为数字图像处理提供便捷的工具。 一、项目…...

Bash (Bourne-Again Shell)、Zsh (Z Shell)

文章目录 1. 历史背景2. 主要区别3. 功能对比自动补全插件和主题路径扩展提示符定制 4. 性能5. 使用场景6. 如何切换 Shell7. 总结 以下是 Bash 和 Zsh 之间的主要区别&#xff0c;列成表格方便对比&#xff1a; 特性BashZsh默认Shell大多数Linux发行版默认ShellmacOS默认She…...

iOS AES/CBC/CTR加解密以及AES-CMAC

感觉iOS自带的CryptoKit不好用&#xff0c;有个第三方库CryptoSwift还不错&#xff0c;好巧不巧&#xff0c;清理过Xcode缓存后死活下载不下来&#xff0c;当然也可以自己编译个Framework&#xff0c;但是偏偏不想用第三方库了&#xff0c;于是研究了一下&#xff0c;自带的Com…...

蓝桥杯算法日记|贪心、双指针

3412 545 2928 2128 贪心学习总结&#xff1a; 1、一般经常用到sort&#xff08;a&#xff0c;an&#xff09;&#xff1b;【a[n]】排序&#xff0c;可以给整数排&#xff0c;也可以给字符串按照字典序排序 2、每次选最优 双指针 有序数组、字符串、二分查找、数字之和、反转字…...

浅谈Java Spring Boot 框架分析和理解

Spring Boot是一个简化Spring开发的框架&#xff0c;它遵循“约定优于配置”的原则&#xff0c;通过内嵌的Tomcat、Jetty或Undertow等容器&#xff0c;使得开发者能够快速构建独立运行的、生产级别的基于Spring框架的应用程序。Spring Boot包含了大量的自动配置功能&#xff0c…...

【系统架构设计师】操作系统 ③ ( 存储管理 | 页式存储弊端 - 段式存储引入 | 段式存储 | 段表 | 段表结构 | 逻辑地址 的 合法段地址判断 )

文章目录 一、页式存储弊端 - 段式存储引入1、页式存储弊端 - 内存碎片2、页式存储弊端 - 逻辑结构不匹配3、段式存储引入 二、段式存储 简介1、段式存储2、段表3、段表 结构4、段内地址 / 段内偏移5、段式存储 优缺点6、段式存储 与 页式存储 对比 三、逻辑地址 的 合法段地址…...

网络编程-day4-TPC之文件传输

服务器 #include <stdio.h> #include <string.h> #include <unistd.h> #include <stdlib.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <pthread.h> #include <semaphore.h> #includ…...

定制化APP:开启企业数字化转型新未来

在当今快速发展的数字时代,企业的生存与发展不仅依赖于其传统的运营模式,更需要借助创新的技术手段来提升效率、优化服务并创造价值。而定制化的移动应用程序(简称“定制化APP”)正是实现这一目标的重要工具之一。通过量身定制的应用程序,企业能够更好地满足自身独特的业务…...

JS宏进阶:XMLHttpRequest对象

一、概述 XMLHttpRequest简称XHR&#xff0c;它是一个可以在JavaScript中使用的对象&#xff0c;用于在后台与服务器交换数据&#xff0c;实现页面的局部更新&#xff0c;而无需重新加载整个页面&#xff0c;也是Ajax&#xff08;Asynchronous JavaScript and XML&#xff09;…...

点大商城V2-2.6.6源码全开源uniapp +搭建教程

一.介绍 点大商城V2独立开源版本&#xff0c;版本更新至2.6.6&#xff0c;系统支持多端&#xff0c;前端为UNiapp&#xff0c;多端编译。 二.搭建环境&#xff1a; 系统环境&#xff1a;CentOS、 运行环境&#xff1a;宝塔 Linux 网站环境&#xff1a;Nginx 1.21 MySQL 5.…...

Docker的深入浅出

目录 Docker引擎 Docker镜像 (镜像由多个层组成&#xff0c;每层叠加之后&#xff0c;从外部看来就如一个独立的对象。镜像内部是一个精简的操作系统&#xff08;OS&#xff09;&#xff0c;同时还包含应用运行所必须的文件和依赖包) Docker容器 应用容器化--Docker化 最佳…...

导航守卫router.beforeEach

router.beforeEach 是一个全局前置守卫&#xff0c;在每次路由跳转之前都会触发。 //index.jsrouter.beforeEach((to, from, next) > {// 打印即将要进入的目标路由信息console.log(即将要进入的目标路由信息:, to)// 打印当前正要离开的路由信息console.log(当前正要离开的…...

Perl语言的软件开发工具

Perl语言的软件开发工具 引言 在当今软件开发的世界中&#xff0c;随着互联网的快速发展和信息技术的不断进步&#xff0c;编程语言和开发工具的选择变得尤为重要。特别是在处理大量数据、实现快速原型以及网络编程等领域&#xff0c;Perl语言凭借其独特的优势而受到广泛青睐…...

在 Linux 系统下,解压 `.tar.gz`

在 Linux 系统下,解压 .tar.gz 文件通常使用 tar 命令。.tar.gz 文件是一种压缩归档文件,它首先使用 tar 命令将多个文件打包为一个 .tar 文件,然后再使用 gzip 压缩生成 .tar.gz 文件。 解压 .tar.gz 文件的命令 要解压 .tar.gz 文件,可以使用以下命令: tar -xzvf fil…...

Deepseek

1.Deepseek是什么&#xff1f; deepseek是一家人工智能科技公司所开发的能够进行人工智能对话的一个应用&#xff0c;它的主要目标是大规模的研发与应用。deepseek-R1是它的开源推理模型,主要负责处理复杂任务并且可以免费使用。 2.Deepseek可以做什么&#xff1f; Deepseek…...

oracle如何查询历史最大进程数?

oracle如何查询历史最大进程数&#xff1f; SQL> desc dba_hist_resource_limitName Null? Type---------------------------------------------------- -------- ------------------------------------SNAP_ID …...

强一致性算法:Raft

目录 什么是 Raft 算法&#xff1f; Leader的选举 投票分裂后的选举过程 Raft算法日志复制过程 修复不一样的日志 数据安全性的保证 什么是 Raft 算法&#xff1f; Raft 算法是一种是一种用于管理复制日志的强一致性算法&#xff0c;用于保证分布式系统中节点数据的一致…...

8.flask+websocket

http是短连接&#xff0c;无状态的。 websocket是长连接&#xff0c;有状态的。 flask中使用websocket from flask import Flask, request import asyncio import json import time import websockets from threading import Thread from urllib.parse import urlparse, pars…...

是德科技 | PCIe 7.0 互连— PCIe的尽头会是光吗?

伴随大语言模型和相关训练系统迅猛增长、对非结构化数据处理的需求急剧上升&#xff0c;市场对算力的需求也是呈指数级增加。PCIe作为计算机和服务器中使用广泛的高速数据传输技术发展迅猛&#xff0c;今年4月份PCI-SIG已经批准 Draft 0.5版基础规范&#xff0c;目前0.7版本基础…...

Aitken 逐次线性插值

Aitken 逐次线性插值 用 Lagrange 插值多项式 L n ( x ) L_n(x) Ln​(x)计算函数近似值时&#xff0c;如需增加插值节点&#xff0c;那么原来算出的数据均不能利用&#xff0c;必须重新计算。为克服这个缺点&#xff0c;可用逐次线性插值方法求得高次插值。 令 I i 1 , i 2…...

Orange 开源项目介绍

Orange 开源项目 项目兼容单体架构与微服务架构两种模式&#xff0c;集成了包括部门管理、用户管理、菜单配置、角色分配、字典维护以及日志记录在内的多种系统管理功能。 项目体验 Orange 官网: http://hengzq.cn在线体验: http://tiny.hengzq.cn项目文档: http://hengzq.cn/…...

【高级架构师】多线程和高并发编程(三):锁(下)深入ReentrantReadWriteLock

文章目录 4、深入ReentrantReadWriteLock4.1 为什么要出现读写锁4.2 读写锁的实现原理4.3 写锁分析4.3.1 写锁加锁流程概述4.3.2 写锁加锁源码分析4.3.3 写锁释放锁流程概述&释放锁源码 4.4 读锁分析4.4.1 读锁加锁流程概述4.4.1.1 基础读锁流程4.4.1.2 读锁重入流程4.4.1.…...

如何在Node.js中使用中间件处理请求

Node.js作为一种基于事件驱动、非阻塞I/O模型的运行环境&#xff0c;广泛用于构建高性能的Web应用。在Node.js中&#xff0c;处理中间件是处理HTTP请求和响应的一个常见方式&#xff0c;特别是在使用Express框架时&#xff0c;中间件扮演着至关重要的角色。本文将介绍如何在Nod…...

Kotlin 2.1.0 入门教程(十三)异常、Nothing

创建自定义异常 可以通过创建继承内置 Exception 类来定义自定义异常。这允许你创建更符合应用程序需求的特定错误类型。 要创建一个自定义异常&#xff0c;可以定义一个继承 Exception 的类&#xff1a; class MyException : Exception("My message")在这个例子中…...

Unity 打造游戏资源加密解密系统详解

在游戏开发中&#xff0c;保护游戏资源不被轻易破解和盗用至关重要。本文将详细介绍如何在 Unity 中打造一个游戏资源加密解密系统&#xff0c;并提供技术详解和代码实现。 一、加密方案选择 1.1 对称加密 优点: 加密解密速度快&#xff0c;适合加密大量数据。 缺点: 密钥管…...

HarmonyOS Next 方舟字节码文件格式介绍

在开发中&#xff0c;可读的编程语言要编译成二进制的字节码格式才能被机器识别。在HarmonyOS Next开发中&#xff0c;arkts会编译成方舟字节码。方舟字节码长什么样呢&#xff1f;我们以一个demo编译出的abc文件&#xff1a; 二进制就是长这样&#xff0c;怎么去理解呢&…...

二层、三层小总结

一、网络隔离 1、物理隔离。搭建两套完全独立的网络&#xff0c;这也是最土豪最安全的做法。 2、二层隔离。使用Vlan隔离&#xff0c;使用不同Vlan或者Pvlan等。 3、三层隔离。路由隔离。 4、设备特性隔离。比如端口隔离swichport protected&#xff0c;或者ACL等。 5、安全…...

Window系统通过Docker本地安装ollama和deepseek

在 Windows 系统上安装 Ollama 和 DeepSeek 的步骤如下&#xff1a; 安装 Ollama 安装 WSL&#xff08;Windows Subsystem for Linux&#xff09;&#xff1a; 如果还没有安装 过WSL的&#xff08;安装过的你直接跳过就行了&#xff09;&#xff0c;可以按照以下步骤进行安装&…...