Overview

This document explains about definition of these values on OUI Chartron.

Definition of Error Types

  • Error to Origin (50x) Hits/Sec

    • The hits per seconds of response 504. As RFC2616, "504" means "Gateway Timeout". But CS use this value for logging "Error to Origin".
    • The situation to return response 504 : If PX-503 response header starts with "O ", then log as 504.

  • Internal CDN Error (50x) Hits/Sec
    • Definition : The hits per seconds of response 505. As RFC2616, "505" means "HTTP Version Not Supported". But CS use this value for logging "Internal CDN Error".
    • The situation to return response 505 : If PX-503 response header not starts with "O " , then log as 505.

  • External Error (50x) Hits/Sec
    • Definition : The hits per seconds of response 50x received from origin.
    • If origin returns 504 or 505, CS logs as 503. (i.e. External Error = all of 5xx except 504,505)
  • Internal timeout (202) 
    • Definition : The hits per seconds of response 202.
      The situation that a request has accepted, but internal timeout
      occurs. As RFC2616, "202" means "Accepted". CS use similary this
      meaning.

      • If a real 202 response come from origin, perhit log
        has other reponse headers like "Server" or "Date", etc. But 202 response
        without other headers, the situation is internal timeout.
      • While CS retries to other nodes, CS will disconnect client connection and log as 202. In this case, request client cannot receives any http response code nor headers.

Test environment

  • Edge node : n5 (10.40.196.201)
  • Shield node : n7 (10.40.196.203), n4(10.40.196.204)
  • Origin : 10.40.198.222 (CustomHttpd)
  • Attached file : very_small.mp4 (325117 bytes)
  • Reproduce conditions
    • User -> CS edge
    • CS edge -> master or shield
    • CS shield -> origin

Error Cases by connection state

  • (CS Last level shield - origin)

  • (CS node - CS node)

  • Client - CS edge node

http.log messages

Edit Document

Error type http.log message Description
Error To Origin "read error" When using gzip compression, error occured on reading data to gzip buffer.
Error To Origin "too many downloads" The count of active connection to origin is over limit. (site's max_origin_downloads)
Error To Origin "PAD is marked dead" When
site is not dead, total origin connection per site is over 100 and
origin timeout per site is over 40% of total origin request per site,
the site is marked dead. This check is working every 20 second. And
origin connection counters are also reset every 20 seconds.

When site is dead, total origin connection per site is over 0 and origin
timeout per site is under 20% of total origin request per site, this
condition has been met every 20 seconds 3 times in raw (during 60
seconds), the site is marked undead.

When the requested cache object does not exist and the site is dead, if
num of total upstream is over than 100, CS respond 503 with "Px-503: O
PAD is marked dead".

Error To Origin "preceding upstream connection has not yet finished" When waiting prceding upstream connection at using NTLM feature (v8.2.1~)
Error To Origin "Too many upstream connections, aborting download for $(URL)" Upstream connection is over limit.
Internal CDN Error "file too large (chunked-transfer-encoding on a chunking pad)" (~
v8.0.x) Redirect to origin when data size is larger than 200MB and
use_sub_file is false and use transfer-encoding is chunked.
Internal CDN Error "bad file (disk)" The data from disk is bad.
Internal CDN Error "subfile mismatch" When using sub_file (chunking) , subfile's total content length is mismatched from first chunk's.
Internal CDN Error "short read" When Disk Cache cannot read data in right length from Disk.
Internal CDN Error "Init Task Failed" Various reason for fail MyStack.initStack()
Internal CDN Error "Selecting Master" Exception occurs on selectMaster()
Internal CDN Error "null" UpstreamConnectionHandler.doConnect()
Conditional "unknown host" upstream download fail : UnknownHostException occurred
Conditional "socket timeout" upstream download fail : SocketTimeoutException occurred
Conditional "io exception" upstream download fail : IOException occurred
Conditional "unknown exception" upstream download fail : Exception occurred
Conditional "Host lookup failed for $(host)" upstream download fail : DNS lookup failed
Conditional "Stalled download" + "Killed by connection manager after XXX" Upstream timeout
Conditional "Connect Failed" Upstream connect fail
Conditional "Read buffer filled but cannot parse" Read buffer done, but still cannot parse response header.
Conditional "reading (connection was closed prematurely)" Receiving socket close packet from upstream.
Conditional "reading response: connection was closed prematurely" connection was closed by upstream.
Conditional "The client side connection was already closed!" connection was closed by client.
Conditional "Downstream connection closed while upstream transfer chunked channel setting." Downstream connection closed while upstream transfer chunked channel setting.
Conditional "Connection closed while writing request" upstream connection was closed while writing request to upstream
Conditional "Connection closed while writing request body" upstream connection was closed while writing request body to upstream
Conditional "Connection closed while writing request body(chunked) : XX bytes sent" Error occured on ending stream Transfer-Encoding : chunked
Conditional "Invalid selection key" Java nio selection key is invalid on handling upstream connections.
Conditional "gotMoreContentDataThreaded" Exception occured in UpstreamConnection thread
     
"Conditional"
: When upstream fails, CS retries another upstream server that is
called "failover" logic. Following failover logic, If the last selected
server is origin, Error type decides "Error To Origin", other "Internal
CDN Error"

Understanding on 'Error to Origin (50x)' , 'Internal CDN Error (50x)' and 'External Error (50x)' in Chartron的更多相关文章

  1. angularjs 运行时报错ERROR in node_modules/rxjs/internal/types.d.ts(81,44): error TS1005: ';' expected. node_modules/rxjs/internal/types.d.ts(81,74): error TS1005: ';' expected. node_modules/rxjs/internal/t

    解决方法: 在package.json文件里面 修改 "rxjs": "^6.0.0" 为 "rxjs": "6.0.0" ...

  2. idea报错:error java compilation failed internal java compiler error

    idea下面报如下问题 error java compilation failed internal java compiler error 解决办法:Setting->Compiler-> ...

  3. idea Error:java: Compilation failed: internal java compiler error

    idea 遇到Error:java: Compilation failed: internal java compiler error 是提示说你当前使用的编译器jdk版本不对. 按住Ctrl+Alt ...

  4. com.sun.xml.internal.ws.server.ServerRtException: Server Runtime Error: java.net.BindException: Cannot assign requested address: bind

    在发布 web service 时报错: Endpoint.publish(publishAddress, hl7MessageReveiver); com.sun.xml.internal.ws.s ...

  5. Error:java:Compilation failed: internal java compiler error

    在IDEA中编译时出现这个错误:Error:java:Compilation failed: internal java compiler error! Information:Using javac ...

  6. Git版本控制工具使用:Error pulling origin: error: Your local changes to the following files would be overwritten by merge

    摘自: CSDN 逆觞 git在pull时,出现这种错误的时候,可能很多人进进行stash,相关stash的请看:Error pulling origin: error: Your local cha ...

  7. Error pulling origin: error: The following untracked working tree files would be overwritten by...

    git在pull时,出现这样的错误的时候,可能非常多人进进行stash.相关stash的请看:Error pulling origin: error: Your local changes to th ...

  8. Error pulling origin: error: Your local changes to the following files would be overwritten by merge

    Git在pull时,出现这种错误的时候,可能很多人进进行stash,相关stash的请看:Error pulling origin: error: Your local changes to the ...

  9. Android studio Error:org.gradle.api.internal.tasks.DefaultTaskInputs$TaskInputUnionFileCollection cannot be cast to

    http://blog.csdn.net/FlyRabbit_1/article/details/74536317 Error:org.gradle.api.internal.tasks.Defaul ...

随机推荐

  1. git 使用流程 命令

    克隆远程分支到本地 git clone <https://github.com/cqzyl/methods.js.git> 进入master分支 git checkout master 以 ...

  2. table-列组

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. 微信小程序:从本地相册选择图片或使用相机拍照。

    wx.chooseImage(OBJECT) 从本地相册选择图片或使用相机拍照. OBJECT参数说明: 示例代码: wx.chooseImage({ count: 1, // 默认9 sizeTyp ...

  4. Alembic基本使用

    1.alembic init YOUR_ALEMBIC_DIR 该目录下会有alembic.ini以及YOUR_ALEMBIC_DIR的目录. alembic.ini 提供了一些基本的配置 YOUR_ ...

  5. JAVA 与 sqlite3 连接

    SQLite SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中.它是D.RichardHipp建立的公有领域项目.它的设计目标是嵌入式的,而且目前已经 ...

  6. 【extjs6学习笔记】1.11 初始: config

    Ext JS有一个名为config的功能. 该配置允许您使用默认值声明公共属性,这些属性将被其他类成员完全封装. 通过config声明的属性将自动获取get()和set()方法,如果类没有定义这些方法 ...

  7. MySQL-数据类型及选择

    一.数据类型 详见:http://www.runoob.com/mysql/mysql-data-types.html 二.类型选择 整形>date,time>enum,char>v ...

  8. 阿里 EasyExcel 7 行代码优雅地实现 Excel 文件生成&下载功能

    欢迎关注个人微信公众号: 小哈学Java, 文末分享阿里 P8 资深架构师吐血总结的 <Java 核心知识整理&面试.pdf>资源链接!! 个人网站: https://www.ex ...

  9. hdu-1598 find the most comfortable road---kruskal+枚举下界

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1598 题目大意: XX星有许多城市,城市之间通过一种奇怪的高速公路SARS(Super Air Ro ...

  10. ASP.NET各种技巧

    1.动态添加文件框 前台页面关键部分: <script type="text/javascript"> //添加一个选项 function AddFileCtrol() ...