In my Astro site one of the routes is routing to localhost

Hello. I am trying to move my Astro site from Vercel, where it is currently working without problems (except for some bug in the Vercel integration that makes impossible to build static pages) to railway. I created a docker image and managed to make it build properly. The site is deployed and available, but for some weird reason one of the routes that points to a static path is redirecting me to localhost. When I click the link first I see a white screen saying that I will be redirected to localhost, and them I am redirected to localhost. Any idea why? Is this something Railway load balancer does?
42 Replies
Percy
Percy9mo ago
Project ID: c2147d2a-2ed6-4234-b48a-50d16f81e68c
danielo515
danielo5159mo ago
c2147d2a-2ed6-4234-b48a-50d16f81e68c
maddsua
maddsua9mo ago
Hey! Mind sharing a link? It doesn't look like something that neither Astro or Railway usually do
danielo515
danielo5159mo ago
Boda de Ali y Dani
Boda de Alicia y danielo
danielo515
danielo5159mo ago
By the way, I fixed the redirect by providing the public url of the site to Astro, so at least it now redirects to the right place When testing this inside docker in my local machine accessing that url makes the server crash, which is why I assume the redirect happens
Brody
Brody9mo ago
vercel will automatically intercept redirects to localhost and change them to redirect to the public address, railway will not do anything of the sort, when running on railway your code must send the correct redirect response
danielo515
danielo5159mo ago
The app does not crash on Vercel, and no redirect happens, the right route is displayed On railway there are no logs when I hit that route wich make me suspect the app crashes, and as I mentioned in docker in my local machine it crash Tried different versions of docker node and all crash the same way Running as a node server (no docker) everything works fine
Brody
Brody9mo ago
let's see your dockerfile
danielo515
danielo5159mo ago
FROM node:18-slim AS base
ENV PNPM_HOME="/pnpm"
ENV PATH="$PNPM_HOME:$PATH"
RUN corepack enable
COPY . /app
COPY astro.node.config.ts /app/astro.config.ts
WORKDIR /app

FROM base AS prod-deps
RUN --mount=type=cache,id=s/0cdba51f-ca18-4991-b228-f30672040b04-pnpm,target=/pnpm/store pnpm install --prod --frozen-lockfile

FROM base AS build
ARG POSTGRES_URL
ARG SITE_URL
RUN --mount=type=cache,id=s/0cdba51f-ca18-4991-b228-f30672040b04-pnpm,target=/pnpm/store pnpm install --frozen-lockfile
RUN pnpm run build

FROM base
COPY --from=prod-deps /app/node_modules /app/node_modules
COPY --from=build /app/dist /app/dist

ENV HOST=0.0.0.0
ENV PORT=4321
EXPOSE 4321
CMD node ./dist/server/entry.mjs
FROM node:18-slim AS base
ENV PNPM_HOME="/pnpm"
ENV PATH="$PNPM_HOME:$PATH"
RUN corepack enable
COPY . /app
COPY astro.node.config.ts /app/astro.config.ts
WORKDIR /app

FROM base AS prod-deps
RUN --mount=type=cache,id=s/0cdba51f-ca18-4991-b228-f30672040b04-pnpm,target=/pnpm/store pnpm install --prod --frozen-lockfile

FROM base AS build
ARG POSTGRES_URL
ARG SITE_URL
RUN --mount=type=cache,id=s/0cdba51f-ca18-4991-b228-f30672040b04-pnpm,target=/pnpm/store pnpm install --frozen-lockfile
RUN pnpm run build

FROM base
COPY --from=prod-deps /app/node_modules /app/node_modules
COPY --from=build /app/dist /app/dist

ENV HOST=0.0.0.0
ENV PORT=4321
EXPOSE 4321
CMD node ./dist/server/entry.mjs
Brody
Brody9mo ago
i see you are doing a whole lot of stuff that isnt absolutely necessary, please get a minimal dockerfile working first
maddsua
maddsua9mo ago
wait do you really need a dockerfile to make astro work on railway?
Brody
Brody9mo ago
no no
danielo515
danielo5159mo ago
I was using a dockerfiie for portability in case I want to go another place. But will try without a dockerfiie How do I force it to be a node server? It automatically detects the dockerfiie and uses it
Brody
Brody9mo ago
remove or rename the dockerfile
danielo515
danielo5159mo ago
I changed to custom build and run commands. Does that suffice ? The problem persists
Brody
Brody9mo ago
what are your custom build and start commands?
danielo515
danielo5159mo ago
Just removed the dockerfile. The build now fails. My custom build is: pnpm build My custom run is node ./dist/server/entry.mjs Now that I removed the dockerfile it fails to build:
15.05 [commonjs--resolver] Failed to resolve entry for package "flowbite-svelte". The package may have incorrect main/module/exports specified in its package.json: No known conditions for "." specifier in "flowbite-svelte" package
15.05 [commonjs--resolver] Failed to resolve entry for package "flowbite-svelte". The package may have incorrect main/module/exports specified in its package.json: No known conditions for "." specifier in "flowbite-svelte" package
danielo515
danielo5159mo ago
Maybe I need to run pnpm install first? Or does that happen automatically?
Brody
Brody9mo ago
fix your typo please, i dont understand the question
danielo515
danielo5159mo ago
wow, chrome made having bookmarklets very difficult
Brody
Brody9mo ago
its just drag and drop? i use chrome remove the install command from your build command please
danielo515
danielo5159mo ago
Removed, do I re-export the logs?
Brody
Brody9mo ago
yes please
Brody
Brody9mo ago
what node version are you using locally
danielo515
danielo5159mo ago
18 18.18.0
Brody
Brody9mo ago
you do use pnpm locally right
danielo515
danielo5159mo ago
yes you think I'm installing mac-scpecific stuff?
Brody
Brody9mo ago
there are no errors duing the install phase can you run pnpm build locally without issues?
danielo515
danielo5159mo ago
no, there are not Yes, I do it like 5 times a day because it's convenient
Brody
Brody9mo ago
are you making sure node_modules and the built files arent making it into your repo
danielo515
danielo5159mo ago
Wait, let me test something locally
danielo515
danielo5159mo ago
Yes, both configs build locally fine
danielo515
danielo5159mo ago
Yes, they are all gitignored (shaded/dark files are gitignored)
No description
Brody
Brody9mo ago
you ran a different build command than what you are telling railway to run
danielo515
danielo5159mo ago
I tested both locally Gonna try pnpm build -f astro.node.config.ts on railway Same error
Brody
Brody9mo ago
this error wouldnt be isolated to railway, have you tried searching for solutions to the error?
danielo515
danielo5159mo ago
Is the bookmark the only way to download the logs? Gonna give build a try in a lxc container
Brody
Brody9mo ago
unless you want to use railway's api directly, yes
danielo515
danielo5158mo ago
Then in my vps I isolated the problem to be an issue with Astro hybrid mode. For some reason, when running on hybrid mode is not following the normal flow for pages that are not found, and crashes. Using server mode doesn't suffer from that problem
Want results from more Discord servers?
Add your server