fix: destroy后仍有push流

This commit is contained in:
archer
2023-03-24 14:35:33 +08:00
parent 6ce727f9ea
commit 30678d8ebf
2 changed files with 4 additions and 9 deletions

View File

@@ -121,7 +121,7 @@ export default async function handler(req: NextApiRequest, res: NextApiResponse)
if (!content) return;
responseContent += content;
// console.log('content:', content)
stream.push(content.replace(/\n/g, '<br/>'));
!stream.destroyed && stream.push(content.replace(/\n/g, '<br/>'));
} catch (error) {
error;
}
@@ -140,7 +140,8 @@ export default async function handler(req: NextApiRequest, res: NextApiResponse)
} catch (error) {
console.log('pipe error', error);
}
stream.push(null);
// close stream
stream.destroy();
const promptsLen = formatPrompts.reduce((sum, item) => sum + item.content.length, 0);
console.log(`responseLen: ${responseContent.length}`, `promptLen: ${promptsLen}`);
@@ -154,8 +155,8 @@ export default async function handler(req: NextApiRequest, res: NextApiResponse)
});
} catch (err: any) {
if (step === 1) {
console.log('error结束');
// 直接结束流
console.log('error结束');
stream.destroy();
} else {
res.status(500);

View File

@@ -14,15 +14,9 @@ export const pushBill = async ({
}) => {
await connectToDatabase();
const modelItem = modelList.find((item) => item.model === modelName);
if (!modelItem) return;
let billId;
try {
await connectToDatabase();
const modelItem = modelList.find((item) => item.model === modelName);
if (!modelItem) return;