この問題は、生産段階、開発段階でのみ発生します - 魅力のように機能します。
ユーザーがヘルパー経由で生成されたリンクからファイルをダウンロードしようとすると:
<a href="{{fileRef.url download=true}}">Download</a>
サーバー側で node.js が失敗し、forever
再起動すると、次のエラーが表示されます。
Error: write after end
at ServerResponse.OutgoingMessage.write (_http_outgoing.js:413:15)
at ServerResponse.http.OutgoingMessage.write (packages/meteorhacks:inject-data/lib/server.js:56:1)
at ServerResponse.res.write (/var/node/bundle/programs/server/npm/webapp/node_modules/connect/lib/middleware/compress.js:110:17)
at ServerResponse.res.end (/var/node/bundle/programs/server/npm/webapp/node_modules/connect/lib/middleware/compress.js:116:14)
at sendResponseIfDone (packages/cfs:http-methods/http.methods.server.api.js:543:1)
at IncomingMessage.<anonymous> (packages/cfs:http-methods/http.methods.server.api.js:568:1)
at IncomingMessage.emit (events.js:104:17)
at _stream_readable.js:908:16
at process._tickCallback (node.js:355:11)
error: Forever detected script exited with code: 1
error: Script restart attempt #1
クライアントでは、ファイルは部分的にしかダウンロードされなかったと思います-最初のチャンクのみ。nginx リバース プロキシ キャッシング、バッファ設定を変更しようとしましたが、オフにしてもまったく役に立ちません。
修正方法、またはエラーを探す場所はありますか? どんな助けでも大歓迎です。
コレクション初期化コード:
path = (if (NODE_ENV is "development") then "/uploads/Addresses" else "/builded/bundle/programs/server/assets/app/uploads/Addresses")
Collections.Addresses = new FS.Collection 'Addresses',
stores: [
new FS.Store.FileSystem 'Addresses' ,
path: path
]
,
filter:
allow:
extensions: ['xls', 'xlsx']
if Meteor.isServer
Meteor.startup ->
Collections.Addresses.allow
insert: (userId) ->
return checkFunc userId
remove: (userId) ->
return checkFunc userId
update: (userId) ->
return checkFunc userId
download: (userId) ->
return checkFunc userId
Meteor.publish 'Addresses', (ProjectID) ->
check ProjectID, Mongo.ObjectID
if checkFunc this.userId
Collections.Addresses.find
'metadata.project_id': ProjectID
else
throw new Meteor.Error 403, 'Permission denied'