NestJS மைக்ரோ சர்வீஸில் உள்ள டோக்கர் சிக்கல்களைச் சரிசெய்தல்
வளரும் போது ஏ மைக்ரோ சர்வீஸ் அடிப்படையிலான RestAPI, டோக்கர் கொள்கலனில் இயங்கும் சேவைகள் சில நேரங்களில் எதிர்பாராத சிக்கல்களுக்கு வழிவகுக்கும். டோக்கரால் கண்டுபிடிக்க முடியாதபோது இதுபோன்ற ஒரு சிக்கல் எழுகிறது தொகுதி, சேவை இயங்குவதைத் தடுக்கிறது.
அங்கீகாரம் மற்றும் முன்பதிவுகள் போன்ற பல சேவைகளை நீங்கள் ஏற்கனவே அமைத்துள்ளீர்கள், மேலும் அவை அந்தந்த கொள்கலன்களில் சீராக இயங்குவதை உறுதிசெய்யும் வகையில் செயல்படும்போது இந்தச் சிக்கல் குறிப்பாக வெறுப்பாக இருக்கிறது. சந்திப்பது ஏ பிழை வளர்ச்சியை நிறுத்தலாம் மற்றும் உடனடி பிழைகாணல் தேவைப்படுகிறது.
டோக்கர் கன்டெய்னருக்குள் சார்புநிலைகள் எவ்வாறு கையாளப்படுகின்றன, குறிப்பாக a ஐப் பயன்படுத்தும் போது, சிக்கல் பெரும்பாலும் தொடர்புடையது அடிப்படை படம் மற்றும் தொகுப்பு மேலாளர்கள் போன்றவர்கள் . பிழைப் பதிவு பொதுவாக கொள்கலனில் காணாமல் போன தொகுதியை சுட்டிக்காட்டுகிறது கோப்பகம், இது சேவை தொடக்க செயல்முறையை பாதிக்கிறது.
இந்த வழிகாட்டியில், இந்த பிழைக்கான பொதுவான காரணங்களை நாங்கள் படிப்போம், சாத்தியமான தீர்வுகளைப் பற்றி விவாதிப்போம் மற்றும் அதைத் தீர்ப்பதற்கான பரிந்துரைகளை வழங்குவோம், உங்கள் NestJS சேவைகள் Docker சூழலில் எதிர்பார்த்தபடி இயங்குவதை உறுதிசெய்வோம்.
| கட்டளை | பயன்பாட்டின் உதாரணம் |
|---|---|
| @nestjs/cli | இந்த கட்டளை உலகளவில் NestJS CLI ஐ நிறுவுகிறது, இது டோக்கரில் NestJS பயன்பாடுகளை இயக்குவதற்கு முக்கியமானது. தவிர்க்க உதவுகிறது பிழை. |
| RUN npm install -g pnpm | டோக்கர் கொள்கலனில் உலகளவில் pnpm தொகுப்பு மேலாளரை நிறுவுகிறது, இது அனைத்து சார்புகளும், குறிப்பாக pnpm க்கு நோக்கப்பட்டவை, சரியாக நிறுவப்பட்டிருப்பதை உறுதி செய்கிறது. |
| pnpm run build | குறிப்பிட்ட சேவைக்கான (அங்கீகாரம் அல்லது முன்பதிவுகள்) உருவாக்க கட்டளையை pnpm ஐப் பயன்படுத்தி செயல்படுத்துகிறது, பயன்பாடு மேம்பாடு மற்றும் உற்பத்தி சூழல்கள் இரண்டிற்கும் சரியாக உருவாக்கப்பட்டுள்ளதை உறுதி செய்கிறது. |
| COPY --from=development /usr/src/app/dist | இந்த டோக்கர் மல்டி-ஸ்டேஜ் பில்ட் கட்டளை உருவாக்க வெளியீட்டை டெவலப்மெண்ட் நிலையிலிருந்து உற்பத்தி நிலைக்கு நகலெடுக்கிறது, டோக்கர் படத்தின் அளவை மேம்படுத்துகிறது மற்றும் பயன்பாடு இயங்கத் தயாராக இருப்பதை உறுதி செய்கிறது. |
| CMD ["node", "dist/apps/auth/main.js"] | இந்த கட்டளையை இயக்க பயன்படுகிறது கட்டப்பட்ட டிஸ்ட் டைரக்டரியில் இருந்து பிரதான ஜாவாஸ்கிரிப்ட் கோப்பை நேரடியாக இயக்குவதன் மூலம் உற்பத்தியில் சேவை. |
| testEnvironment: 'node' | ஜெஸ்ட் கட்டமைப்பில், இந்த கட்டளையானது சோதனை சூழலை Node.js ஆக அமைக்கிறது, யூனிட் சோதனைகள் பின்தள சூழலை துல்லியமாக உருவகப்படுத்த முடியும் என்பதை உறுதி செய்கிறது. |
| describe('Nest CLI Module Check') | ஜெஸ்டில், இந்தச் செயல்பாடு ஒரு சோதனைத் தொகுப்பை வரையறுக்கிறது டோக்கர் கொள்கலனுக்குள் சரியாக நிறுவப்பட்டு, தொகுதி சார்புகள் தீர்க்கப்படுவதை உறுதி செய்கிறது. |
| exec('nest --version') | என்பதை சரிபார்க்க சோதனையின் உள்ளே ஷெல் கட்டளையை செயல்படுத்துகிறது சிஎல்ஐ டோக்கர் கொள்கலனில் கிடைக்கிறது, இது தொகுதி காணவில்லையா அல்லது தவறாக உள்ளமைக்கப்பட்டதா என்பதைக் கண்டறிய உதவுகிறது. |
டோக்கர் மற்றும் NestJS CLI ஒருங்கிணைப்பைப் புரிந்துகொள்வது
எடுத்துக்காட்டுகளில் வழங்கப்பட்ட முதல் Dockerfile, தீர்வு காண்பதில் கவனம் செலுத்துகிறது போன்ற சேவைகளை இயக்கும் போது NestJS CLI தொடர்பான பிழை மற்றும் . வளர்ச்சி மற்றும் உற்பத்தி நிலைகள் இரண்டிலும் தேவையான உலகளாவிய சார்புகள் நிறுவப்பட்டிருப்பதை உறுதி செய்வதன் மூலம் இது அடையப்படுகிறது. Dockerfile ஒரு இலகுரக பயன்படுத்தி தொடங்குகிறது முனை:அல்பைன் படம், இது ஒட்டுமொத்த படத்தின் அளவைக் குறைக்க உதவுகிறது. இது தொகுப்பு மேலாளரை நிறுவுகிறது மற்றும் NestJS CLI உலகளவில் தேவையான அனைத்து தொகுதிக்கூறுகளும் சுற்றுச்சூழலில் இருப்பதை உறுதிசெய்யும்.
CLI மற்றும் தொகுப்பு மேலாளர் நிறுவப்பட்டதும், ஸ்கிரிப்ட் தேவையான கோப்புகளை நகலெடுக்கிறது மற்றும் கட்டமைப்பு கோப்புகள், திட்ட சார்புகளை நிறுவுவதற்கு முக்கியமானவை. சார்புகள் நிறுவப்பட்ட பிறகு, கட்டளையைப் பயன்படுத்தி திட்டம் கட்டப்பட்டது , இது மூலக் குறியீட்டை விநியோகிக்கக்கூடிய வடிவத்தில் தொகுக்கிறது. இந்த படிநிலை அவசியமானது, ஏனெனில் தொகுக்கப்பட்ட வெளியீடு இறுதி உற்பத்தி சூழலில் பயன்படுத்தப்படும், வளர்ச்சிக் கருவிகளில் இருந்து தேவையற்ற மேல்நிலையைத் தவிர்க்கிறது.
Dockerfile இன் இரண்டாம் நிலை பல-நிலை உருவாக்க செயல்முறையைப் பயன்படுத்துகிறது. இந்த கட்டத்தில், வளர்ச்சி நிலையிலிருந்து தொகுக்கப்பட்ட வெளியீடு ஒரு புதிய உற்பத்தி சூழலுக்கு நகலெடுக்கப்படுகிறது, இறுதி படம் இலகுரக மற்றும் செயல்திறனுக்காக உகந்ததாக இருப்பதை உறுதி செய்கிறது. இந்த முறை தயாரிப்பு படத்தை சிறியதாகவும் பாதுகாப்பாகவும் வைத்திருக்க உதவுகிறது, ஏனெனில் இது பயன்பாட்டை இயக்க தேவையானவற்றை மட்டுமே கொண்டுள்ளது. இதைச் செய்வதன் மூலம், உற்பத்திச் சூழலில் சேர்க்கப்படும் வளர்ச்சி சார்புகள் தொடர்பான சாத்தியமான மோதல்கள் அல்லது சிக்கல்களைத் தடுக்கிறது.
பயன்பாட்டு தொடக்கத்தைக் கையாள, தி கட்டளை இயக்க வேண்டிய முக்கிய கோப்பைக் குறிப்பிடுகிறது, இது வழக்கமாக அமைந்துள்ளது உருவாக்க செயல்முறைக்குப் பிறகு அடைவு. டோக்கர் கொள்கலன் கட்டளையை இயக்குகிறது (அல்லது முன்பதிவுகள்/main.js மற்ற சேவைக்கு), மைக்ரோ சர்வீஸ் சரியான சூழலில் செயல்படுத்தப்படுவதை உறுதி செய்கிறது. இந்த அணுகுமுறை மைக்ரோ சர்வீஸ் கட்டமைப்பை அளவிட அனுமதிக்கிறது, ஏனெனில் ஒவ்வொரு சேவையும் அதன் சொந்த கொள்கலனில் அனைத்து சார்புகளையும் சரியாக நிர்வகிக்கலாம். ஒட்டுமொத்த அமைப்பானது, டோக்கர் NestJS சேவைகளை திறமையாக இயக்குவதை உறுதிசெய்கிறது, கொள்கலன்மயமாக்கலின் போது ஏற்படும் பொதுவான CLI சிக்கல்களைத் தீர்க்கிறது.
NestJS டோக்கர் தொகுதியைத் தீர்ப்பதில் நோட் மற்றும் டோக்கர் மேம்படுத்தல்களைப் பயன்படுத்துவதில் பிழை இல்லை
இந்த தீர்வு, @nestjs/cli/bin/nest.js இல்லாமையின் சிக்கலைத் தீர்க்க, Docker உடன் Node.js சூழலைப் பயன்படுத்துகிறது.
// Dockerfile - Solution 1 (Ensure Global Dependencies are Installed)FROM node:alpine AS developmentWORKDIR /usr/src/appCOPY package.json pnpm-lock.yaml tsconfig.json nest-cli.json ./RUN npm install -g pnpm @nestjs/cli # Install NestJS CLI globallyRUN pnpm installCOPY . .RUN pnpm run build authFROM node:alpine AS productionWORKDIR /usr/src/appCOPY --from=development /usr/src/app/dist ./distCMD ["node", "dist/apps/auth/main.js"]
சார்பு மேலாண்மை மூலம் NestJS டோக்கர் அமைப்பில் விடுபட்ட தொகுதியை சரிசெய்தல்
இந்த அணுகுமுறை சார்புகளை மிகவும் திறம்பட கையாள்வதில் கவனம் செலுத்துகிறது, தேவையான தொகுதிகள் எப்போதும் இருப்பதை உறுதி செய்கிறது.
// Dockerfile - Solution 2 (Install CLI during both development and production stages)FROM node:alpine AS developmentWORKDIR /usr/src/appCOPY package.json pnpm-lock.yaml tsconfig.json nest-cli.json ./RUN npm install -g pnpm @nestjs/cli # Install CLI in dev environmentRUN pnpm installCOPY . .RUN pnpm run build reservationsFROM node:alpine AS productionWORKDIR /usr/src/appCOPY package.json pnpm-lock.yaml ./RUN npm install -g pnpm @nestjs/cli --prod # Install CLI in production tooCOPY --from=development /usr/src/app/dist ./distCMD ["node", "dist/apps/reservations/main.js"]
டோக்கர் கொள்கலன்களில் சரியான தொகுதி நிறுவலை சரிபார்க்க தானியங்கு சோதனைகள்
இந்த ஸ்கிரிப்ட் வெவ்வேறு சூழல்களில் தேவையான தொகுதிகள் சரியாக நிறுவப்பட்டுள்ளதா என்பதை சரிபார்க்க Jest ஐப் பயன்படுத்தி யூனிட் சோதனைகளைச் சேர்க்கிறது.
// jest.config.js - Unit Testsmodule.exports = {testEnvironment: 'node',moduleFileExtensions: ['js', 'json', 'ts'],rootDir: './',testRegex: '.spec.ts$',transform: { '^.+\\.(t|j)s$': 'ts-jest' },coverageDirectory: './coverage',};// sample.spec.ts - Check if Nest CLI is available in the Docker containerdescribe('Nest CLI Module Check', () => {it('should have @nestjs/cli installed', async () => {const { exec } = require('child_process');exec('nest --version', (error, stdout, stderr) => {expect(stdout).toContain('Nest'); // Verify CLI presence});});});
டாக்கரைஸ் செய்யப்பட்ட NestJS சேவைகளில் முனை தொகுதிகளை கையாளுதல்
NestJS இல் மைக்ரோ சர்வீஸ் கட்டமைப்பில் பணிபுரியும் போது, ஒரு முக்கியமான அம்சம், உங்கள் சார்புகள் சரியாக நிறுவப்பட்டு, டோக்கர் கொள்கலன்களில் நிர்வகிக்கப்படுவதை உறுதி செய்வதாகும். ஆவணப்படுத்தப்பட்ட சூழல்கள் சில நேரங்களில் கையாளுதலை சிக்கலாக்கும் , குறிப்பாக பல-நிலை உருவாக்கங்களைப் பயன்படுத்தும் போது, இது போன்ற பிழைகள் ஏற்படலாம் . போன்ற உலகளாவிய தொகுதிகள் போது இந்த பிழை பொதுவாக எழுகிறது கொள்கலனில் சரியாக நிறுவப்படவில்லை.
இதைத் தவிர்க்க, தேவையான அனைத்து தொகுதிக்கூறுகளும் மேம்பாடு மற்றும் உற்பத்தி நிலைகளில் இருப்பதை உறுதிசெய்யும் வகையில் Dockerfile கட்டமைப்பது முக்கியம். ஒரு பொதுவான தீர்வு வெளிப்படையாக நிறுவ வேண்டும் போன்ற கட்டளைகளை இயக்கும் போது இரு நிலைகளிலும் விடுபட்ட பைனரிகள் தொடர்பான சிக்கல்களைத் தவிர்க்க அல்லது . நீங்கள் pnpm, npm அல்லது நூலைப் பயன்படுத்தினாலும், இந்த முறை சூழல் முழுவதும் நிலைத்தன்மையை வழங்குகிறது.
கூடுதலாக, போன்ற கருவிகளைப் பயன்படுத்துதல் டோக்கர் பட அளவு மற்றும் சார்பு நிறுவல் செயல்முறையை மேம்படுத்தலாம். இருப்பினும், டோக்கர் கொள்கலன்களுக்குள் வெவ்வேறு பேக்கேஜ் மேலாளர்களுக்கு இடையே மாறும்போது பல டெவலப்பர்கள் சிக்கல்களை எதிர்கொள்வதால், pnpm உலகளவில் நிறுவப்பட்டிருப்பதை உறுதிசெய்ய வேண்டும். உங்கள் பல-நிலை உருவாக்கங்களை கட்டமைத்தல், இதனால் அத்தியாவசிய கோப்புகள் (dist கோப்புறை மற்றும் போன்றவை ) உற்பத்தி நிலைக்கு நகலெடுக்கப்பட்டவை, வரிசைப்படுத்தல் செயல்முறையை சீரமைக்கவும், காணாமல் போன தொகுதிகள் தொடர்பான பொதுவான பிழைகளைத் தவிர்க்கவும் உதவும்.
- டோக்கரில் காணாமல் போன மாட்யூல் பிழைகளை எவ்வாறு தடுப்பது?
- நீங்கள் நிறுவுவதை உறுதிசெய்யவும் உலகளவில் பயன்படுத்தப்படுகிறது வளர்ச்சி மற்றும் உற்பத்தி நிலைகள் இரண்டிலும்.
- "@nestjs/cli/bin/nest.js தொகுதியைக் கண்டறிய முடியவில்லை" என்ற பிழையை நான் ஏன் பெறுகிறேன்?
- இந்த பிழை பொதுவாக நிகழ்கிறது உங்கள் டோக்கர் கொள்கலனில் உலகளவில் நிறுவப்படவில்லை. சேர்த்தல் இதை தீர்க்க வேண்டும்.
- நான் டோக்கர் கொள்கலன்களில் npm அல்லது pnpm ஐப் பயன்படுத்த வேண்டுமா?
- வட்டு இடத்தின் அடிப்படையில் மிகவும் திறமையானதாக இருக்கும், ஆனால் இது உலகளவில் கன்டெய்னரில் நிறுவப்பட்டுள்ளதை உறுதிசெய்யவும் சார்பு சிக்கல்களைத் தவிர்க்க.
- ஒரு டோக்கர் கொள்கலனில் பல சேவைகளை இயக்க முடியுமா?
- தொழில்நுட்ப ரீதியாக சாத்தியமானாலும், ஒவ்வொன்றையும் இயக்குவது நல்லது சிறந்த தனிமைப்படுத்தல் மற்றும் அளவிடுதல் ஆகியவற்றிற்காக அதன் சொந்த டோக்கர் கொள்கலனில் மைக்ரோ சர்வீஸ்.
- எனது டோக்கர் படத்தின் அளவை நான் எவ்வாறு குறைப்பது?
- அத்தியாவசிய கோப்புகள் மட்டுமே விரும்பும் பல-நிலை கட்டமைப்பைப் பயன்படுத்தவும் மற்றும் இறுதி தயாரிப்பு படத்திற்கு நகலெடுக்கப்படுகின்றன.
டோக்கரைஸ் செய்யப்பட்ட NestJS மைக்ரோ சர்வீஸ் சூழலில் சார்புநிலைகளை நிர்வகிப்பது சவாலானதாக இருக்கும், குறிப்பாக உலகளாவிய தொகுதிகள் விரும்பும்போது ஈடுபட்டுள்ளனர். வளர்ச்சி மற்றும் உற்பத்தி நிலைகளில் இந்த தொகுதிகளை நிறுவுவது மிகவும் முக்கியமானது.
முறையான பல-நிலை Dockerfile அமைப்புடன், காணாமல் போன தொகுதிப் பிழைகளைத் தவிர்க்கலாம் மற்றும் உற்பத்திக்கான கொள்கலனை மேம்படுத்தலாம். இது போன்ற சீராக இயங்கும் சேவைகளை இது உறுதி செய்கிறது மற்றும் சார்பு மோதல்கள் இல்லாமல்.
- இந்தக் கட்டுரை டோக்கர் ஆவணங்கள் மற்றும் சமூக மன்றங்களின் நுண்ணறிவைப் பயன்படுத்தி உருவாக்கப்பட்டது. மேலும் தகவலுக்கு, அதிகாரப்பூர்வ டோக்கர் தளத்தைப் பார்வையிடவும் டோக்கர் ஆவணம் .
- NestJS CLI மற்றும் மைக்ரோ சர்வீஸ் முறைகளைக் கையாள்வதற்கான வழிகாட்டுதலை அதிகாரப்பூர்வ NestJS ஆவணத்தில் காணலாம் NestJS ஆவணம் .
- தொகுதி சிக்கல்களைத் தீர்ப்பது பற்றிய கூடுதல் விவரங்கள் StackOverflow பற்றிய விவாதங்களிலிருந்து தழுவி எடுக்கப்பட்டது ஸ்டாக்ஓவர்ஃப்ளோ .