புதிய தயாரிப்புகளைச் சேர்க்கும்போது E-Commerce ஆப்ஸில் Next.js 500 பிழையைச் சரிசெய்தல்

Next.js

தடையற்ற ஈ-காமர்ஸ் பணிப்பாய்வு முறிந்தால்

ஈ-காமர்ஸ் தளத்தை உருவாக்குவது அதன் சொந்த சவால்களைக் கொண்டுவருகிறது, குறிப்பாக நவீன கட்டமைப்புகளை ஒருங்கிணைக்கும் போது லாராவெல் போன்ற வலுவான பின்தளங்களுடன். எதிர்பாராத பிழைகள் ஏற்படும் போது நீங்கள் கற்பனை செய்யும் தடையற்ற அனுபவம் தடைபடலாம். 500 இன்டர்னல் சர்வர் பிழை என்பது பீதியையும் குழப்பத்தையும் ஏற்படுத்தக்கூடிய ஒரு கனவு. 😟

சமீபத்தில், நான் ஹோஸ்ட் செய்யப்பட்ட ஒரு திட்டத்தில் இந்த சரியான சிக்கலை எதிர்கொண்டேன் . ஆரம்பத்தில் எல்லாம் நன்றாகத் தெரிந்தது-முகப்புப்பக்கம் புதிய தயாரிப்புகளை விக்கல்கள் இல்லாமல் காட்டியது. ஆனால் நான் தயாரிப்பு விவரம் பக்கத்திற்கு செல்ல முயற்சித்த அல்லது இணைப்பு கூறுகளைப் பயன்படுத்தி ஒரு தயாரிப்பின் மீது வட்டமிட முயற்சித்த தருணத்தில், பயங்கரமான 500 பிழை அதன் தலையை உயர்த்தியது.

இந்த சிக்கலை குழப்பமடையச் செய்தது அதன் முரண்பாடு. உள்நாட்டில், உற்பத்தி மற்றும் காட்சி சூழல்களைப் பிரதிபலிக்கும் போது கூட, பயன்பாடு குறைபாடற்ற முறையில் வேலை செய்தது. ஸ்டேஜிங் வரிசைப்படுத்தலும் நன்றாக வேலை செய்தது, ஆனால் உற்பத்தி? அங்குதான் அது தோல்வியடைந்தது. இந்த மர்மங்கள் டெவலப்பரின் பொறுமை மற்றும் சரிசெய்தல் திறன்களை சோதிக்கலாம்.

ஒரு சாலைப் பயணத்தின் போது சரியாக ஓடிய பிறகு என் கார் விவரிக்க முடியாதபடி பழுதடைந்த நேரத்தை இது எனக்கு நினைவூட்டியது. பயன்பாட்டைப் பிழைத்திருத்தம் செய்வது போல், எரிபொருள், டயர்கள் மற்றும் அடைபட்ட வடிகட்டிகள் போன்ற தெளிவற்ற சிக்கல்கள் அனைத்தையும் சரிபார்க்கலாம். இதேபோல், இந்த பிழையை தீர்ப்பதற்கு ஒரு முறையான அணுகுமுறை மற்றும் நிறைய சோதனை மற்றும் பிழை தேவைப்பட்டது. 🚗💻

கட்டளை பயன்பாட்டின் உதாரணம்
dehydrate முன்னரே பெறப்பட்ட வினவல்களின் நிலையை வரிசைப்படுத்த ரியாக்ட் வினவலுடன் பயன்படுத்தப்படுகிறது, எனவே இது முன்பக்கத்தில் பயன்படுத்தப்படலாம். எடுத்துக்காட்டு: டீஹைட்ரேட்(கேரிக்ளையன்ட்).
prefetchQuery ஒரு பக்கத்தை வழங்குவதற்கு முன் கொடுக்கப்பட்ட விசைக்கான வினவல் தரவை முன்கூட்டியே ஏற்றுகிறது. எடுத்துக்காட்டு: queryClient.prefetchQuery(['key'], fetchFunction).
fallback: 'blocking' ISR உருவாக்கத்தின் போது Next.js எவ்வாறு புதிய டைனமிக் பாதைகளைக் கையாளுகிறது என்பதைக் குறிப்பிடுகிறது. 'தடுத்தல்' என அமைக்கப்படும் போது, ​​பக்கம் சர்வர் பக்கமாக ரெண்டர் செய்யப்பட்டு தற்காலிகமாக சேமிக்கப்படும்.
cache: 'no-cache' API மறுமொழிகளின் தேக்ககத்தைத் தடுக்கிறது, சமீபத்திய தரவு பெறப்படுவதை உறுதி செய்கிறது. எடுத்துக்காட்டு: பெறு(url, { கேச்: 'நோ-கேச்' }).
notFound: true பக்கம் இல்லை என்று Next.js க்கு, 404 பதிலை வழங்கும். எடுத்துக்காட்டு: தவறான பாதைகளுக்கு getStaticProps இல் திரும்பியது.
QueryClient வினவல் நிலையை நிர்வகிக்க எதிர்வினை வினவல் கிளையன்ட் நிகழ்வை உருவாக்குகிறது. எடுத்துக்காட்டு: const queryClient = புதிய QueryClient().
fetchProductDetails பின்தளத்தில் இருந்து மாறும் வகையில் தயாரிப்பு விவரங்களைப் பெறுவதற்கான தனிப்பயன் செயல்பாடு. எடுத்துக்காட்டு: fetchProductDetails('product_slug').
revalidate ISR பக்கம் மீண்டும் ரெண்டர் செய்யப்படுவதற்கு சில நொடிகளில் கால அளவை தீர்மானிக்கிறது. எடுத்துக்காட்டு: மறுமதிப்பீடு: 10.
paths Contains an array of dynamic routes to pre-render during build. Example: const paths = data.map(item =>உருவாக்கத்தின் போது முன்-ரெண்டர் செய்வதற்கான டைனமிக் வழிகளின் வரிசையைக் கொண்டுள்ளது. எடுத்துக்காட்டு: const paths = data.map(item => ({ params: { slug: item.slug } })).
axios.get ஒரு குறிப்பிட்ட API இறுதிப் புள்ளியிலிருந்து தரவைப் பெறுகிறது. எடுத்துக்காட்டு: axios.get('/api/product').

தீர்வைப் புரிந்துகொள்வது: குறியீட்டை உடைத்தல்

வழங்கப்பட்ட ஸ்கிரிப்டுகள் பொதுவான சிக்கலைக் குறிப்பிடுகின்றன பயன்பாடுகள்: டைனமிக் ரூட்டிங் மற்றும் ISR (அதிகரிக்கும் நிலையான மீளுருவாக்கம்) சவால்கள். முதல் ஸ்கிரிப்ட் ரியாக் வினலைப் பயன்படுத்துகிறது பக்கங்களை ரெண்டரிங் செய்வதற்கு முன் தரவைப் பெறுவதற்கும் தேக்குவதற்கும் முறை. பயனர் தயாரிப்பு விவரம் பக்கத்திற்குச் செல்லும்போது தயாரிப்பு விவரங்கள் கிடைப்பதை இது உறுதிசெய்கிறது, இயக்க நேரத்தைப் பெறுவதில் தாமதத்தைத் தடுக்கிறது. வரிசையில் காத்திருப்பதைத் தவிர்க்க திரைப்பட டிக்கெட்டை முன்கூட்டியே ஆர்டர் செய்வது போன்றது. 🎟️ இந்த செயலூக்கமான பெறுதல் பக்க சுமை நேரங்களைக் குறைத்து பயனர் அனுபவத்தை மேம்படுத்துகிறது.

இரண்டாவது எழுத்தில், தி செயல்பாடு பின்தளத்தில் API ஐப் பயன்படுத்தி தயாரிப்புகளுக்கான வழிகளை மாறும் வகையில் உருவாக்குகிறது. குறிப்பிடுவதன் மூலம் , புதிய தயாரிப்புகள் முதல் முறையாக அணுகும்போது தேவைக்கேற்ப வழங்கப்படுவதை இது உறுதி செய்கிறது. ஆயிரக்கணக்கான தயாரிப்புகளைக் கொண்ட ஈ-காமர்ஸ் தளங்களுக்கு இந்த முறை முக்கியமானது, ஏனெனில் இது உருவாக்க நேரத்தில் சாத்தியமான அனைத்து பக்கங்களையும் முன்-ரெண்டர் செய்வதைத் தவிர்க்கிறது. உங்கள் சமையலறையை ஒவ்வொரு சுவையுடனும் முன்பே நிரப்புவதற்குப் பதிலாக யாராவது ஆர்டர் செய்தால் குக்கீகளை பேக்கிங் செய்வதாக நினைத்துப் பாருங்கள். 🍪

மூன்றாவது ஸ்கிரிப்ட்டின் ஒருங்கிணைப்பு உள்ளே சேவையக பக்க தரவுகளை வரிசைப்படுத்தப்பட்ட நிலையாக முன்பகுதிக்கு அனுப்ப அனுமதிக்கிறது. இது SEO க்கு மிகவும் பயனுள்ளதாக இருக்கும், ஏனெனில் இது ISR வழியாக கொடுக்கப்பட்ட பக்கங்கள் இன்னும் தேடுபொறிகள் வலம் வருவதற்கு தேவையான மெட்டாடேட்டாவைக் கொண்டிருப்பதை உறுதி செய்கிறது. இது வீட்டில் ஒரு உணவைத் தயாரிப்பதற்கும், டெலிவரிக்காக அதை பேக்கேஜிங் செய்வதற்கும் ஒப்பானது, இதனால் அது கவர்ச்சிகரமானதாகவும், வந்தவுடன் சாப்பிட தயாராக இருக்கும். 🥡 இது தேடுபொறிகளில் பயன்பாட்டின் தெரிவுநிலை மற்றும் செயல்திறனை மேம்படுத்துகிறது.

இறுதியாக, பிழை கையாளுதல் ஒரு முக்கிய பங்கு வகிக்கிறது. போன்ற கட்டளைகள் தவறான வழிகள், பயன்பாட்டை செயலிழக்கச் செய்வதற்குப் பதிலாக, பயனர்களை 404 பக்கத்திற்குத் திருப்பி விடுகின்றன என்பதை உறுதிப்படுத்தவும். இதற்கிடையில், அமைத்தல் API அழைப்புகளுக்கு சமீபத்திய தரவு எப்பொழுதும் பெறப்படும் என்பதற்கு உத்தரவாதம் அளிக்கிறது. இந்த அம்சங்கள் பயன்பாட்டை வலுவாகவும் பயனர் நட்புடனும் ஆக்குகின்றன. ஹோட்டல் பட்டியலைப் புதுப்பித்தாலும், காலாவதியான தகவலைப் பார்ப்பதை கற்பனை செய்து பாருங்கள் - இது பயனர்களை ஏமாற்றும்! இந்த ஸ்கிரிப்டுகள் இதுபோன்ற காட்சிகளைத் தடுக்கின்றன, சமீபத்திய தயாரிப்பு விவரங்கள் எப்போதும் காட்டப்படுவதை உறுதி செய்கிறது.

Next.js இ-காமர்ஸ் பயன்பாடுகளில் 500 பிழைகளைக் கண்டறிந்து சரிசெய்தல்

டைனமிக் ரூட்டிங் சிக்கல்களைத் தீர்ப்பதற்கு Laravel உடன் Next.jsஐ பின்தளமாகப் பயன்படுத்துதல்

const axios = require('axios');
const baseURL = 'https://your-backend-api.com';

async function fetchProductDetails(slug) {
  try {
    const response = await axios.get(`${baseURL}/api/product/${slug}`);
    return response.data;
  } catch (error) {
    console.error('Error fetching product details:', error.message);
    throw new Error('Could not fetch product details');
  }
}

module.exports = fetchProductDetails;
// Unit Test Example
const fetchProductDetails = require('./fetchProductDetails');
test('Should fetch valid product details', async () => {
  const data = await fetchProductDetails('test-product');
  expect(data).toHaveProperty('name');
});

சிறந்த செயல்திறனுக்காக Next.js இல் நிலையான பாதை உருவாக்கத்தை மேம்படுத்துதல்

டைனமிக் ISR பயன்பாடுகளுக்கான getStaticPaths முறையை மேம்படுத்துகிறது

export async function getStaticPaths() {
  try {
    const res = await fetch(`${baseURL}/api/all-product`, { cache: 'no-cache' });
    const { data } = await res.json();
    const paths = data.map(product => ({
      params: { product_slug: product.slug },
    }));
    return { paths, fallback: 'blocking' };
  } catch (error) {
    console.error('Error fetching paths:', error.message);
    return { paths: [], fallback: 'blocking' };
  }
}
// Add additional error handling for 500 responses

எஸ்சிஓ உகப்பாக்கத்திற்காக Next.js இல் Prefetch Query மற்றும் Dehydration ஐ மேம்படுத்துதல்

Prefetch மற்றும் dehydrate நிலையை திறம்பட செய்ய Next.js உடன் React Query ஐப் பயன்படுத்துதல்

import { dehydrate, QueryClient } from '@tanstack/react-query';
import { fetchProductDetails } from './api/fetchProductDetails';

export async function getStaticProps(context) {
  const { product_slug } = context.params;
  const queryClient = new QueryClient();
  try {
    await queryClient.prefetchQuery(['productDetails', { product_slug }], () => fetchProductDetails(product_slug));
    return {
      props: { dehydratedState: dehydrate(queryClient) },
      revalidate: 10,
    };
  } catch (error) {
    console.error('Error prefetching product data:', error.message);
    return {
      notFound: true,
    };
  }
}
// Modularized prefetching ensures maintainability

அதிகரிக்கும் நிலையான மீளுருவாக்கத்தை (ISR) ஆழமாக ஆராய்தல்

அதிகரிக்கும் நிலையான மீளுருவாக்கம் (ISR) ஒரு சக்திவாய்ந்த அம்சமாகும் முழு பயன்பாட்டையும் மீண்டும் உருவாக்காமல் இருக்கும் பக்கங்களை புதுப்பிக்க இது உங்களை அனுமதிக்கிறது. பெரிய அளவிலான பயன்பாடுகளுக்கு, குறிப்பாக தயாரிப்பு பட்டியல்கள் அல்லது விலையிடல் புதுப்பிப்புகள் போன்ற தரவு அடிக்கடி மாறும் மின்-வணிக தளங்களுக்கு இந்த திறன் அவசியம். அமைப்பதன் மூலம் உள்ள சொத்து , பின்னணியில் ஒரு பக்கம் எவ்வளவு அடிக்கடி மீண்டும் உருவாக்கப்படுகிறது என்பதை டெவலப்பர்கள் தீர்மானிக்க முடியும். ஒரு புத்தகக் கடை தினசரி புதிய தலைப்புகளைச் சேர்ப்பதை கற்பனை செய்து பாருங்கள் - ஐஎஸ்ஆர் தளம் முழுவதுமாக மறுபயன்பாடு இல்லாமல் புதுப்பிக்கப்படுவதை உறுதி செய்கிறது. 📚

ISR இன் ஒரு முக்கியமான அம்சம் பின்வாங்கும் நிலைகளை திறம்பட கையாள்வது. பயன்படுத்தி , முந்தைய எடுத்துக்காட்டில் காட்டப்பட்டுள்ளபடி, புதிய அல்லது அரிய வழிகள் முதல் முறையாக அணுகும்போது தேவைக்கேற்ப உருவாக்கப்படுவதை உறுதி செய்கிறது. இது ஆரம்ப கட்ட நேரத்தை குறைக்கிறது மற்றும் ஆயிரக்கணக்கான பக்கங்களைக் கொண்ட பயன்பாடுகளுக்கு குறிப்பாக பயனுள்ளதாக இருக்கும். ஒரு நிஜ உலக உதாரணம், பயனர்கள் தேடும் போது, ​​வளங்களைச் சேமித்து, செயல்திறனை உறுதி செய்யும் போது, ​​குறைவான அறியப்படாத இடங்களுக்கான பக்கங்களை மாறும் வகையில் உருவாக்கும் பயணத் தளமாக இருக்கலாம். ✈️

ISR இன் மற்றொரு சவால் பிழை மேலாண்மை. ஒரு பின்தள API தரவை வழங்கத் தவறினால், ISR ஆனது உடைந்த பக்கத்தை உருவாக்கலாம். போன்ற செயல்பாடுகளில் சரியான பிழை கையாளுதலை இணைப்பதன் மூலம் மற்றும் திரும்பும் இதுபோன்ற சந்தர்ப்பங்களில், டெவலப்பர்கள் இந்த சூழ்நிலையைத் தடுக்கலாம். இந்த அணுகுமுறை பயனர் அனுபவத்தைப் பாதுகாப்பது மட்டுமல்லாமல், உடைந்த பக்கங்களை அட்டவணைப்படுத்தும் தேடுபொறிகளிலிருந்து எஸ்சிஓ அபராதங்களையும் தவிர்க்கிறது. இந்த நடைமுறைகள் செயல்திறன் மற்றும் நம்பகத்தன்மையை பராமரிக்கும் போது பயன்பாடுகளை அளவிடுவதற்கான ஒரு முக்கிய கருவியாக ISR ஆக்குகிறது.

  1. 500 பிழைகளுக்கு என்ன காரணம்? ?
  2. 500 பிழைகள் பெரும்பாலும் பின்தளத்தில் APIகளில் கையாளப்படாத விதிவிலக்குகள் அல்லது டைனமிக் ரூட்களுக்கான தரவு விடுபட்டதால் ஏற்படுகின்றன. பயன்படுத்தி சரியான பிழை கையாளுதல் போன்ற அர்த்தமுள்ள பதில்களைத் தருகிறது அவற்றைக் குறைக்க உதவலாம்.
  3. தயாரிப்பு பக்கங்களில் அடிக்கடி புதுப்பித்தல்களை ISR எவ்வாறு கையாளுகிறது?
  4. ஐஎஸ்ஆர் பயன்படுத்துகிறது குறிப்பிட்ட இடைவெளியில் பின்னணியில் நிலையான பக்கங்களை மீண்டும் உருவாக்குவதற்கான சொத்து. இது முழு மறுபயன்பாடு இல்லாமல் உள்ளடக்கத்தை புதியதாக வைத்திருக்கும்.
  5. இதன் முக்கியத்துவம் என்ன ISR இல்?
  6. புதிய வழிகளுக்கான பக்கங்கள் முதல் முறையாக அணுகப்படும்போது தேவைக்கேற்ப வழங்கப்படுவதை இந்த அமைப்பு உறுதிசெய்கிறது, இது பல டைனமிக் பக்கங்களைக் கொண்ட பெரிய அளவிலான பயன்பாடுகளுக்கு ஏற்றதாக அமைகிறது.
  7. ஏன் உள்ளது இந்த ஸ்கிரிப்ட்களில் பயன்படுத்தப்பட்டதா?
  8. இது முன் எடுக்கப்பட்ட வினவல் தரவை முன்னோக்கிக்கு மாற்றுவதற்கு ஏற்ற வடிவமைப்பில் வரிசைப்படுத்துகிறது. இது கிளையன்ட் பக்கத்தில் உள்ள ரியாக்ட் வினவல் கேச்களை ஹைட்ரேட் செய்ய உதவுகிறது, இது தடையற்ற பயனர் அனுபவத்தை உறுதி செய்கிறது.
  9. தோல்வியுற்ற API அழைப்புகளைக் கையாள்வதற்கான சிறந்த நடைமுறைகள் யாவை?
  10. சரியான பிழை கையாளுதலைப் பயன்படுத்தவும் தொகுதிகள், பிழைத்திருத்தத்திற்கான பதிவு பிழைகள், மற்றும் போன்ற அழகான பின்னடைவுகளை திரும்பப் பெறுதல் அல்லது பயனருக்குத் தெரிவிக்க பொருத்தமான நிலைக் குறியீடு.

டைனமிக் வழிகளைக் கையாளுதல் மற்றும் சர்வர் பக்க ரெண்டரிங் கட்டமைக்கப்பட்ட அணுகுமுறை தேவை. முறையான பிழை கையாளுதல், ஃபால்பேக் முறைகளைப் பயன்படுத்துதல் மற்றும் வினவல் தரவை முன்கூட்டியே பெறுதல் போன்ற நுட்பங்கள் இயக்க நேரப் பிழைகளைக் கணிசமாகக் குறைக்கும். டைனமிக் பக்கங்கள் பயனர்களுக்கு தடையின்றி செயல்படுவதை இந்த முறைகள் உறுதி செய்கின்றன.

வாழ்க்கையைப் போலவே, இதுபோன்ற பிழைகளைத் தீர்ப்பதற்கு பொறுமை மற்றும் முறையான சிக்கலைத் தீர்ப்பது அவசியம், இது பயணத்தின் நடுவில் திடீரென நிறுத்தப்படும்போது கார் எஞ்சினை சரிசெய்வது போன்றது. பிழைத்திருத்தக் கருவிகளை ஹோஸ்டிங் கண்டறிதலுடன் இணைப்பது ஏமாற்றத்தை வெற்றியாக மாற்றும். 🚀 ஒவ்வொரு சவாலிலும் தொடர்ந்து முன்னேறுங்கள்!

  1. பயன்பாடு பற்றி விரிவாகக் கூறுகிறது மற்றும் டைனமிக் ரூட்டிங் மற்றும் ஐஎஸ்ஆர்: Next.js ஆவணம் .
  2. இ-காமர்ஸ் தீர்வுகளுக்கு Laravel ஐப் பயன்படுத்தி பின்தள APIகளை செயல்படுத்துவது பற்றிய விவரங்கள்: Laravel அதிகாரப்பூர்வ ஆவணம் .
  3. டிஜிட்டல் பெருங்கடலில் உள்ள 500 உள் சேவையகப் பிழைகளை பிழைத்திருத்தம் மற்றும் தீர்ப்பதற்கான நுண்ணறிவுகளை வழங்குகிறது: டிஜிட்டல் ஓஷன் ஆப் பிளாட்ஃபார்ம் ஆவணப்படுத்தல் .
  4. வினைத்திறன் வினவல் மூலம் செயல்திறனை மேம்படுத்துதல் மற்றும் பிழைகளைக் குறைத்தல் பற்றிய வழிகாட்டுதல்கள்: எதிர்வினை வினவல் ஆவணம் .
  5. Next.js பயன்பாடுகளில் கேச் மற்றும் டைனமிக் டேட்டாவை நிர்வகிப்பதற்கான சிறந்த நடைமுறைகளை விளக்குகிறது: LogRocket Blog on Caching in Next.js .