mirror of
https://gitee.com/huangge1199_admin/vue-pro.git
synced 2025-01-19 03:30:06 +08:00
【优化】dall 绘画,改为异步。
This commit is contained in:
parent
63a8cc244d
commit
e97408b3ac
@ -35,6 +35,9 @@ import org.springframework.transaction.annotation.Transactional;
|
|||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.concurrent.LinkedBlockingQueue;
|
||||||
|
import java.util.concurrent.ThreadPoolExecutor;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ai 作图
|
* ai 作图
|
||||||
@ -53,6 +56,8 @@ public class AiImageServiceImpl implements AiImageService {
|
|||||||
private final OpenAiImageClient openAiImageClient;
|
private final OpenAiImageClient openAiImageClient;
|
||||||
private final MidjourneyWebSocketStarter midjourneyWebSocketStarter;
|
private final MidjourneyWebSocketStarter midjourneyWebSocketStarter;
|
||||||
private final MidjourneyInteractionsApi midjourneyInteractionsApi;
|
private final MidjourneyInteractionsApi midjourneyInteractionsApi;
|
||||||
|
private static ThreadPoolExecutor EXECUTOR = new ThreadPoolExecutor(
|
||||||
|
3, 5, 1, TimeUnit.HOURS, new LinkedBlockingQueue<>(32));
|
||||||
|
|
||||||
@PostConstruct
|
@PostConstruct
|
||||||
public void startMidjourney() {
|
public void startMidjourney() {
|
||||||
@ -89,10 +94,18 @@ public class AiImageServiceImpl implements AiImageService {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public AiImageDallRespVO dallDrawing(AiImageDallReqVO req) {
|
public AiImageDallRespVO dallDrawing(AiImageDallReqVO req) {
|
||||||
|
// 保存数据库
|
||||||
|
AiImageDO aiImageDO = doSave(req.getPrompt(), req.getSize(), req.getModel(),
|
||||||
|
null, null, AiImageStatusEnum.IN_PROGRESS, null,
|
||||||
|
null, null, null);
|
||||||
|
// 异步执行
|
||||||
|
EXECUTOR.execute(() -> {
|
||||||
|
try {
|
||||||
|
|
||||||
// 获取 model
|
// 获取 model
|
||||||
OpenAiImageModelEnum openAiImageModelEnum = OpenAiImageModelEnum.valueOfModel(req.getModel());
|
OpenAiImageModelEnum openAiImageModelEnum = OpenAiImageModelEnum.valueOfModel(req.getModel());
|
||||||
OpenAiImageStyleEnum openAiImageStyleEnum = OpenAiImageStyleEnum.valueOfStyle(req.getStyle());
|
OpenAiImageStyleEnum openAiImageStyleEnum = OpenAiImageStyleEnum.valueOfStyle(req.getStyle());
|
||||||
try {
|
|
||||||
// 转换openai 参数
|
// 转换openai 参数
|
||||||
OpenAiImageOptions openAiImageOptions = new OpenAiImageOptions();
|
OpenAiImageOptions openAiImageOptions = new OpenAiImageOptions();
|
||||||
openAiImageOptions.setModel(openAiImageModelEnum.getModel());
|
openAiImageOptions.setModel(openAiImageModelEnum.getModel());
|
||||||
@ -103,20 +116,26 @@ public class AiImageServiceImpl implements AiImageService {
|
|||||||
ImageGeneration imageGeneration = imageResponse.getResult();
|
ImageGeneration imageGeneration = imageResponse.getResult();
|
||||||
// 图片保存到服务器
|
// 图片保存到服务器
|
||||||
String filePath = fileApi.createFile(HttpUtil.downloadBytes(imageGeneration.getOutput().getUrl()));
|
String filePath = fileApi.createFile(HttpUtil.downloadBytes(imageGeneration.getOutput().getUrl()));
|
||||||
// 保存数据库
|
// 更新数据库
|
||||||
AiImageDO aiImageDO = doSave(req.getPrompt(), req.getSize(), req.getModel(),
|
aiImageMapper.updateById(
|
||||||
filePath, imageGeneration.getOutput().getUrl(), AiImageStatusEnum.COMPLETE, null,
|
new AiImageDO()
|
||||||
null, null, null);
|
.setId(aiImageDO.getId())
|
||||||
|
.setStatus(AiImageStatusEnum.COMPLETE.getStatus())
|
||||||
|
.setPicUrl(filePath)
|
||||||
|
.setOriginalPicUrl(imageGeneration.getOutput().getUrl())
|
||||||
|
);
|
||||||
|
} catch (AiException aiException) {
|
||||||
|
// 更新错误信息
|
||||||
|
aiImageMapper.updateById(
|
||||||
|
new AiImageDO()
|
||||||
|
.setId(aiImageDO.getId())
|
||||||
|
.setStatus(AiImageStatusEnum.FAIL.getStatus())
|
||||||
|
.setErrorMessage(aiException.getMessage())
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
// 转换 AiImageDallDrawingRespVO
|
// 转换 AiImageDallDrawingRespVO
|
||||||
return AiImageConvert.INSTANCE.convertAiImageDallDrawingRespVO(aiImageDO);
|
return AiImageConvert.INSTANCE.convertAiImageDallDrawingRespVO(aiImageDO);
|
||||||
} catch (AiException aiException) {
|
|
||||||
// 保存数据库
|
|
||||||
AiImageDO aiImageDO = doSave(req.getPrompt(), req.getSize(), req.getModel(),
|
|
||||||
null, null, AiImageStatusEnum.FAIL, aiException.getMessage(),
|
|
||||||
null, null, null);
|
|
||||||
// 发送错误信息
|
|
||||||
return AiImageConvert.INSTANCE.convertAiImageDallDrawingRespVO(aiImageDO);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Loading…
Reference in New Issue
Block a user