- 系统信息性能模块psutil
浅水鲤鱼
linux运维服务器
psutil是一个跨平台库(第三方库/模块),能够获取系统进程进程及CPU,内存,磁盘、网络使用率等信息;主要用于监控系统,分析和限制系统资源及进程的管理它实现了n多个同等命令行工具实现的功能,如ps、top、lsof、netstat、ifconfig、who、df、kill、free、nice、ionice、iostat、iotop、uptime、pidof、tty、taskset、pmap等命
- Linux 性能调优技巧
云夏之末
运维linux运维服务器
1理解Linux性能的基本组成CPU使用率:衡量CPU在单位时间内被占用的程度。内存使用:关注的是活跃内存与缓存内存的比例,以及是否有过多的交换。I/O性能:磁盘读写速度直接影响应用程序的响应时间和吞吐量。网络性能:数据包的丢失率、延迟和带宽都是衡量标准。内核与进程管理:内核如何调度进程、管理内存、处理中断等都会影响性能。2.CPU性能调优处理器亲和性:taskset命令用于将进程固定到特定的CP
- spark streaming优点和缺点
scott_alpha
优点:sparkstreaming会被转化为spark作业执行,由于spark作业依赖DAGScheduler和RDD,所以是粗粒度方式而不是细粒度方式,可以快速处理小批量数据,获得准实时的特性;以spark作业提交和执行,很方便的实现容错机制;DStreaming是在RDD上的抽象,更容易与RDD进行交互操作。需要将流式数据与批数据结合分析的情况下,非常方便。缺点:不可避免的延迟
- Linux 系统性能调优 1
Wade_Crab
linux
Linux系统性能调优涉及多个方面,包括CPU、内存、I/O子系统、网络等。以下是一些常见的Linux系统性能调优技巧,可以帮助提升系统的整体性能。###1.**CPU调优**-**CPU绑定(CPUAffinity)**:通过`taskset`或`cgroups`设置进程或线程与特定CPU核心绑定,减少上下文切换带来的开销。-**CPU频率调节**:利用`cpufreq`工具,选择适当的CPU调
- objective-c中调用shell命令
maricoliu
macobjective-c
Launchingatask[permalink]Herearethebasicstolaunch"ls-l-a-t"inthecurrentdirectory,andthenreadtheresultintoanNSString:NSTask*task;task=[[NSTaskalloc]init];[tasksetLaunchPath:@"/bin/ls"];NSArray*argument
- 【Spark重点难点】你以为的Shuffle和真正的Shuffle
王知无(import_bigdata)
大数据sparkjavapython数据库
我们的【Spark重点难点】系列继续更新。以往的系列:我们在学习Spark的时候,到底在学习什么?我在B站读大学,大数据专业【Spark重点难点01】你从未深入理解的RDD和关键角色通俗解释上节课我们讲了DAGScheduler划分Stage的原理:DAGScheduler调度时会根据是否需要经过Shuffle过程将Job划分为多个Stage。Shuffle就这么重要?正是由于Shuffle的计算
- Spark程序执行逻辑迷你版
{BOOLEAN}
Sparkspark大数据java
Driver就是自己写的程序,里面有一个main方法,main方法划分DAG,形成Task,再把Task发出去DAGScheduler的功能,将rdd转换逻辑切分stage,生成taskset然后模拟taskScheduler的功能,将这些task发到Executor上去执行(真正的发送逻辑sparksubmit进程启动Driver,然后Driver会找Executor,将Executor启动起来
- 【Spark】Spark作业执行原理--提交任务
w1992wishes
本篇结构:创建Task创建TaskSetManager并向DriverEndpoint发送消息分配资源发送消息告诉Executor去执行Task一、创建Task当调度阶段运行后,在DAGScheduler的submitMissingTasks方法中会根据调度阶段Partition数量拆分对应个数任务。对于ResultStage,生成ResultTask,对于ShuffleMapStage生成Shu
- locust--python实现的分布式性能测试工具
chuntian_tester
python开发语言
1.locust特点:1.1支持Python编写测试用例方案;1.2使用requests发送http请求;1.3使用协程实现,高并发时消耗更低;1.4使用Flask提供WebUI;1.5有第三方插件支持扩展;2.创建locust性能测试用例步骤:2.1创建locust.TaskSet的子类;2.2为用例加上@locust.task()装饰器;2.3使用self.client发送请求;2.4制定aw
- 【Spark系列4】Task的执行
周润发的弟弟
从零开始搞大数据java服务器开发语言
一、Task的执行流程1.1、Task执行流程DAGScheduler将Stage生成TaskSet之后,会将Task交给TaskScheduler进行处理,TaskScheduler负责将Task提交到集群中运行,并负责失败重试,为DAGScheduler返回事件信息等,整体如流程如下:当任务提交到TaskScheduler时,TaskScheduler会通知SchedulerBackend分配
- Gradle for Androider
leap_
本文参考:深入理解Android之Gradle写给Android开发者的Gradle系列AndroidStudio自定义GradlePlugingradle是用于构建项目的,在安卓项目中,gradle构建主要是针对.gradle文件,一个安卓项目中的.gradle文件有三种:根目录下的build.gradle:进行全局配置每一个子Moudle下的build.gradle:执行各个构建Taskset
- Spark作业执行原理
垫路的石头
spark
Spark的作业和任务调度系统是Spark的核心,它能够有效地进行调度根本原因是对任务划分DAG和容错,使得它对低层到顶层的各个模块之间的调用和处理显得游刃有余。下面介绍一些相关术语。作业(Job):RDD中由行动操作所生成的一个或多个调度阶段。调度阶段(Stage):每个Job作业会因为RDD之间的依赖关系拆分成多组任务集合,称为调度阶段,简称阶段,也叫做任务集(TaskSet)。调度阶段的划分
- Spark详解(五):Spark作业执行原理
MasterT-J
Spark框架Spark框架Spark框架
Spark的作业和任务调度系统是其核心,它能够有效地进行调度的根本原因是对任务的划分DGG和容错。下面我们介绍一下相关术语:作业(Job):RDD中由行动操作所生成的一个或者多个调度阶段调度阶段(Stage):每个作业会因为RDD之间的依赖关系拆分成多组任务集合,称为调度阶段,也叫做任务集合(TaskSet)。调度阶段的划分是由DAGScheduler俩划分的,调度阶段由ShuffleMapSta
- 【Spark系列1】Spark作业执行原理
周润发的弟弟
从零开始搞大数据servlet
本文字数在7800字左右,预计时间在15分钟一、整体流程每个Aciton操作会创建一个JOB,JOB会提交给DAGScheduler,DAGScheduler根据RDD依赖的关系划分为多个Stage,每个Stage又会创建多个TaskSet,每个TaskSet包含多个Task,这个Task就是每个分区的并行计算的任务。DAGScheduler将TaskSet按照顺序提交给TaskScheduler
- Spark学习笔记五:Spark资源调度和任务调度
开发者连小超
一、StageSpark任务会根据RDD之间的依赖关系,形成一个DAG有向无环图,DAG会提交给DAGScheduler,DAGScheduler会把DAG划分相互依赖的多个stage,划分stage的依据就是RDD之间的宽窄依赖。遇到宽依赖就划分stage,每个stage包含一个或多个task任务。然后将这些task以taskSet的形式提交给TaskScheduler运行。stage切割规则切
- Locust参数化之queue实战
$团长$
python开发语言
需求:用4000用户随机登录调用接口性能压测思路1、随机取用户函数2、将随机取用户函数放到队列中3、使用的时候从队列依次取出fromlocustimportHttpUser,task,between,TaskSetfromgevent._semaphoreimportSemaphoreimportqueuefromcloudDataFactory.publicCenter.excle_dataim
- (转)Spark Streaming遇到问题分析
达微
parkStreaming遇到问题分析1、Spark2.0之后搞了个StructuredStreaming还没仔细了解,可参考:https://github.com/lw-lin/Coo...2、Spark的Job与Streaming的Job有区别及StreamingJob并发控制:先看看SparkStreaming的JobSet,Job,与SparkCore的Job,Stage,TaskSet,
- 深入理解 Spark(二)SparkApplication 提交和运行源码分析
我很ruo
大数据服务器servlet运维
spark核心流程yarn-clientyarn-clusterspark任务调度sparkstage级别调度sparktask级别调度失败重试和白名单对于运行失败的Task,TaskSetManager会记录它失败的次数,如果失败次数还没有超过最大重试次数,那么就把它放回待调度的Task池子中等待重新执行,当重试次数过允许的最大次数,整个Application失败。在记录Task失败次数过程中,
- RDD算子——概念及部分操作
我像影子一样
Spark大数据spark大数据
RDD的算子分类特点Spark中所有的Transformations是Lazy(惰性)的,它们不会立即执行获得结果,相反,它们只会记录在数据集上要应用的操作.只有当需要返回结果给Driver时,才会执行这些操作,通过DAGScheduler和TaskScheduler分发到集群中运行,这个特性叫做惰性求值默认情况下,每一个Action运行的时候,其所关联的所有TransformationRDD都会
- 【linux C】绑定任务到特定CPU(CPU亲和性)
tyrocjl
#linuxCcpu亲和性linuxC语言cpu_set_tCPU_SET
绑定任务到特定CPU(CPU亲和性)1相关概念及工具1.1CPU亲和性1.2查看cpu有几个核1.2.1命令查看1.2.2代码查看1.3taskset命令2代码讲解2.1cpu集(cpu_set_t)2.1.1cpu_set_t的使用2.1.1.1非动态分配cpu_set_t2.1.1.2动态分配cpu_set_t2.1.2glibc源码粗讲解(无兴趣可跳过)2.2绑定任务到指定CPU2.2.1s
- Spark源码分析之:Shuffle
你说个der
Sparkspark大数据
这一篇我们来分析Spark2.1的Shuffle流程。其实ShuffleDependency从SparkContext初始化就已经被DAGScheduler划分好了,本文主要探讨在Task运行过程中的ShufleWrite和ShuffleRead。要从Task运行开始说起,就要知道Task在哪里运行的。我们普遍认为Executor是负责执行Task的,但是我们发现Executor其实就是一个类pr
- 【大数据面试知识点】Spark的DAGScheduler
话数Science
大数据SparkSpark精讲spark大数据面试
Spark数据本地化是在哪个阶段计算首选位置的?先看一下DAGScheduler的注释,可以看到DAGScheduler除了Stage和Task的划分外,还做了缓存的跟踪和首选运行位置的计算。DAGScheduler注释:Thehigh-levelschedulinglayerthatimplementsstage-orientedscheduling.ItcomputesaDAGofstages
- locust 分布式大全
御剑天涯
locust提高篇pythonlocust分布式性能分布式性能测试locust
准备测脚本locustfile.pyfromlocustimportTaskSet,HttpUserlocust_data={'environment':'http://127.0.0.1:8000','task_name':'压测一号','task':[{'path':'/test1/books/read_book/','method':'GET','task':'1','header':{},
- Hadoop集群找不到native-hadoop
tuoluzhe8521
Hadoophadoop大数据分布式
1.问题描述========hive运行中的问题,需要把把native复制进去/usr/lib2023-02-1519:59:42,165WARNscheduler.TaskSetManager:Losttask11.0instage1.0(TID3,common4,executor2):java.lang.RuntimeException:HiveRuntimeErrorwhileclosing
- 为什么Spark比MapReduce快?
tracy_668
MapReduce慢是因为模型很呆板,频繁的Io操作Spark快的话不仅是因为它是内存迭代计算吧?具体什么是内存迭代计算?Answer1Spark计算比MapReduce快的根本原因在于DAG计算模型。一般而言,DAG相比Hadoop的MapReduce在大多数情况下可以减少shuffle次数(怎么体现?)。Spark的DAGScheduler相当于一个改进版的MapReduce,如果计算不涉及与
- cpu亲和力总结taskset和setcpu及其他相关
ttyttytty12
c开发工具使用技巧linux
一:taskset--获取或指定进程运行的CPU.mantaskset出现CPUaffinityisaschedulerpropertythat"bonds"aprocesstoagivensetofCPUsonthesystem.TheLinuxschedulerwillhonorthegivenCPUaffinityandtheprocesswillnotrunonanyotherCPUs.N
- 从零开始学Spark系列(1)——Spark概览
xiaoziHZP
Sparkspark大数据
目录1.Spark简介2.Spark的相关术语2.1master和worker节点2.2Application2.3driver和executor进程2.4ClusterManager2.5Task2.6Job2.7Stage2.8DAGScheduler2.9TASKScheduler3.运行原理4.任务提交4.1使用sparksubmit启动应用程序4.1.1参数详解4.2使用sparkLau
- spark在standalone模式下提交任务流程
程序媛啊
1、application(自己编写的应用程序),拷贝到用来提交spark应用的机器上,用spark-summit来提交这个application,在standalone模式下,会在本机客户端直接启动一个driver进程。2、在driver里面首先干的第一件事就是构造sparkcontext,构造的时候会初始化DAGScheduler和TaskScheduler,构造完TaskScheduler后
- spark源码:SparkContext初始化需要启动的组件
weixin_38842855
spark
spark源码分析之SparkContext1.SparkContext简介2初始化SparkContext需要启动的组件2.0SparkContext私有的可变成员变量2.1SpaekEnv2.2LiveListenerBus2.3SparkUI2.4SparkStatusTracker2.5ConsoleProgressBar2.6DAGScheduler2.7TaskScheduler2.8
- Spark核心机制总结
Icedzzz
Spark大数据spark
文章目录1.RDD2.与MapReduce对比3.Spark的各大组件4.Spark执行流程5.执行过程中的一些细节6.Spark的部署模式和作业提交部署模式Spark的作业提交7.宽窄依赖DAGScheduler的stage划分算法7.Shuffle(1)ShuffleWrite详解(2)ShuffleRead详解(3)reduceByKey和groupByKey的区别?(4)与HadoopMa
- 多线程编程之join()方法
周凡杨
javaJOIN多线程编程线程
现实生活中,有些工作是需要团队中成员依次完成的,这就涉及到了一个顺序问题。现在有T1、T2、T3三个工人,如何保证T2在T1执行完后执行,T3在T2执行完后执行?问题分析:首先问题中有三个实体,T1、T2、T3, 因为是多线程编程,所以都要设计成线程类。关键是怎么保证线程能依次执行完呢?
Java实现过程如下:
public class T1 implements Runnabl
- java中switch的使用
bingyingao
javaenumbreakcontinue
java中的switch仅支持case条件仅支持int、enum两种类型。
用enum的时候,不能直接写下列形式。
switch (timeType) {
case ProdtransTimeTypeEnum.DAILY:
break;
default:
br
- hive having count 不能去重
daizj
hive去重having count计数
hive在使用having count()是,不支持去重计数
hive (default)> select imei from t_test_phonenum where ds=20150701 group by imei having count(distinct phone_num)>1 limit 10;
FAILED: SemanticExcep
- WebSphere对JSP的缓存
周凡杨
WAS JSP 缓存
对于线网上的工程,更新JSP到WebSphere后,有时会出现修改的jsp没有起作用,特别是改变了某jsp的样式后,在页面中没看到效果,这主要就是由于websphere中缓存的缘故,这就要清除WebSphere中jsp缓存。要清除WebSphere中JSP的缓存,就要找到WAS安装后的根目录。
现服务
- 设计模式总结
朱辉辉33
java设计模式
1.工厂模式
1.1 工厂方法模式 (由一个工厂类管理构造方法)
1.1.1普通工厂模式(一个工厂类中只有一个方法)
1.1.2多工厂模式(一个工厂类中有多个方法)
1.1.3静态工厂模式(将工厂类中的方法变成静态方法)
&n
- 实例:供应商管理报表需求调研报告
老A不折腾
finereport报表系统报表软件信息化选型
引言
随着企业集团的生产规模扩张,为支撑全球供应链管理,对于供应商的管理和采购过程的监控已经不局限于简单的交付以及价格的管理,目前采购及供应商管理各个环节的操作分别在不同的系统下进行,而各个数据源都独立存在,无法提供统一的数据支持;因此,为了实现对于数据分析以提供采购决策,建立报表体系成为必须。 业务目标
1、通过报表为采购决策提供数据分析与支撑
2、对供应商进行综合评估以及管理,合理管理和
- mysql
林鹤霄
转载源:http://blog.sina.com.cn/s/blog_4f925fc30100rx5l.html
mysql -uroot -p
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
[root@centos var]# service mysql
- Linux下多线程堆栈查看工具(pstree、ps、pstack)
aigo
linux
原文:http://blog.csdn.net/yfkiss/article/details/6729364
1. pstree
pstree以树结构显示进程$ pstree -p work | grep adsshd(22669)---bash(22670)---ad_preprocess(4551)-+-{ad_preprocess}(4552) &n
- html input与textarea 值改变事件
alxw4616
JavaScript
// 文本输入框(input) 文本域(textarea)值改变事件
// onpropertychange(IE) oninput(w3c)
$('input,textarea').on('propertychange input', function(event) {
console.log($(this).val())
});
- String类的基本用法
百合不是茶
String
字符串的用法;
// 根据字节数组创建字符串
byte[] by = { 'a', 'b', 'c', 'd' };
String newByteString = new String(by);
1,length() 获取字符串的长度
&nbs
- JDK1.5 Semaphore实例
bijian1013
javathreadjava多线程Semaphore
Semaphore类
一个计数信号量。从概念上讲,信号量维护了一个许可集合。如有必要,在许可可用前会阻塞每一个 acquire(),然后再获取该许可。每个 release() 添加一个许可,从而可能释放一个正在阻塞的获取者。但是,不使用实际的许可对象,Semaphore 只对可用许可的号码进行计数,并采取相应的行动。
S
- 使用GZip来压缩传输量
bijian1013
javaGZip
启动GZip压缩要用到一个开源的Filter:PJL Compressing Filter。这个Filter自1.5.0开始该工程开始构建于JDK5.0,因此在JDK1.4环境下只能使用1.4.6。
PJL Compressi
- 【Java范型三】Java范型详解之范型类型通配符
bit1129
java
定义如下一个简单的范型类,
package com.tom.lang.generics;
public class Generics<T> {
private T value;
public Generics(T value) {
this.value = value;
}
}
- 【Hadoop十二】HDFS常用命令
bit1129
hadoop
1. 修改日志文件查看器
hdfs oev -i edits_0000000000000000081-0000000000000000089 -o edits.xml
cat edits.xml
修改日志文件转储为xml格式的edits.xml文件,其中每条RECORD就是一个操作事务日志
2. fsimage查看HDFS中的块信息等
&nb
- 怎样区别nginx中rewrite时break和last
ronin47
在使用nginx配置rewrite中经常会遇到有的地方用last并不能工作,换成break就可以,其中的原理是对于根目录的理解有所区别,按我的测试结果大致是这样的。
location /
{
proxy_pass http://test;
- java-21.中兴面试题 输入两个整数 n 和 m ,从数列 1 , 2 , 3.......n 中随意取几个数 , 使其和等于 m
bylijinnan
java
import java.util.ArrayList;
import java.util.List;
import java.util.Stack;
public class CombinationToSum {
/*
第21 题
2010 年中兴面试题
编程求解:
输入两个整数 n 和 m ,从数列 1 , 2 , 3.......n 中随意取几个数 ,
使其和等
- eclipse svn 帐号密码修改问题
开窍的石头
eclipseSVNsvn帐号密码修改
问题描述:
Eclipse的SVN插件Subclipse做得很好,在svn操作方面提供了很强大丰富的功能。但到目前为止,该插件对svn用户的概念极为淡薄,不但不能方便地切换用户,而且一旦用户的帐号、密码保存之后,就无法再变更了。
解决思路:
删除subclipse记录的帐号、密码信息,重新输入
- [电子商务]传统商务活动与互联网的结合
comsci
电子商务
某一个传统名牌产品,过去销售的地点就在某些特定的地区和阶层,现在进入互联网之后,用户的数量群突然扩大了无数倍,但是,这种产品潜在的劣势也被放大了无数倍,这种销售利润与经营风险同步放大的效应,在最近几年将会频繁出现。。。。
如何避免销售量和利润率增加的
- java 解析 properties-使用 Properties-可以指定配置文件路径
cuityang
javaproperties
#mq
xdr.mq.url=tcp://192.168.100.15:61618;
import java.io.IOException;
import java.util.Properties;
public class Test {
String conf = "log4j.properties";
private static final
- Java核心问题集锦
darrenzhu
java基础核心难点
注意,这里的参考文章基本来自Effective Java和jdk源码
1)ConcurrentModificationException
当你用for each遍历一个list时,如果你在循环主体代码中修改list中的元素,将会得到这个Exception,解决的办法是:
1)用listIterator, 它支持在遍历的过程中修改元素,
2)不用listIterator, new一个
- 1分钟学会Markdown语法
dcj3sjt126com
markdown
markdown 简明语法 基本符号
*,-,+ 3个符号效果都一样,这3个符号被称为 Markdown符号
空白行表示另起一个段落
`是表示inline代码,tab是用来标记 代码段,分别对应html的code,pre标签
换行
单一段落( <p>) 用一个空白行
连续两个空格 会变成一个 <br>
连续3个符号,然后是空行
- Gson使用二(GsonBuilder)
eksliang
jsongsonGsonBuilder
转载请出自出处:http://eksliang.iteye.com/blog/2175473 一.概述
GsonBuilder用来定制java跟json之间的转换格式
二.基本使用
实体测试类:
温馨提示:默认情况下@Expose注解是不起作用的,除非你用GsonBuilder创建Gson的时候调用了GsonBuilder.excludeField
- 报ClassNotFoundException: Didn't find class "...Activity" on path: DexPathList
gundumw100
android
有一个工程,本来运行是正常的,我想把它移植到另一台PC上,结果报:
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.mobovip.bgr/com.mobovip.bgr.MainActivity}: java.lang.ClassNotFoundException: Didn't f
- JavaWeb之JSP指令
ihuning
javaweb
要点
JSP指令简介
page指令
include指令
JSP指令简介
JSP指令(directive)是为JSP引擎而设计的,它们并不直接产生任何可见输出,而只是告诉引擎如何处理JSP页面中的其余部分。
JSP指令的基本语法格式:
<%@ 指令 属性名="
- mac上编译FFmpeg跑ios
啸笑天
ffmpeg
1、下载文件:https://github.com/libav/gas-preprocessor, 复制gas-preprocessor.pl到/usr/local/bin/下, 修改文件权限:chmod 777 /usr/local/bin/gas-preprocessor.pl
2、安装yasm-1.2.0
curl http://www.tortall.net/projects/yasm
- sql mysql oracle中字符串连接
macroli
oraclesqlmysqlSQL Server
有的时候,我们有需要将由不同栏位获得的资料串连在一起。每一种资料库都有提供方法来达到这个目的:
MySQL: CONCAT()
Oracle: CONCAT(), ||
SQL Server: +
CONCAT() 的语法如下:
Mysql 中 CONCAT(字串1, 字串2, 字串3, ...): 将字串1、字串2、字串3,等字串连在一起。
请注意,Oracle的CON
- Git fatal: unab SSL certificate problem: unable to get local issuer ce rtificate
qiaolevip
学习永无止境每天进步一点点git纵观千象
// 报错如下:
$ git pull origin master
fatal: unable to access 'https://git.xxx.com/': SSL certificate problem: unable to get local issuer ce
rtificate
// 原因:
由于git最新版默认使用ssl安全验证,但是我们是使用的git未设
- windows命令行设置wifi
surfingll
windowswifi笔记本wifi
还没有讨厌无线wifi的无尽广告么,还在耐心等待它慢慢启动么
教你命令行设置 笔记本电脑wifi:
1、开启wifi命令
netsh wlan set hostednetwork mode=allow ssid=surf8 key=bb123456
netsh wlan start hostednetwork
pause
其中pause是等待输入,可以去掉
2、
- Linux(Ubuntu)下安装sysv-rc-conf
wmlJava
linuxubuntusysv-rc-conf
安装:sudo apt-get install sysv-rc-conf 使用:sudo sysv-rc-conf
操作界面十分简洁,你可以用鼠标点击,也可以用键盘方向键定位,用空格键选择,用Ctrl+N翻下一页,用Ctrl+P翻上一页,用Q退出。
背景知识
sysv-rc-conf是一个强大的服务管理程序,群众的意见是sysv-rc-conf比chkconf
- svn切换环境,重发布应用多了javaee标签前缀
zengshaotao
javaee
更换了开发环境,从杭州,改变到了上海。svn的地址肯定要切换的,切换之前需要将原svn自带的.svn文件信息删除,可手动删除,也可通过废弃原来的svn位置提示删除.svn时删除。
然后就是按照最新的svn地址和规范建立相关的目录信息,再将原来的纯代码信息上传到新的环境。然后再重新检出,这样每次修改后就可以看到哪些文件被修改过,这对于增量发布的规范特别有用。
检出