Socket.io - High Frequency of Requests
Unanswered
Japanese flying squid posted this in #help-forum
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
I've custom server.js with socket.io. It was working normally, but I think I god DDoS attack. I've changed server from render to VPS hostinger. Also added cloudflare. I made website work and stay alive but I can't help socket.io. I am getting thousands of requests on socket.io every minute. It doesn't stop.
I get this error: GET https://www.kisa.ge/socket.io?EIO=4&transport=polling&t=PGv5Sxa net::ERR_TOO_MANY_REDIRECTS
Status Code: 308 Permanent Redirect
I get this error: GET https://www.kisa.ge/socket.io?EIO=4&transport=polling&t=PGv5Sxa net::ERR_TOO_MANY_REDIRECTS
Status Code: 308 Permanent Redirect
data:image/s3,"s3://crabby-images/d2e3a/d2e3a059ad3cabb5621bc0c0755a81a2caab0f92" alt="Image"
data:image/s3,"s3://crabby-images/e36af/e36af5060faa0fef22b12a379a082b78caace384" alt="Image"
148 Replies
first, if u have a vps and nginx, use certbot
then, u dont need a seperate socket.io handler in your nginx config
also, setting up a seperate api with express on a different port for socket.io is highly recommended
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
@gin also, setting up a seperate api with express on a different port for socket.io is highly recommended
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
Can you help me to do all this stuff?
I am using Certbot already
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
@Japanese flying squid did you exposed your ports correctly, so your server can handle that request (should be
Also, where did you got these logs from?
ufw
on ubuntu)?Also, where did you got these logs from?
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
I got logs from: sudo tail -f /var/log/nginx/access.log
And PORT is the same, I am using sockets from same next.js custom server, 3000 PORT
I didn’t expose anything manually from VPS
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
@Japanese flying squid ah ok. Try to search on how to setup a socket connection via your VPS. Then check against what you have done and change it
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
I couldn't find anything helpful online 😦
@B33fb0n3
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Japanese flying squid I am using Certbot already
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
but your setup is false
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Japanese flying squid I couldn't find anything helpful online 😦
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
this might help you: https://www.youtube.com/results?search_query=connect+socket.io+with+VPS+server
When you hosting though docker, then you should also set up nginx. The first video (this one: https://www.youtube.com/watch?v=uVTSBsUmB7A) for example clarifies how you need to change your nginx config to be able to use socket.io
When you hosting though docker, then you should also set up nginx. The first video (this one: https://www.youtube.com/watch?v=uVTSBsUmB7A) for example clarifies how you need to change your nginx config to be able to use socket.io
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
@gin but your setup is false
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
what is his setup?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
i already told him what he has to do
having a custom server with nextjs is very bad
u loose a bunch of critical features
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
@B33fb0n3 what is his setup?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
he is proxying the same port twice
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
@gin u loose a bunch of critical features
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
what's for example? When self hosting it, all nextjs features are supported
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
@gin can you help me with setting up different socket.io server on VPS? I've not a lot of experience with VPS
data:image/s3,"s3://crabby-images/16a7a/16a7ab777a8dade3adca20517b4fd4620753bc13" alt="Image"
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Japanese flying squid <@759064479521701888> can you help me with setting up different socket.io server on VPS? I've not a lot of experience with VPS
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
socket.io runs fine on a seperate express or any other node server
also u dont need extra setup for sockets
cause nginx supports it by native
make sure if u use cloudflare to enable wss support
cause sometimes it may be disabled
so socketio will switch to polling which will extremely increase the requests
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
so I've to set upanother socket server with express, run it for examplelocalhost:3001, and connect from Next.js app to localhost:3001 socket server?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
i see in your screenshot
@Japanese flying squid can u go inside your networks tab and send me a screenshot of the first init connection socketio makes?
filter by websocket
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
@gin u mean custom server?
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
the
Read more: https://nextjs.org/docs/app/building-your-application/configuring/custom-server
Automatic Static Optimization
link, links to the pages router. And also all the content itself is about the pages router. So it isn't relevant for the app routerRead more: https://nextjs.org/docs/app/building-your-application/configuring/custom-server
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
@gin Inside networks, when I filter WS I don;t get any messages
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
@B33fb0n3 the Automatic Static Optimization link, links to the pages router. And also all the content itself is about the pages router. So it isn't relevant for the app router
Read more: https://nextjs.org/docs/app/building-your-application/configuring/custom-server
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
yeah i know that but the app docs still links to that page and also it is saying optimizations
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
data:image/s3,"s3://crabby-images/22341/223413fbb807c0a482876af1a7a5501e448d979a" alt="Image"
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Japanese flying squid Click to see attachment
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
just to make sure. You did this, right: https://nextjs-forum.com/post/1325627467993714769#message-1325743631138689046 <--- click
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
its just that if u switch for websockets to a serverfull extern server u will have less problems
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
I've nto yet done cloudflare
this my nginx config rn
data:image/s3,"s3://crabby-images/7ef31/7ef31e07ae370ebed5e6b5b9b6962a44eaef1d85" alt="Image"
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
Yes, it's Full encryption rn
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Japanese flying squid this my nginx config rn
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
ignore that config
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
data:image/s3,"s3://crabby-images/769f6/769f6d9cb578664d6219f31d5d5ffef929adee11" alt="Image"
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
its faulty rn thats why u getting a 308
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
data:image/s3,"s3://crabby-images/6f4df/6f4df8827185c15e8d22417cec2f699e0390e669" alt="Image"
@gin I will go and set up new repository for express websockets server, correct?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
yes
and remove custom server from nextjs
the rest is self explanatory, if u want to use the same endpoint, u can just route a path to a different port in nginx
so everything under yourdomain.com/socket routes to localhost:3001 (your socketio backend)
or u create a subdomain like socket.yourdomain.com, makes the setup easier
this is the only thing to consider when u have a external server, u will profit a lot having a seperate backend
talking from experience
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
I need to make it asap for now
data:image/s3,"s3://crabby-images/55ca3/55ca343d60a2eefbe0f917d19b651578cc935ba8" alt="Image"
Is it okay?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
yes
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
data:image/s3,"s3://crabby-images/4d85e/4d85e4080ee94463ef37503a93d242d820984328" alt="Image"
Now just delete server.js from next?
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
"scripts": {
"dev": "next dev",
"build": "next build",
"start": "node .next/standalone/server.js",
"prod_start": "NODE_ENV=production node server.js",
"lint": "next lint",
"deploy": "npm run build && git add . && git commit -m 'deploy' && git push"
},
"dev": "next dev",
"build": "next build",
"start": "node .next/standalone/server.js",
"prod_start": "NODE_ENV=production node server.js",
"lint": "next lint",
"deploy": "npm run build && git add . && git commit -m 'deploy' && git push"
},
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
your prod_start to next start
dont need node env since start is in production mode
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
from my dockerfile I started server like
# Start the server
CMD ["node", "server.js"]
# Start the server
CMD ["node", "server.js"]
so I should change it "npm" "start"?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
yes
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
and insit start script leave : "start": "node .next/standalone/server.js",?
or change to next start
i just remembered on standalone u dont need next start cause it bundles everything
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
"use client";
import { io } from "socket.io-client";
export const socket = io();
what about this?
import { io } from "socket.io-client";
export const socket = io();
what about this?
this is my socket.ts
and then using like this
import { socket } from "./socket";
import { T_SocketEvent } from "./socket.types";
const socketEmit = (event: T_SocketEvent, data: any) => {
socket.emit(event, data);
};
export default socketEmit;
import { socket } from "./socket";
import { T_SocketEvent } from "./socket.types";
const socketEmit = (event: T_SocketEvent, data: any) => {
socket.emit(event, data);
};
export default socketEmit;
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Japanese flying squid "use client";
import { io } from "socket.io-client";
export const socket = io();
what about this?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
this a hook i usually use for my apps
import {io} from "socket.io-client";
let socket: ReturnType<typeof io>;
export default function useSocket() {
if (!socket) {
socket = io("https://yourdomain.com", {
path: "/api/socket.io",
});
}
return socket;
}
the important thing is to specify the path
just resuse the same socket instance
so u can just refernce it across your app and u will have the same connection
without creating it everytime
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
"use client";
import { io } from "socket.io-client";
export const socket = io("http://localhost:3077");
import { io } from "socket.io-client";
export const socket = io("http://localhost:3077");
is it okay?
to leave like this?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
u can leave it like this yes
just define the path
u will probably have it routed to /socket/socket.io
/socket/ routes to your 3077 and, /scoket.io is created internally
on local u can just have it to localhost:3077/socket.io
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
wait wait Iam confused now
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
keep what u have
it will work
socket.io-client will use /socketi.io automatically
but on production u need point the path otherwise it will fail
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
data:image/s3,"s3://crabby-images/6ae27/6ae2743586d7c03f582b97e09e0533bb554be107" alt="Image"
So I guess it is now okay for localhost
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
👍
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
Now I need to build and run my next app to test it, correct?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
yes data:image/s3,"s3://crabby-images/60b7c/60b7c3fc2a7132645702c3624e31bf64a97ac525" alt=":pausechamp:"
data:image/s3,"s3://crabby-images/60b7c/60b7c3fc2a7132645702c3624e31bf64a97ac525" alt=":pausechamp:"
data:image/s3,"s3://crabby-images/c33ed/c33ed98822a36b3d57f7d42aef5acc451ef426c7" alt=":shrug:"
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
You are helping me so much thanks, I need to fix it on prod in like 2 hours maximum
data:image/s3,"s3://crabby-images/046d8/046d88ca7176ae8745ed4adbb0193341cda77c55" alt="Image"
data:image/s3,"s3://crabby-images/88ac1/88ac1265030808feba9b54a21dcfd69805e2a2bd" alt="Image"
data:image/s3,"s3://crabby-images/d36c2/d36c2e7743ef90ca274cd94dff5dc443bf304c06" alt="Image"
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
what did u run?
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
npm run build
npm start - it runs node .next/standalone/server.js
just removing standalone
I will try without standalone
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
Better to leave still standalone?
Okay deleted .next and trying again with standalone
Will it be easy to make it work on VPS?
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
standalone is good if use nextjs with docker
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
Yes I use
Same problem with new build
data:image/s3,"s3://crabby-images/137ee/137ee4df3843946cbeb53b3dec4a7564da48589f" alt="Image"
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
strange
can i look at the codebase?
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
data:image/s3,"s3://crabby-images/70ffa/70ffaec748f013304887451b74f9df9b6ea9aee0" alt="Image"
on dev server it's ok
data:image/s3,"s3://crabby-images/547a4/547a4b3ae94cb6a09b8a16abf0623ffade1f871a" alt="Image"
inside .next I don't even see standalone folder
data:image/s3,"s3://crabby-images/3084f/3084f6a26b60e43c1bb573b9cb9f72536be3791a" alt="Image"
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
how does your next config look like
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
data:image/s3,"s3://crabby-images/83a8f/83a8fb71582a2593a9d9b37998e5e6f095455d48" alt="Image"
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
@Japanese flying squid Click to see attachment
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
do this
cp -r public .next/standalone/ && cp -r .next/static .next/standalone/.next/
data:image/s3,"s3://crabby-images/45ab0/45ab0f9182490158acff2d3ad1048eabdacf7567" alt="Image"
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
data:image/s3,"s3://crabby-images/738d4/738d44e61a34796996887c50699cefdc42f68975" alt="Image"
data:image/s3,"s3://crabby-images/c2550/c2550e42ef726555d4e4654a51055d529ade0380" alt="Image"
because inside standalone there is no server.js file
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
just run next start
the standalone folder has its own .next its probably in there
next start will work even with standalone
just do that locally
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
data:image/s3,"s3://crabby-images/b2ca6/b2ca6859f11c652770001e9a1b7c89bec78b92f3" alt="Image"
data:image/s3,"s3://crabby-images/edb38/edb381e3e5f123eebd4b47a522c9bcb91873da07" alt="Image"
but it works now
const io = new Server(httpServer, {
cors: {
origin: "http://localhost:3000", // Replace with your client origin
methods: ["GET", "POST"], // Allowed HTTP methods
credentials: true, // Allow cookies if needed
},
});
Should I add my prod url here also inside origin?
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Japanese flying squidOP
After removing custom server, on prod VPS I get error:
> kisa@1.1.0 start
> next start
sh: next: not found