首页
学习
活动
专区
圈层
工具
发布

eBPF在android上的使用

对于eBPF可以简单的理解成kernel实现了一个虚拟机机制,将类C代码编译成字节码(后文有详细解释),挂在到内核的钩子上,当钩子被触发时,kernel在虚拟机的"沙盒"中运行字节码,这样既能方便的实现很多功能...BCC在android系统上也可以运行,但是要对系统进行一定程度的修改,后续可能会写单独的文章进行讲解。对于内核开发者我还比较关注怎么自己来实现监控的功能,下文也将做简单的讲解。 ?...8)中断性能 三、eBPF框架 在开始说明之前先解释下eBPF上的名词,来帮忙更好的理解。...可以使用下面的命令调试动态加载 ? 4. 用户空间程序实现 下面我们需要编写用户空间的显示程序,本质上就是在用户态通过系统调用把BPF map给读出来。 ? ?...至此,如何在android平台使用eBPF实现统计系统中每个pid在一段时间内系统调用的次数的功能就介绍完了。

5.9K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    ProGuard 在 Android 上的使用姿势

    减少包体积的好处有很多,比如增加用户黏性和满意度,提升下载速度,减少安装时间,以便在终端设备上连接用户,尤其是在新兴市场。...如果以上还不足以说服您使用 ProGuard,其实移除无用代码和混淆所有名称还有其他更多的优化效果: 在一些版本的 Android 设备上,DEX 代码会在安装或者运行时被编译成机器码。...这些警告的一个原因就是,您的构建路径中没有加入需要依赖的 JARs,如使用了 provided (仅编译时)依赖。而有时候,在 Android 上这些代码的依赖在运行时并不会被真正的调用。...在某些情况下,ProGuard 的警告确实有助于您发现闪退的罪魁祸首和关于您配置上的其他问题。...tools 目录下(SDK/tools/proguard/proguard-android.txt),但在新版的 SDK Tools 和 Android Gradle 插件版本2.2.0+上,可以在构建时从

    3.8K40

    MySQL vs PostgreSQL:算法工程师为何转投PostgreSQL阵营

    当前数据库技术选型的决策困境在机器学习工程实践中,数据基础设施的选型已成为决定项目成败的关键技术决策之一。...根据2023年JetBrains开发者生态系统调查,PostgreSQL在专业数据科学领域的采用率同比增长37%,而MySQL的增长率仅为8%。...核心架构差异:从存储引擎到查询执行的深度剖析1 存储引擎层的技术分野MySQL采用插件式存储引擎架构,默认的InnoDB引擎虽支持事务,但其聚集索引设计在特定场景下存在显著限制。...(32核128GB RAM,NVMe SSD)上耗时仅3.2秒,性能提升14.7倍。...2 查询优化器的智能演进PostgreSQL的遗传查询优化器(GEQO)在处理5表以上JOIN时展现独特优势。我们通过一个推荐系统的特征关联查询来验证。

    28210

    告别 Count Distinct 慢查询:StarRocks 高效去重全攻略

    在大数据分析中,去重计算(如 Count Distinct)是一个常见但计算开销极高的操作,尤其在高基数和高并发场景下,常常成为查询性能的瓶颈。...对于大规模聚合键表,读取操作时底层存储的合并成本可能会超过直接扫描详细表的成本。查询性能可能会比直接在去重键表上执行 COUNT DISTINCT 更差。...(array_agg(lo_linenumber)) as ndv2, array_distinct(array_agg(lo_orderpriority)) as ndv3, -- ndv...因此,在实际使用中需要根据具体业务场景权衡选择。...去重列为普通 string 或其他非数值类型时:如需精确去重,可使用 array_distinct(array_agg(column)) 保存中间状态;如可接受近似去重,则可根据数据特点与精度要求,选择

    33110

    Prometheus+Grafana PG监控部署以及自定义监控指标

    exporter:广义上向Prometheus提供监控数据的程序都可以成为一个exporter的,一个exporter的实例称为target, exporter来源主要有2个方面:一方面是社区提供的,另一方面是用户自定义的...注2:尽量不要使用root用户运行,而是采用postgres用户或者别的适当用户。...注3:在需要新增监控指标的参数添加时,一定要参照git上的pg_queries.yaml格式进行修改(包括缩进等,最好就是复制原有的再进行修改,postgres_exporter在这里执行的非常严格,最开始配置的时候我在这里调了不少时间...) 8.新增监控指标: 8.1 在postgres_exporter端的pg_queries.yaml中加入该监控指标的查询SQL 例如: 8.2 在192.168.254.128:9187/metrics...上图中1的位置是设置需要显示在图例中的相关参数值,这个值是取自8.2中讲到的相关数字。 设置好之后数据就会又展示出来,保存即可。

    5K21

    Postgresql快照堆栈ActiveSnapshot

    因为在事务中,有些行为是需要看到最新数据的,比如一个RR事务拿到一个快照后执行了一段时间,这时运行了一条CALL Func或触发器语句,开始进入函数的执行逻辑。...那么这个函数按照PG的定义,是需要自己重新拿最新的快照去执行的,调用或被触发的函数,直观上理解应该能看到 调用时刻的最新数据才对,而不是看到很久前事务启动时的数据。...代码中是在CallStmt时判断procedure则拿新的快照,旧的入栈。 3 快照堆栈 实际上PG中PushActiveSnapshot的用处非常多,例如创建索引、vacuum等等。...几个内部变量: CurrentSnapshot:表示当前连接正在使用的活动事务快照。 SecondarySnapshot:永远指向一个最新的快照。...PG中的快照和其他资源一样,生命周期也是严格跟随事务系统的,也就是在事务提交、撤销、子事务提交、子事务撤销时,都会有快照的销毁或转移动作。

    1.3K60

    Linux的GUI程序在Windows上使用

    一,在linux机上安装xorg-x11-xauth 如果没装,启动GUI程序会提示Canno open display。...yes 三、在Windows客户端上安装X11 Server程序 Xming是运行于Windows下的X 服务器,下载Xming:http://sourceforge.net/projects/xming...安装完成后,点击启动即可 四、在Windows上的ssh客户端设置 客户端需要设置x11转发,常用secureCRT和putty,根据自己所用的客户端设置即可。...五、安装字体文件 如果发现无法显示文字,有可能是服务器上没安装字体文件,解决方法是到yum上装几个 yum search fonts yum install wqy-zenhei-fonts.noarch...yum install xorg-x11-fonts-100dpi.noarch 最后,登录devnet tlinux服务器,运行一个GUI程序,就可以在windows上看到!

    5.9K50

    Apache Doris 聚合函数源码阅读与解析|源码解读系列

    相较于单机数据库,由于所有数据都存储在同一台机器上、无需跨节点的网络数据传输,往往单机数据库的聚合函数执行效率更高,而分布式数据库由于数据分散存储于多个节点、并行执行计算时需要从多个节点汇集数据,带来了额外的网络传输和本地磁盘...By 包含非分桶列,同一个分组中的数据可能分布在多个 BE 上;三阶段聚合:Count Distinct 包含 Group By(即 2 个两阶段聚合的组合);四阶段聚合:Count Distinct...;将聚合后的结果按照 distinct 字段进行重分区,然后对新的分区按照 distinct 字段进行分组聚合;将 count distinct 转换为 count,对新的分区进行聚合;对各分区的结果进行汇总聚合...在 Prepare 阶段会使用 std::bind 将函数绑定到具体的实现上,根据是否开启 streaming pre-agg、是否存在 group by、是否存在 distinct 等条件来确定具体绑定什么函数...array_agg 使用介绍语法:ARRAY_AGG(col)功能:将一列中的值(包括空值 null)串联成一个数组,可以用于多行转一行(行转列)。

    1.1K11

    在 CentOS 7 上使用 Apache 的 SSL 证书

    [题图] 本指南将向你演示如何启用 SSL 来保护由 CentOS 或者 Fedora 上的 Apache 提供服务的网站。...前期准备 本文假定你在 CentOS 或 Fedora 上运行 Apache2。...在使用本指南之前, 确保你在 Linode 上执行了以下步骤: 了解我们的入门指引并完成设置 Linode 主机名和时区的步骤。...完成 CenOS 上的 LAMP指南,并创建一个你希望使用 SSL 保护的站点。 按照我们的指引获取一个自签名的或商业的 SSL证书。...你可以通过运行以下命令来执行此操作: yum install mod_ssl 配置 Apache 以使用 SSL 证书 1.编辑 /etc/httpd/conf.d/ssl.conf 文件中的虚拟主机条目来将认证文件和需要用在每个域名上的虚拟主机信息包含在内

    3.6K20

    如何正确的在 Android 上使用协程 ?

    第一类是 Medium 上热门文章的翻译,其实我也翻译过: 在 Android 上使用协程(一):Getting The Background 在 Android 上使用协程(二):Getting started...在 Android 上使用协程(三) :Real Work 说实话,这三篇文章的确加深了我对协程的理解。...在 Android 中,一般是不建议直接使用 GlobalScope 的。那么,在 Android 中应该如何正确使用协程呢?再细分一点,如何直接在 Activity 中使用呢?...如何配合 ViewModel 、LiveData 、LifeCycle 等使用呢?我会通过简单的示例代码来阐述 Android 上的协程使用,你也可以跟着动手敲一敲。...协程在 Android 上的使用 GlobalScope 在一般的应用场景下,我们都希望可以异步进行耗时任务,比如网络请求,数据处理等等。当我们离开当前页面的时候,也希望可以取消正在进行的异步任务。

    4.4K30

    在 Linux 上使用 NTP 保持精确的时间

    如何保持正确的时间,如何使用 NTP 和 systemd 让你的计算机在不滥用时间服务器的前提下保持同步。 它的时间是多少? 让 Linux 来告诉你时间的时候,它是很奇怪的。...1.fedora.pool.ntp.org 你可以输入你希望使用的其它时间服务器,比如你自己的本地 NTP 服务器,在 NTP= 行上输入一个以空格分隔的服务器列表。...(别忘了取消这一行的注释)NTP= 行上的任何内容都将覆盖掉 FallbackNTP 行上的配置项。 如果你不想使用 systemd 呢?那么,你将需要 NTP 就行。...在大多数 Linux 上的 NTP 都来自 ntp 包,它们大多都提供 /etc/ntp.conf 文件去配置时间服务器。查阅 NTP 时间服务器池 去找到你所在的区域的合适的 NTP 服务器池。...现在,你可以在你的局域网中的其它计算机上设置 systemd-timesyncd,这样它们就可以使用你的本地 NTP 服务器了,或者,在它们上面安装 NTP,然后在它们的 /etc/ntp.conf 上输入你的本地

    2.5K20

    在 FreeBSD 10.2 上安装使用 Nginx 的 Ghost

    Node.js 是用于开发服务器端应用程序的开源的运行时环境。Node.js 应用使用 JavaScript 编写,能在任何有 Node.js 运行时的服务器上运行。...Node.js 是 Ryan Dahl 以及在 Joyent 工作的其他开发者于 2009 年创建的。它的设计目标就是构建可扩展的网络应用程序。 Ghost 是使用 Node.js 编写的博客平台。...它不仅开源,而且有很漂亮的界面设计、对用户友好并且免费。它允许你快速地在网络上发布内容,或者创建你的混合网站。...在这篇指南中我们会在 FreeBSD 上安装使用 Nginx 作为 web 服务器的 Ghost。我们会在 FreeBSD 10.2 上安装 Node.js、Npm、nginx 和 sqlite3。...第一步 - 安装 Node.js npm 和 Sqlite3 如果你想在你的服务器上运行 ghost,你必须安装 node.js。

    1.8K20

    在 centos 上使用 NTP 保持精确的时间

    你的系统上(至少)有两个时钟:系统时间 —— 它由 Linux 内核管理,第二个是你的主板上的硬件时钟,它也称为实时时钟(RTC)。...1.fedora.pool.ntp.org 你可以输入你希望使用的其它时间服务器,比如你自己的本地 NTP 服务器,在 NTP= 行上输入一个以空格分隔的服务器列表。...(别忘了取消这一行的注释)NTP= 行上的任何内容都将覆盖掉 FallbackNTP 行上的配置项。 如果你不想使用 systemd 呢?那么,你将需要 NTP 就行。...在大多数 Linux 上的 NTP 都来自 ntp 包,它们大多都提供 /etc/ntp.conf 文件去配置时间服务器。查阅 NTP 时间服务器池 去找到你所在的区域的合适的 NTP 服务器池。...现在,你可以在你的局域网中的其它计算机上设置 systemd-timesyncd,这样它们就可以使用你的本地 NTP 服务器了,或者,在它们上面安装 NTP,然后在它们的 /etc/ntp.conf 上输入你的本地

    1.7K30

    使用Hexo在Github上搭建自己的博客

    以前的博客是使用Jekyll托管在github上,后来用着越来越不方便,比如没有自动生成post,不能一键部署,文件结构和配置也是比较繁琐,更重要的是有时候用markdown写一篇文章,生成的静态文件很乱...现在下决心换成了hexo Nodejs安装 因为hexo是基于nodejs的应用,所以要先安装nodejs才可以。我这里以ubuntu为例,因为我自己一直在使用ubuntu。...这里有一些Front-matter需要介绍,可以配置文章使用的模板、所属的分类和tag等。...Front-matter 是文件最上方以 — 分隔的区域,用于指定个别文件的变量,举例来说: title: "使用Hexo在Github上搭建自己的博客" date: 2015-03-10 22:30:...hexo clean hexo generate 然后把生成的public目录下的文件放到你的master分支下即可。git commit后把这两个分支推送到你的github上。

    75920

    【论文】使用bilstm在中文分词上的SOTA模型

    文章模型使用的是字和字bigram作为输入,所以使用wang2vec(https://github.com/wlin12/wang2vec),在word2vec中加入了顺序信息。...2.在LSTM中加入了dropout。3.使用momentum-based averaged SGD(Weiss et al.2015)方法训练模型。主要就是优化算法的小改进加上超参数的网格搜索。...在大部分的数据集上加入预训练的字向量都能有一个点左右的提升,除了MSR和PKU两个数据集,这两个数据集上本文算法表现并不好。...在我的认知和平时的实验中,一般使用预训练字向量时会选择fine-tuning,因为考虑到任务的特殊性,比较通用的词向量很难学到某些特定领域词在任务中的表示。...结论: 作者没有对本文做过多的总结,给出了中文分词两个挑战,也可以说是展望吧:1.模型结构上的调优,2.外部知识库的使用。

    1.7K20
    领券