Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Feature Request] Golang to Serve Frontend Assets (like React) instead of Node.Js #339

Open
1 task done
EarliestFall988 opened this issue Nov 22, 2024 · 1 comment · May be fixed by #357
Open
1 task done

[Feature Request] Golang to Serve Frontend Assets (like React) instead of Node.Js #339

EarliestFall988 opened this issue Nov 22, 2024 · 1 comment · May be fixed by #357
Labels
enhancement New feature or request

Comments

@EarliestFall988
Copy link

Tell us about your feature request

I work on projects that require pretty high security standards, and I have yet to get Node.Js pushed through (maybe Deno in the future??). Has anyone tried deploying go-blueprint with React and without Node - letting Golang serve the frontend assets instead?

This would be similar to the official React + ASP.NET or Vue + ASP.NET templates. Vite becomes a proxy server during development for DX reasons (HMR, tailwind, etc.). When it's time to deploy, Vite builds the frontend assets into a public folder, which Golang picks up and serves. All API endpoints will get served through 'https://example.com/api/' (it would feel kinda like Next.Js).

It could simplify the deployment story because you wouldn't necessarily need docker-compose just to serve HTML/CSS/JS assets. One Golang server would do all the work, and latency could be reduced (depending on how the project is deployed).

Deploying without Node means you can't deploy any server-side JS packages. But go-blueprint is a Golang backend project - if you're deploying backend JS, you're probably doing it wrong.

If this seems interesting, I am happy to tinker and create a PR, but I don't want to expand this project's scope because of a specific deployment opinion or security need.

Any thoughts?

Huge fan!! Go Blueprint is incredible!!

Disclaimer

  • I agree
@EarliestFall988 EarliestFall988 added the enhancement New feature or request label Nov 22, 2024
@Ujstor
Copy link
Collaborator

Ujstor commented Nov 24, 2024

@EarliestFall988
I agree with you, the current implementation is not ideal. The use of serve for serving static content can be removed. Instead, we can adopt a more efficient approach. Nginx, for instance, is highly efficient, fast, secure, and production-ready.

Bundling the frontend and backend into one monolith is not something I favor. We should keep these two components separate. This separation aligns with cloud-native patterns.

If you are deploying into k8s, as most production apps are, you gain granular control over resources, autoscaling, rolling updates, and fault isolation. It also simplifies scaling specific components and removes the need to redeploy the backend if only the frontend changes, and vice versa.

The only remaining question is whether to serve the frontend using a Go or Nginx.

@Ujstor Ujstor linked a pull request Dec 16, 2024 that will close this issue
2 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants