Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
4cfd8418
提交
4cfd8418
authored
11月 16, 2016
作者:
Jeromy Johnson
提交者:
GitHub
11月 16, 2016
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #2971 from ipfs/feature/gateway-resolve-error
gateway: degrade error in gateway to log to reduce noise
上级
afa1f154
ce96b915
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
24 行增加
和
11 行删除
+24
-11
gateway_handler.go
core/corehttp/gateway_handler.go
+23
-10
gateway_test.go
core/corehttp/gateway_test.go
+1
-1
没有找到文件。
core/corehttp/gateway_handler.go
浏览文件 @
4cfd8418
...
...
@@ -12,12 +12,12 @@ import (
"time"
core
"github.com/ipfs/go-ipfs/core"
coreiface
"github.com/ipfs/go-ipfs/core/coreapi/interface"
"github.com/ipfs/go-ipfs/importer"
chunk
"github.com/ipfs/go-ipfs/importer/chunk"
dag
"github.com/ipfs/go-ipfs/merkledag"
dagutils
"github.com/ipfs/go-ipfs/merkledag/utils"
coreiface
"github.com/ipfs/go-ipfs/core/coreapi/interface"
"github.com/ipfs/go-ipfs/namesys"
path
"github.com/ipfs/go-ipfs/path"
ft
"github.com/ipfs/go-ipfs/unixfs"
...
...
@@ -160,17 +160,29 @@ func (i *gatewayHandler) getOrHeadHandler(ctx context.Context, w http.ResponseWr
dr
,
err
:=
i
.
api
.
Cat
(
ctx
,
urlPath
)
dir
:=
false
if
err
==
coreiface
.
ErrIsDir
{
switch
err
{
case
nil
:
// core.Resolve worked
defer
dr
.
Close
()
case
coreiface
.
ErrIsDir
:
dir
=
true
}
else
if
err
==
coreiface
.
ErrOffline
{
w
.
WriteHeader
(
http
.
StatusServiceUnavailable
)
fmt
.
Fprint
(
w
,
"Could not resolve path. Node is in offline mode."
)
case
namesys
.
ErrResolveFailed
:
// Don't log that error as it is just noise
w
.
WriteHeader
(
http
.
StatusInternalServerError
)
fmt
.
Fprintf
(
w
,
"Path Resolve error: %s"
,
err
.
Error
())
log
.
Info
(
"Path Resolve error: %s"
,
err
.
Error
())
return
}
else
if
err
!=
nil
{
case
coreiface
.
ErrOffline
:
if
!
i
.
node
.
OnlineMode
()
{
w
.
WriteHeader
(
http
.
StatusServiceUnavailable
)
fmt
.
Fprint
(
w
,
"Could not resolve path. Node is in offline mode."
)
return
}
fallthrough
default
:
// all other erros
webError
(
w
,
"Path Resolve error"
,
err
,
http
.
StatusBadRequest
)
return
}
else
{
defer
dr
.
Close
()
}
etag
:=
gopath
.
Base
(
urlPath
)
...
...
@@ -531,7 +543,8 @@ func webError(w http.ResponseWriter, message string, err error, defaultCode int)
func
webErrorWithCode
(
w
http
.
ResponseWriter
,
message
string
,
err
error
,
code
int
)
{
w
.
WriteHeader
(
code
)
log
.
Errorf
(
"%s: %s"
,
message
,
err
)
// TODO(cryptix): log errors until we have a better way to expose these (counter metrics maybe)
log
.
Errorf
(
"%s: %s"
,
message
,
err
)
// TODO(cryptix): log until we have a better way to expose these (counter metrics maybe)
fmt
.
Fprintf
(
w
,
"%s: %s"
,
message
,
err
)
}
...
...
core/corehttp/gateway_test.go
浏览文件 @
4cfd8418
...
...
@@ -136,7 +136,7 @@ func TestGatewayGet(t *testing.T) {
{
"localhost:5001"
,
"/"
,
http
.
StatusNotFound
,
"404 page not found
\n
"
},
{
"localhost:5001"
,
"/"
+
k
,
http
.
StatusNotFound
,
"404 page not found
\n
"
},
{
"localhost:5001"
,
"/ipfs/"
+
k
,
http
.
StatusOK
,
"fnord"
},
{
"localhost:5001"
,
"/ipns/nxdomain.example.com"
,
http
.
Status
BadRequest
,
"Path Resolve error: "
+
namesys
.
ErrResolveFailed
.
Error
()},
{
"localhost:5001"
,
"/ipns/nxdomain.example.com"
,
http
.
Status
InternalServerError
,
"Path Resolve error: "
+
namesys
.
ErrResolveFailed
.
Error
()},
{
"localhost:5001"
,
"/ipns/example.com"
,
http
.
StatusOK
,
"fnord"
},
{
"example.com"
,
"/"
,
http
.
StatusOK
,
"fnord"
},
}
{
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论