升级到 CDP 后Hive on Tez 性能调整和故障排除指南
优化Hive on Tez查询永远不能以一种万能的方法来完成。查询的性能取决于数据的大小、文件类型、查询设计和查询模式。在性能测试期间,要评估和验证配置参数和任何 SQL 修改。建议在工作负载的性能测试期间一次进行一项更改,并且最好在生产环境中使用它们之前评估调整更改在您的开发和 QA 环境中的影响。Cloudera WXM可以帮助评估性能测试期间查询更改的好处。
下面先介绍常见的调优组合。
0.常用参数组合
0.1 文件合并
Try using TEZ execution engine and then hive.merge.tezfiles. You might also want to specify the size as well.
set hive.execution.engine=tez; -- TEZ execution engine
set hive.merge.tezfiles=true; -- Notifying that merge step is required
set hive.merge.smallfiles.avgsize=128000000; --128MB
set hive.merge.size.per.task=128000000; -- 128MB 最好是HDFS BLOCK 大小的整数倍
0.2 参数调优
set hive.exec.dynamic.partition=true;
set hive.exec.dynamic.partition.mode=nonstrict;
set hive.exec.max.dynamic.partitions=3000;
set hive.exec.max.dynamic.partitions.pernode=500;
sethive.tez.container.size=6656; -- container大小,一直跑不出来
set hive.tez.java.opts=-Xmx5120m; --java heap space内存溢出
set hive.merge.tezfiles=true;
set hive.merge.smallfiles.avgsize=128000000;--128M
set hive.merge.size.per.task=128000000;--128M
set hive.execution.engine=tez;
set tez.am.task.max.failed.attempts=10; -- 重试失败,资源竞争激烈
set tez.am.max.app.attemps=5; -- 重试失败,资源竞争激烈如果map阶段划分过多,可以设置为合并小文件格式化org.apache.hadoop.hive.ql.io.CombineHiveInputFormat
hive.tez.input.format=org.apache.hadoop.hive.ql.io.HiveInputFormat
hive.tez.input.format=org.apache.hadoop.hive.ql.io.CombineHiveInputFormat
0.3 小文件手动合并
#对于非分区表
alter table tablename concatenate;
#对于分区表
alter table tablename partition(dt=20201224) concatenate;
insert overwrite table tableName partition(dt=2022031100)
select column1,column2 from tableName
where dt = 2022031100
# 只支持 RCFILE 和 ORC 文件类型,需要执行多次,才能把文件合并为1个
# impala里面 set num_nodes=1; 可以强行合并程1个
0.4 其他参考
# 参考
Hive 命令
hive.merge.mapredfiles=true;
hive.merge.mapfiles=true
hive.merge.rcfile.block.level=true
hive.merge.size.per.task=256000000
hive.merge.smallfiles.avgsize=16000000spark 命令 :
hive.merge.sparkfiles=true
开始干货,相关调优指南~
1. 调优指南
在从 CDH 发行版到 CDP 私有云的多次迁移中观察到,与 MR 或 Spark 等较旧的执行引擎相比,Hive on Tez查询往往执行得更慢。这通常是由不同执行引擎之间的开箱即用的调整行为的差异引起的。此外,用户可能已经完成了对旧版分发的调整,这不会自动反映在 Hive on Tez转换中。对于从 HDP 发行版升级的用户,此讨论还有助于查看和验证是否正确配置了属性以实现 CDP 中的性能。
1.1. 确定问题步骤
以下步骤可帮助您确定可能会降低性能的重点领域。
第 1 步:核实和验证 YARN 容量调度器的配置。由于错误配置的队列配置(用户可用资源的任意上限)可能会影响查询性能。验证用户限制因子、最小用户限制百分比和最大容量。(请参阅YARN – 容量调度器博客以了解这些配置设置。)
第 2 步:查看 Hive on Tez和 Hive 的任何安全阀(Hive 和 HiveServer2 配置的非默认值)的相关性。删除任何遗留和过时的属性。
第 3 步:识别缓慢的区域,例如 map 任务、reduce 任务和Join。
- 查看通用的 Tez 引擎和平台的可调整的属性。
- 查看Map任务并调整-根据需要增加/减少任务计数。
- 查看Reduce任务并调整-根据需要增加/减少任务计数。
- 查看任何与并发相关的问题——这里有两种并发问题,如下所示:
- 队列内用户之间的并发。这可以使用 YARN 队列的用户限制因子进行调整(请参阅容量调度器博客中的详细信息)。
- Hive on Tez 会话的预热容器之间的并发性,如下文详细讨论。
2. 了解 Tez 中的并行化
在更改任何配置之前,您必须了解 Tez 内部工作的机制。例如,这包括了解 Tez 如何确定正确的Map和Reduce数量。查看 Tez 架构设计以及有关初始任务并行性和自动减少并行性如何工作的详细信息将帮助您优化查询性能。
3. 了解Map的数量
Tez 使用作业的初始输入数据来确定Map任务的数量。在 Tez 中,任务的数量由分组拆分决定,这相当于 map reduce 作业中由输入拆分确定的Map数量。
- tez.grouping.min-size和tez.grouping.max-size确定Map的数量。min-size的默认值为16 MB, max-size为 1 GB。
- Tez 确定任务的数量,以使每个任务的数据符合分组最大/最小大小。
- 减小tez.grouping.max-size会增加Map/Reduce的数量。
- 增加tez.grouping.max-size会减少任务的数量。
- 考虑以下示例:
- 输入数据(输入分片/分割)如 1000 个文件(大约 1.5 MB 大小)
- 总数据大小为 1000*1.5 MB = ~ 1.5 GB
- Tez 可以尝试使用至少两个任务处理此数据,因为最大数据/任务可能是 1 G。最终,Tez 可以强制将 1000 个文件(拆分)合并为两个任务,从而导致执行时间变慢。
- 如果tez.grouping.max-size从 1 GB 减少到 100 MB,则Map的数量可以增加到 15 个,从而提供更好的并行性。然后性能会提高,因为改进的并行性将工作从两个并发任务扩展到 15 个。
以上是一个示例场景,但是在使用 ORC 或 parquet 等二进制文件格式的生产环境中,根据存储类型、拆分策略文件或 HDFS 块边界确定Map的数量可能会变得复杂。 注意:更高程度的并行性(例如大量Map/Reduce)并不总是转化为更好的性能,因为它可能导致每个任务的资源更少,并且由于任务开销而导致更高的资源浪费。
4. 了解Reduce的数量
Tez 使用多种机制和设置来确定完成查询所需的 reducer 数量。
- Tez 根据要处理的数据(字节数)自动确定 reducer。
- 如果hive.tez.auto.reducer.parallelism设置为true,hive会估计数据大小并设置并行度估计。Tez 将对源顶点的输出大小进行采样,并根据需要在运行时调整估计值。
- 默认情况下,最大Reduce数量设置为 1009 ( hive.exec.reducers.max )
- Hive/Tez 使用以下公式估计 reducer 的数量,然后调度 Tez DAG:Max(1, Min(hive.exec.reducers.max [1009], ReducerStage estimate/hive.exec.reducers.bytes.per.reducer)) x hive.tez.max.partition.factor [2]
可以调整以下三个参数来增加或减少Map的数量:
- hive.exec.reducers.bytes.per.reducer 每个 reducer 的大小。将其更改为较小的值以增加并行度,或将其更改为较大的值以降低并行度。默认值 = 256 MB [即如果输入大小为 1 GB,则将使用 4 个Reduce]
- tez.min.partition.factor 默认值 = 0.25
- tez.max.partition.factor 默认值 = 2.0 增加更多Reduce。减少Reduce的数量。
用户可以使用mapred.reduce.tasks 手动设置 reducer 的数量。
不建议这样做,您应该避免使用它。
建议:
- 避免手动设置Reduce。
- 添加更多Reduce并不总能保证更好的性能。
- 如果要增加或减少 reducer 的数量,请根据 reduce 阶段的估计值将hive.exec.reducers.bytes.per.reducer参数调整为更低或更高的值。
5. 并发
本部分旨在帮助理解和调整 Hive on Tez 的并发会话,例如运行多个 Tez AM【AppMaster】 容器。以下属性有助于理解默认队列和会话数行为。
- hive.server2.tez.default.queues :逗号分隔值的列表,对应于维护 Tez 会话池的 YARN 队列。
- hive.server2.tez.sessions.per.default.queue : 每个 YARN 队列在池中维护的 Tez 会话数 (DAGAppMaster)。
- hive.server2.tez.initialize.default.sessions:如果启用,HiveServer2 (HS2) 在启动时将在指定的default.queues内启动所有必要的 Tez会话以满足 session.per.default.queue 的要求。 当您定义下面列出的属性时,HiveServer2 将为每个默认队列创建一个 Tez Application Master (AM),乘以 HiveServer2 服务启动时的会话数。因此:
(Tez Sessions)total = HiveServer2instances x (default.queues) x (sessions.per.default.queue)
通过示例理解:
hive.server2.tez.default.queues= “queue1, queue2”
hive.server2.tez.sessions.per.default.queue=2 =>Hiveserver2 将创建 4 个 Tez AM(2 个用于 queue1,2 个用于 queue2)。
注意:池化的 Tez 会话始终在运行,即使在空闲集群上也是如此。 如果 HiveServer2 持续使用,那些 Tez AM 将继续运行,但如果您的 HS2 空闲,这些 Tez AM 将根据tez.session.am.dag.submit.timeout.secs 定义的超时被终止。
情况一:未指定队列名称
如果未指定队列名称 ( tez.queue.name ) ,则查询将仅使用池中的 Tez AM(如上所述初始化)。在这种情况下,HiveServer2 将选择 Tez AM 空闲/可用之一(此处的队列名称可能是随机选择的)。
如果未指定队列名称,则查询将在 HiveServer2 中保持挂起状态,直到初始化池中的默认 Tez AM 之一可用于为查询提供服务。JDBC/ODBC 客户端或 HiveServer2 日志文件中不会有任何消息。因为查询挂起时没有生成消息,所以用户可能认为 JDBC/ODBC 连接或 HiveServer2 已损坏,但它正在等待 Tez AM 执行查询。
情况二:指定队列名称
如果确实指定了队列名称,那么无论有多少已初始化的 Tez AM 正在使用或空闲,HiveServer2 都会为此连接创建一个新的 Tez AM,并且可以执行查询(如果队列有可用资源)。 并发指南/建议:
对于不希望用户限制在同一个 Tez AM 池中的用例或查询,将此hive.server2.tez.initialize.default.sessions设置为 false。禁用此功能可以减少 HiveServer2 上的争用并提高查询性能。
此外,增加会话数量hive.server2.tez.sessions.per.default.queue
如果有需要为每组用户使用单独或专用的 Tez AM 池的用例,则需要有专用的 HiveServer2 服务,每个服务都有各自的默认队列名称和会话数,并要求每组用户使用他们各自的 HiveServer2。
6. 容器重用和预热容器
容器重用:
这是一种限制启动时间对容器的影响的优化。这是通过将tez.am.container.reuse.enabled设置为true来打开的。这节省了与 YARN 交互的时间。我还让容器组保持活力,更快地旋转容器,并跳过Yarn队列。
预热容器:
容器的数量与默认情况下将附加到每个 Tez AM 的 YARN 执行容器的数量有关。每个 AM 将持有相同数量的容器,即使 Tez AM 空闲(不执行查询)也是如此。 如果有太多容器处于空闲状态且未释放,则会出现这种情况,因为此处定义的容器将由 Tez AM 持有,即使它处于空闲状态。这些空闲容器将继续占用 YARN 中其他应用程序可能使用的资源。 以下属性用于配置 Prewarm Containers:
hive.prewarm.enabled
hive.prewarm.numcontainers
7. 通用的 Tez 调整参数
在处理 Tez 查询上 Hive 的性能下降时,请查看下面列出的属性作为第一级检查。您可能需要根据您的查询和数据属性设置或调整其中一些属性。最好在开发和 QA 环境中评估配置属性,然后根据结果将其推送到生产环境。
- hive.cbo.enable 将此属性设置为 true可启用基于成本的优化 (CBO)。CBO 是 Hive 查询处理引擎的一部分。它由 Apache Calcite 提供支持。CBO 通过检查查询中指定的表和条件来生成高效的查询计划,最终减少查询执行时间并提高资源利用率。
- hive.auto.convert.join 将此属性设置为 true 允许 Hive 启用关于根据输入文件大小将 common join 转换为 mapjoin 的优化。
- hive.auto.convert.join.noconditionaltask.size 您将希望在查询中执行尽可能多的 mapjoin。这种大小配置使用户能够控制什么大小的表可以适合内存。该值表示可以转换为适合内存的哈希图的表大小的总和。建议将其设置为hive.tez.container.size 大小的 ⅓。
- tez.runtime.io.sort.mb 输出排序时排序缓冲区的大小。建议将其设置为hive.tez.container.size的40%, 最大为 2 GB。它很少需要超过这个最大值。
- tez.runtime.unordered.output.buffer.size-mb 这是输出不需要排序时的内存。如果不直接写入磁盘,则它是要使用的缓冲区大小。建议将其设置为hive.tez.container.size的10% 。
- hive.exec.parallel 此属性启用 Hive 查询阶段的并行执行。默认情况下,此设置为 false。将此属性设置为 true 有助于并行化独立查询阶段,从而提高整体性能。
- hive.vectorized.execution.enabled 矢量化查询执行是 Hive 的一项功能,可大大降低扫描、过滤器、聚合和连接等典型查询操作的 CPU 使用率。默认情况下,这设置为 false。将此设置为true。
- hive.merge.tezfiles 默认情况下,此属性设置为 false。将此属性设置为 true 将合并 Tez 文件。使用此属性可能会增加或减少查询的执行时间,具体取决于数据的大小或要合并的文件数。在使用此属性之前,请评估您在较低环境中的查询性能。
- hive.merge.size.per.task 此属性描述作业结束时合并文件的大小。
- hive.merge.smallfiles.avgsize 当作业的平均输出文件大小小于此数字时,Hive 将启动额外的 map-reduce 作业以将输出文件合并为更大的文件。默认情况下,此属性设置为 16 MB。
8. 总结
此博客介绍了有关 CDP 的 Hive on Tez 查询的一些基本故障排除和调整指南。作为查询性能分析的第一步,您应该验证并验证在 Hive 和 Hive on Tez 服务上设置的所有配置。所做的每一项更改都应进行测试,以确保其做出可衡量且有益的改进。查询调优是一项专门的工作,并非所有查询都可以通过更改 Tez 配置属性来更好地执行。您可能会遇到需要深入研究 SQL 查询以优化和提高执行和性能的场景。如果您需要有关性能调整工作的更多帮助,请联系您的 Cloudera 帐户和专业服务团队以提供指导。
原文作者:Jay Desai 原文链接:https://blog.cloudera.com/optimizing-hive-on-tez-performance/
相关文章:
升级到 CDP 后Hive on Tez 性能调整和故障排除指南
优化Hive on Tez查询永远不能以一种万能的方法来完成。查询的性能取决于数据的大小、文件类型、查询设计和查询模式。在性能测试期间,要评估和验证配置参数和任何 SQL 修改。建议在工作负载的性能测试期间一次进行一项更改,并且最好在生产环境中使用它们…...
理解HDFS工作流程与机制,看这篇文章就够了
HDFS(The Hadoop Distributed File System) 是最初由Yahoo提出的分布式文件系统,它主要用来: 1)存储大数据 2)为应用提供大数据高速读取的能力 重点是掌握HDFS的文件读写流程,体会这种机制对整个分布式系统性能提升…...
Intel处理器分页机制
分页模式 Intel 64位处理器支持3种分页模式: 32-bit分页PAE分页IA-32e分页 32-bit分页 32-bit分页模式支持两种页面大小:4KB以及4MB。 4KB页面的线性地址转换 4MB页面的线性地址转换 PAE分页模式 PAE分页模式支持两种页面大小:4KB以及…...
Linux常用命令
linux常用命令创建一个目录mkdir 命令可以创建新目录。mkdir 是 make directory 的缩写。[rootiZ2ze66tzux2otcpbvie88Z ~]# ls [rootiZ2ze66tzux2otcpbvie88Z ~]# mkdir web [rootiZ2ze66tzux2otcpbvie88Z ~]# ls web [rootiZ2ze66tzux2otcpbvie88Z ~]# 创建一个文件2.1 在 Li…...
基于STM32设计的音乐播放器
一、项目背景与设计思路 1.1 项目背景 时代进步,科学技术的不断创新,促进电子产品的不断更迭换代,各种新功能和新技术的电子产品牵引着消费者的眼球。人们生活水平的逐渐提高,对娱乐消费市场需求日益扩大,而其消费电子产品在市场中的占有份额越来越举足轻重。目前消费电…...
微服务开发
目录 微服务配置管理 权限认证 批处理 定时任务 异步 微服务调用 (协议)...
【(C语言)数据结构奋斗100天】二叉树(上)
【(C语言)数据结构奋斗100天】二叉树(上) 🏠个人主页:泡泡牛奶 🌵系列专栏:数据结构奋斗100天 本期所介绍的是二叉树,那么什么是二叉树呢?在知道答案之前,请大家思考一下…...
Java 验证二叉搜索树
验证二叉搜索树中等给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。有效 二叉搜索树定义如下:节点的左子树只包含 小于 当前节点的数。节点的右子树只包含 大于 当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。示例 1&…...
C/C++单项选择题标准化考试系统[2023-02-09]
C/C单项选择题标准化考试系统[2023-02-09] ©3.17 单项选择题标准化考试系统 【难度系数】5级 【任务描述】 设计一个单项选择题的考试系统,可实现试题维护、自动组卷等功能。 【功能描述】 (1)管理员功能: 试题管理:每个试题包括题干、四个备选答案标准答案…...
爱了爱了,这些顶级的 Python 工具包太棒了
Python 语言向来以丰富的第三方库而闻名,今天来介绍几个非常nice的库,有趣好玩且强大!推荐好好学习。 文章目录技术交流数据采集AKShareTuShareGoPUPGeneralNewsExtractor爬虫playwright-pythonawesome-python-login-modelDecryptLoginScylla…...
【Explain详解与索引优化最佳实践】
摘要 explain命令是查看MySQL查询优化器如何执行查询的主要方法,可以很好的分析SQL语句的执行情况。每当遇到执行慢(在业务角度)的SQL,都可以使用explain检查SQL的执行情况,并根据explain的结果相应的去调优SQL等。 …...
【树和二叉树】数据结构二叉树和树的概念认识
前言:在之前,我们已经把栈和队列的相关概念以及实现的方法进行了学习,今天我们将认识一个新的知识“树”!!! 目录1.树概念及结构1.1树的概念1.2树的结构1.3树的相关概念1.4 树的表示1.5 树在实际中的运用&a…...
通达信收费接口查询可申购新股c++源码分享
有很多股民在做股票交易时为了实现盈利会借助第三三方炒股工具帮助自己,那么通达信收费接口就是人们常用到的,今天小编来分享一下通达信收费接口查询可申购新股c源码: std::cout << " 查询可申购新股: category 12 \n"; c…...
【C#设计模式】创建型设计模式 (单例,工厂)。
c# 创建型设计模式 1.单例设计模式c# 单例JS 单例(ES6)c# 扩展方法c# 如果窗体非单例(tips:窗口可以容器化)2.工厂设计模式JS 简单工厂(ES6)C# 简单工厂C# params关键词(自定义参数个数)JS 手写JQuery(委托,工厂方式隐藏细节)JS ...四种用法C# 偷懒工厂1.单例设计模式 …...
Ubuntu 22.04 LTS 入门安装配置优化、开发软件安装一条龙
Ubuntu 22.04 LTS 入门安装配置&优化、开发软件安装 例行前言 最近在抉择手上空余的笔记本(X220 i7-2620M,Sk Hynix ddr3 8G*2 ,Samsung MINISATA 256G)拿来运行什么系统比较好,早年间我或许还会去继续使用Win…...
第五十章 动态规划——数位DP模型
第五十章 动态规划——数位DP模型一、什么是数位DP数位DP的识别数位DP的思路二、例题1、AcWing 1083. Windy数(数位DP)2、AcWing 1082. 数字游戏(数位DP)3、AcWing 1081. 度的数量(数位DP)一、什么是数位DP…...
02- pandas 数据库 (机器学习)
pandas 数据库重点: pandas 的主要数据结构: Series (一维数据)与 DataFrame (二维数据)。 pd.DataFrame(data np.random.randint(0,151,size (5,3)), # 生成pandas数据 index [Danial,Brandon,softpo,Ella,Cindy], # 行索引 …...
学Qt想系统的学习,看哪本书?
Qt 是一个跨平台应用开发框架(framework),它是用 C语言写的一套类库。使用 Qt 能为 桌面计算机、服务器、移动设备甚至单片机开发各种应用(application),特别是图形用户界面 (graphical user in…...
2023年网络安全比赛--跨站脚本攻击②中职组(超详细)
一、竞赛时间 180分钟 共计3小时 二、竞赛阶段 1.访问服务器网站目录1,根据页面信息完成条件,将获取到弹框信息作为flag提交; 2.访问服务器网站目录2,根据页面信息完成条件,将获取到弹框信息作为flag提交; 3.访问服务器网站目录3,根据页面信息完成条件,将获取到弹框信息…...
网络安全实验室4.注入关
4.注入关 1.最简单的SQL注入 url:http://lab1.xseclab.com/sqli2_3265b4852c13383560327d1c31550b60/index.php 查看源代码,登录名为admin 最简单的SQL注入,登录名写入一个常规的注入语句: admin’ or ‘1’1 密码随便填,验证…...
领域搜索算法之经典The Lin-Kernighan algorithm
领域搜索算法之经典The Lin-Kernighan algorithmThe Lin-Kernighan algorithm关于算法性能提升的约束参考文献领域搜索算法是TSP问题中的三大经典搜索算法之一,另外两种分别是回路构造算法和组合算法。 而这篇文章要介绍的The Lin-Kernighan algorithm属于领域搜索算…...
深度学习基础-机器学习基本原理
本文大部分内容参考《深度学习》书籍,从中抽取重要的知识点,并对部分概念和原理加以自己的总结,适合当作原书的补充资料阅读,也可当作快速阅览机器学习原理基础知识的参考资料。 前言 深度学习是机器学习的一个特定分支。我们要想…...
C语言操作符详解 一针见血!
目录算数操作符移位操作符位操作符赋值操作符单目操作符关系操作符逻辑操作符条件操作符逗号表达式下标引用、函数调用和结构成员表达式求值11.1 隐式类型转换算数操作符💭 注意/ 除法 --得到的是商% 取模(取余)--得到的是余数如果除法操作符…...
前端面试题汇总
一:JavaScript 1、闭包是什么?利弊?如何解决弊端? 闭包是什么:JS中内层函数可以访问外层函数的变量,外层函数无法操作内存函数的变量的特性。我们把这个特性称作闭包。 闭包的好处: 隔离作用…...
以数据驱动管理场景,低代码助力转型下一站
数据驱动 数据驱动,是通过移动互联网或者其他的相关软件为手段采集海量的数据,将数据进行组织形成信息,之后对相关的信息讲行整合和提炼,在数据的基础上经过训练和拟合形成自动化的决策模型,简单来说,就是…...
2023年全国数据治理DAMA-CDGA/CDGP考试报名到弘博创新
弘博创新是DAMA中国授权的数据治理人才培养基地,贴合市场需求定制教学体系,采用行业资深名师授课,理论与实践案例相结合,快速全面提升个人/企业数据治理专业知识与实践经验,通过考试还能获得数据专业领域证书。 DAMA认…...
流程控制之循环
文章目录五、流程控制之循环5.1 步进循环语句for5.1.1 带列表的for循环语句5.1.2 不带列表的for循环语句5.1.3 类C风格的for循环语句5.2 while循环语句5.2.1 while循环读取文件5.2.2 while循环语句示例5.3 until循环语句5.4 select循环语句5.5 嵌套循环5.4 利用break和continue…...
SpringDataRedis快速入门
SpringDataRedis快速入门1.SpringDataRedis简介2.RedisTemplate快速入门3.RedisSerializer4.StringRedisTemplate1.SpringDataRedis简介 SpringData是Spring中数据操作的模块,包含对各种数据库的集成,其中对Redis的集成模块就叫做SpringDataRedis Spri…...
MySQL 的执行计划 explain 详解
目录 什么是执行计划 执行计划的内容 select子句的类型 访问类型 索引的存在形式...
2023年网络安全比赛--Web综合渗透测试中职组(超详细)
一、竞赛时间 180分钟 共计3小时 二、竞赛阶段 1.通过URL访问http://靶机IP/1,对该页面进行渗透测试,将完成后返回的结果内容作为FLAG值提交; 2.通过URL访问http://靶机IP/2,对该页面进行渗透测试,将完成后返回的结果内容作为FLAG值提交; 3.通过URL访问http://靶机IP/3,对…...
莱芜话题 莱芜在线/长沙seo关键词排名
效果图 带描边的粒子效果 原图 承接上文 特效设...
网站支持asp/杭州seo技术培训
iOS 获取图片有三种方法: 1. 直接调用摄像头拍照 2. 从相册中选择 3. 从图库中选择 UIImagePickerController 是系统提供的用来获取图片和视频的接口; 用UIImagePickerController 类来获取图片视频,大体分为以下几个步骤: 1. 初始…...
万宁网站建设/b站推广app大全
shell 在计算机科学中,Shell俗称壳(用来区别于核),是指“提供使用者使用界面”的软件(命令解析器)。它类似于DOS下的command和后来的cmd.exe。它接收用户命令,然后调用相应的应用程序。 同时它又…...
恒基建设集团网站/58同城如何发广告
这个问题实际上就是iframe sandbox 沙盒绕过,iframe通过sandbox属性实现沙箱模式,允许js脚本执行,可直接引用第三方js文件来绕过。禁止iframe 里的javascript 执行 top.location self.location。 也就是禁止了跳转,绕过了反点击劫…...
wordpress配置qq邮箱/谷歌推广怎么开户
erp5开源制造业erp集群部署指南 1 独立服务器安装mariadb 2 独立服务器安装memcache缓存 3 独立服务器安装zeo 4 1-n台服务器安装zope(erp5) 5 独立服务器安装apache代理,对外提供访问url...
怎样创建自己公司的网站/站内关键词排名优化软件
win10 ubuntu 16.04 VNC 6.18 VNC和windows之间的复制粘贴模板不共享,想要开启他们之间的复制粘贴,只需要如下命令: 安装autocutsel sudo apt install autocutsel 命令行中输入: autocutsel或者后台运行: auto…...