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. docker使用alpine系统构建tomcat镜像

    FROM frolvlad/alpine-oraclejdk8 #此镜像使用alpine-glibc系统,精简jdk,只运行java程序,无法编译/构建 MAINTAINER huqiang:2018 ...

  2. cms-帖子静态化

    实现帖子静态化和实现友情链接静态化一致, 1.首先建立帖子类别的实体类: package com.open1111.entity; /** * 帖子类别实体 * @author user * */pu ...

  3. IDA逆向:结构体的逆向

    源代码: int _tmain(int argc, _TCHAR* argv[]) { struct v1 { int a; short b; char c; int d; double e; }; ...

  4. leetcode--5 Longest Palindromic Substring

    1. 题目: Given a string S, find the longest palindromic substring in S. You may assume that the maximu ...

  5. netcat 详解

    简介 netcat 是一款调试 TCP/UDP 网络连接的利器,常被称作网络调试的瑞士军刀,可见其功能强大. netcat 在 Linux, Windows 等各大操作系统上都有对应等发行版,以下以 ...

  6. POJ 2104 K-th Number(分桶,线段树,主席树)

    一道比较经典的数据结构题.可以用多种方式来做. 一,分桶法(平方分解). 根据数字x的大小和区间内不大于x的数字数量cnt的单调性,可知第k大数kth对应的cnt应该满足cnt≥k, 且kth是满足条 ...

  7. 深入理解计算机系统_3e 第二章家庭作业 CS:APP3e chapter 2 homework

    初始完成日期:2017.9.26 许可:除2.55对应代码外(如需使用请联系 randy.bryant@cs.cmu.edu),任何人可以自由的使用,修改,分发本文档的代码. 本机环境: (有一些需要 ...

  8. React后台管理系统-商品管理列表组件

    1.商品列表页面结构 <div id="page-wrapper">              <PageTitle title="商品列表" ...

  9. 自封装的AJAX

    /* * *create by royal in 2019/1/23 * *royalAjax 自封装ajax函数 * *paramsObj JSON类型参数 *require params: * t ...

  10. js控制时间显示格式

    Date.prototype.Format = function (fmt) { //author: meizz     var o = {        "M+": this.g ...