Understanding on 'Error to Origin (50x)' , 'Internal CDN Error (50x)' and 'External Error (50x)' in Chartron
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.
- If a real 202 response come from origin, perhit log
- Definition : The hits per seconds of response 202.
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
| 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 When the requested cache object does not exist and the site is dead, if |
| 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的更多相关文章
- 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" ...
- idea报错:error java compilation failed internal java compiler error
idea下面报如下问题 error java compilation failed internal java compiler error 解决办法:Setting->Compiler-> ...
- idea Error:java: Compilation failed: internal java compiler error
idea 遇到Error:java: Compilation failed: internal java compiler error 是提示说你当前使用的编译器jdk版本不对. 按住Ctrl+Alt ...
- 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 ...
- Error:java:Compilation failed: internal java compiler error
在IDEA中编译时出现这个错误:Error:java:Compilation failed: internal java compiler error! Information:Using javac ...
- 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 ...
- 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 ...
- 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 ...
- 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 ...
随机推荐
- 从零开始的全栈工程师——js篇2.2
条件语句 补充: var a=“hello world” a这个变量是字符串了 对于里面每一个字母来说 他是字节 里面有11个字节 字节总数用length表示 如下: 根据上面的内容咱们又发现了一个运 ...
- vue $set用法
需求,想给下面的数据添加一个hoby属性 {{data.hoby}}-->让这里的视图改变 data:{ name: "简书", age: '3', info: { cont ...
- 【Shell脚本学习25】Shell文件包含
像其他语言一样,Shell 也可以包含外部脚本,将外部脚本的内容合并到当前脚本. Shell 中包含脚本可以使用: . filename 或 source filename 两种方式的效果相同,简单起 ...
- 百倍性能的PL/SQL优化案例(r11笔记第13天)
我相信你是被百倍性能的字样吸引了,不过我所想侧重的是优化的思路,这个比优化技巧更重要,而结果嘛,其实我不希望说成是百倍提升,“”自黑“”一下. 有一个真实想法和大家讨论一下,就是一个SQL语句如果原本 ...
- LeetCode Unique Binary Search Trees (DP)
题意: 一棵BST有n个节点,每个节点的key刚好为1-n.问此树有多少种不同形态? 思路: 提示是动态规划. 考虑一颗有n个节点的BST和有n-1个节点的BST.从n-1到n只是增加了一个点n,那么 ...
- 项目移动后报error LNK1123
VS20101.解决方案窗口 项目|项目属性|配置属性|清单工具|输入和输出|嵌入清单 “是”改为“否”:2.项目|项目属性|配置属性|连接器|清单文件|嵌入清单 “是”改为“否”:3.对于64位的操 ...
- Dll注入:x86/X64 SetThreadContext 注入
在<Windows核心编程>第七章说到了线程优先级等知识,其中谈到了ThreadContext线程上下背景文. 其中介绍了GetThreadContext函数来查看线程内核对象的内部,并获 ...
- OpenCV之CvMat、Mat、IplImage之间相互转换实例(转)
OpenCV学习之CvMat的用法详解及实例 CvMat是OpenCV比较基础的函数.初学者应该掌握并熟练应用.但是我认为计算机专业学习的方法是,不断的总结并且提炼,同时还要做大量的实践,如编码,才能 ...
- hdu-1272 小希的迷宫---并查集或者DFS
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1272 题目大意: Problem Description 上次Gardon的迷宫城堡小希玩了很久(见 ...
- 【洛谷5113】Sabbat of the witch(毒瘤分块)
点此看题面 大致题意: 给你一个序列,要你支持三种操作:区间赋值,区间求和,撤回之前任一区间赋值操作. 分块 这道题应该是一道十分毒瘤的分块题. 这道题要用到的算法并不是很难,但是思维难度是真的高. ...