mirror of
https://github.com/Dokploy/dokploy.git
synced 2026-06-20 14:45:42 +02:00
- Refactored the deployment worker to create a no-op worker when Redis is disabled (e.g., IS_CLOUD), preventing BullMQ connection errors. - Updated queue initialization to use a no-op queue in cloud environments, ensuring compatibility and stability. - Improved error handling and logging for job processing in the deployment worker.
97 lines
2.8 KiB
TypeScript
97 lines
2.8 KiB
TypeScript
import {
|
|
deployApplication,
|
|
deployCompose,
|
|
deployPreviewApplication,
|
|
IS_CLOUD,
|
|
rebuildApplication,
|
|
rebuildCompose,
|
|
rebuildPreviewApplication,
|
|
updateApplicationStatus,
|
|
updateCompose,
|
|
updatePreviewDeployment,
|
|
} from "@dokploy/server";
|
|
import { type Job, Worker } from "bullmq";
|
|
import type { DeploymentJob } from "./queue-types";
|
|
import { redisConfig } from "./redis-connection";
|
|
|
|
const createDeploymentWorker = () =>
|
|
new Worker(
|
|
"deployments",
|
|
async (job: Job<DeploymentJob>) => {
|
|
try {
|
|
if (job.data.applicationType === "application") {
|
|
await updateApplicationStatus(job.data.applicationId, "running");
|
|
|
|
if (job.data.type === "redeploy") {
|
|
await rebuildApplication({
|
|
applicationId: job.data.applicationId,
|
|
titleLog: job.data.titleLog,
|
|
descriptionLog: job.data.descriptionLog,
|
|
});
|
|
} else if (job.data.type === "deploy") {
|
|
await deployApplication({
|
|
applicationId: job.data.applicationId,
|
|
titleLog: job.data.titleLog,
|
|
descriptionLog: job.data.descriptionLog,
|
|
});
|
|
}
|
|
} else if (job.data.applicationType === "compose") {
|
|
await updateCompose(job.data.composeId, {
|
|
composeStatus: "running",
|
|
});
|
|
if (job.data.type === "deploy") {
|
|
await deployCompose({
|
|
composeId: job.data.composeId,
|
|
titleLog: job.data.titleLog,
|
|
descriptionLog: job.data.descriptionLog,
|
|
});
|
|
} else if (job.data.type === "redeploy") {
|
|
await rebuildCompose({
|
|
composeId: job.data.composeId,
|
|
titleLog: job.data.titleLog,
|
|
descriptionLog: job.data.descriptionLog,
|
|
});
|
|
}
|
|
} else if (job.data.applicationType === "application-preview") {
|
|
await updatePreviewDeployment(job.data.previewDeploymentId, {
|
|
previewStatus: "running",
|
|
});
|
|
|
|
if (job.data.type === "redeploy") {
|
|
await rebuildPreviewApplication({
|
|
applicationId: job.data.applicationId,
|
|
titleLog: job.data.titleLog,
|
|
descriptionLog: job.data.descriptionLog,
|
|
previewDeploymentId: job.data.previewDeploymentId,
|
|
});
|
|
} else if (job.data.type === "deploy") {
|
|
await deployPreviewApplication({
|
|
applicationId: job.data.applicationId,
|
|
titleLog: job.data.titleLog,
|
|
descriptionLog: job.data.descriptionLog,
|
|
previewDeploymentId: job.data.previewDeploymentId,
|
|
});
|
|
}
|
|
}
|
|
} catch (error) {
|
|
console.log("Error", error);
|
|
}
|
|
},
|
|
{
|
|
autorun: false,
|
|
connection: redisConfig,
|
|
},
|
|
);
|
|
|
|
/** No-op worker when Redis is disabled (e.g. IS_CLOUD). Avoids BullMQ connection errors. */
|
|
const noopWorker = {
|
|
run: () => Promise.resolve(),
|
|
close: () => Promise.resolve(),
|
|
cancelJob: () => Promise.resolve(),
|
|
cancelAllJobs: () => Promise.resolve(),
|
|
};
|
|
|
|
export const deploymentWorker = !IS_CLOUD
|
|
? createDeploymentWorker()
|
|
: (noopWorker as unknown as Worker<DeploymentJob>);
|