npm உள்ளமை சார்புகளும், அவற்றை தீர்மானிக்கும் வழிமுறையும்

ஒரு npm கூறு நீக்கப்பட்டதால் எண்ணற்ற திட்டங்களுக்கு ஏற்பட்ட பாதிப்பு குறித்து சமீபத்தில் பரவலாக பேசப்பட்டது. அதில் குறிப்பிடப்பட்ட கூறு ஏன் நீக்கப்பட்டது என்ற விவரங்களை ஒதுக்கிவிட்டு, npm என்பது என்ன, அதன் சார்புக்கூறுகள் எவ்வாறு நிறுவப்படுகின்றன என்பது குறித்து அறிந்துகொள்ள முயல்வோம்.

npm என்றால் என்ன?

ஜாவாஸ்கிரிப்ட் என்பது ஒரு நிரலாக்க மொழி. இன்றைய நவீன வலைதளங்களின் பயனர் இடைமுகத்தில் நிகழ்நேர ஊடாடும் அனுபவத்தை (Realtime interactive experience) வழங்கிட இம்மொழி பெரிதும் பயன்படுகிறது. இதற்கென பல MVC கட்டமைப்புகளும் எழுதப்பட்டுள்ளன. AngularJS, Express, React, Backbone, போன்றவை இவற்றுள் சில. இவையனைத்தும் உலாவிகளில் ஜாவாஸ்கிரிப்ட்டை இயக்குகின்றன.

2009ம் ஆண்டு வரை இம்மொழி உலாவிகளில் மட்டுமே பயன்படுத்தப்பட்டு வந்தது. ரயன் தால் என்பவரும் மேலும் சில நிரலர்களும் இணைந்து, வழங்கிகளில் (server side) ஜாவாஸ்கிரிப்ட்டை இயக்க முயன்றதன் விளைவே NodeJS எனும் அற்புத கட்டமைப்பு ஆகும். npm என்பது NodeJS Package Manager என்பதன் சுருக்கமே. அதாவது NodeJSஇன் தொகுப்புகளுக்கான மேலாளர் தான் npm.

npm தொகுப்பு என்பது என்ன?

ஜாவாஸ்கிரிப்ட் நிரலர்களிடையே நிரல் பகிர்வையும், மறுபயன்பாட்டையும் ஊக்குவிப்பதும், எளிமைப்படுத்துவதுமே npm-இன் நோக்கம். Npm-இல் பங்கிடப்பட்ட நிரலை மேம்படுத்துவதையும் எளிதாக இருக்கிறது. Npm மூலம் பகிரப்பட்ட நிரல் துண்டுகளுக்கு தொகுப்பு (package) அல்லது கூறு (module) என்று பெயர்.

npm தொகுப்பின் அடிப்படைத்தகவல்கள்:

ஒரு திட்டத்தின் பெயர், பதிப்பு, உருவாக்குநர் போன்ற அடிப்படை தகவல்களை ஒரு சிறப்பு கோப்பில் பதிவு செய்யலாம். இக்கோப்பிற்கு package.json என்று பெயர். இதில் குறைந்தபட்சம் திட்டத்தின் பெயர், பதிப்பு ஆகியவை இருக்கவேண்டும். இதிலிருக்கும் இன்னபிற தகவல்களில் நமக்கு இந்த பதிவிற்கு தேவையான தகவல் திட்டத்தின் சார்புகளைப்பற்றியதாகும். சார்புகள் (dependencies) இருவகைப்படும்.
1) devDependencies – தொகுப்பின் உருவாக்கத்திற்கு மட்டும் தேவையான சார்புகள் இப்பட்டியலில் அடங்கும்.
2) dependencies – தொகுப்பினை பிறர் பயன்படுத்தும்போது தேவைப்படும் சார்புகள் இப்பட்டியலில் அடங்கும்.

எ.கா:

{
  "name": "my_package",
  "version": "1.0.0",
  "dependencies": {
    "my_dep": "1.0.0"
  },
  "devDependencies" : {
    "my_test_framework": "3.1.0"
  }
}

இதில் “my_dep” என்ற கூறு நமது தொகுப்பின் செயல்பாட்டிற்கு தேவைப்படுகிறது. பிறர் பயன்படுத்தும்போதும் இச்சார்பு அவசியமாகிறது. ஆனால், நிரல் சோதனைக்குப் பயன்படும் “my_test_framework” என்ற கூறு நமது தொகுப்பின் உருவாக்குநர்களுக்கு மட்டுமே அவசியம், பயனர்களுக்கு இது தேவையில்லை.

npm பதிப்பெண்:

மேற்கண்ட எடுத்துகாட்டில், சார்புகளுக்கு அருகில், ஒரு எண் குறிப்பிடப்பட்டிருப்பதைக் காணலாம்.

"my_test_framework": "3.1.0"

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

{தற்போதைய அம்சங்களை பாதிக்கும் மாற்றங்கள்}.{புதிய அம்சங்கள்}.{வழுநீக்கம்}

குறிப்பிட்ட வெளியீட்டில் செய்யப்பட்டுள்ள மாற்றங்களின் தன்மையைப்பொருத்து அவற்றில் எப்பகுதி அதிகரிக்கப்படவேண்டும் என தீர்மானிக்கவேண்டும்.

npm நிறுவுமுறைகள்:

package.json-இல் கொடுக்கப்படும் சார்புகளை கணினியில் நிறுவுவதே npm-இன் பணி. கணினியில் அவற்றை எங்கே நிறுவவேண்டும் என்பதை சரியான நிறுவுமுறையை தேர்ந்தெடுப்பதன் மூலம் நாம் கட்டுப்படுத்தலாம். npm கூறுகளை நிறுவுவதில் இருவகைகள் உள்ளன.

  1. அந்த இடத்திற்குரிய நிறுவுமுறை – local installation
    திட்டத்தின் கோப்பகத்திற்குள் node_modules என்ற கோப்பகத்தை உருவாக்கி, அதற்குள்ளாக சார்பு தொகுப்புகள் நிறுவப்படும். நிரலில் require என்ற திறவுச்சொல்லைக்கொண்டு சார்பு தொகுப்பை அணுகவேண்டுமெனில், அந்த இடத்திற்குரிய நிறுவுமுறையைத் தேர்வுசெய்யவேண்டும்.
  2.  உலகளாவிய நிறுவுமுறை – global installation
    இவ்வகை நிறுவுமுறையில் NodeJS நிறுவப்பட்டுள்ள கோப்பகத்தில் சார்புகள் நிறுவப்படும். NodeJS நிறுவப்பட்டுள்ள கோப்பகத்தை prefix என்ற அமைப்பைக்கொண்டு அறியலாம். யுனிக்ஸ் கணினிகளில், {prefix}/lib/node_modules என்ற கோப்பகத்திலும், விண்டோஸ் கணினிகளில் {prefix}/node_modules என்ற கோப்பகத்திலும் சார்புகள் நிறுவப்ப்டும். கட்டளை இடைமுகத்தின் (command line interface) மூலம் சார்புகளை அணுகவேண்டுமெனில் உலகளாவிய நிறுவுமுறையைத் தேர்வுசெய்யவேண்டும்.

சார்புகளை தீர்மானிக்கும் வழிமுறை:

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

  • node_modules கோப்பக மரத்தை வட்டிலிருந்து நினைவகத்திற்க்கு ஏற்றவேண்டும்.
  • இம்மரத்தை நகலெடுக்கவேண்டும்.
  • package.json கோப்பினை எடுத்துவந்து, இன்னபிற அடிப்படை தகவல்களையும் சேகரித்து, மரத்தின் நகலில் சேர்க்கவேண்டும்.
  • மரத்தின் நகலில் பயணித்து, விடுபட்ட சார்புகளைச் சேர்க்கவேண்டும்.
    • பிற கூறுகளைப் பாதிக்காதவகையில், இயன்றவரை மரத்தின் தண்டினையொட்டியே சார்புகளைச் சேர்க்கவேண்டும்.
  • நகலினை அதன் மூலத்தோடு ஒப்பிட்டு, நகலிலிருந்து மூலத்திற்கு மாற்றத்தேவையான படிகளைப் பட்டியலிடவேண்டும்.
  • மேற்கண்ட பட்டியலிலுள்ள படிகளை, அவற்றின் ஆழமான பகுதிகளிலிருந்து செய்யத்துவங்கவேண்டும்.
    • புதிய சார்புகளை நிறுவுதல் (install), தேவையற்ற சார்புகளை நீக்குதல் (remove), சார்புகளை மேம்படுத்தல் (update), சார்புகளின் கோப்பகங்களை மேலாகவே, அல்லது கீழாகவே நகர்த்துதல் (move) ஆகியவையே படிகளின் வகைகள்.

இரு எடுத்துக்காட்டுகளுடன் இவ்வழிமுறையை புரிந்துகொள்ள முயற்சிக்கலாம். நமது தொகுப்பிற்கு “A” என்று பெயரிடலாம். அதன் சார்புகளையும், அவற்றின் உள்ளமை சார்புகளையும் இங்கே பட்டியலிடலாம்.

தொகுப்பு சார்புகள்
A B, C
B C
C D

 

வழிமுறையின் முதல் நிலையில் நமக்கு B, C என்ற சார்புகள் தேவைப்படுகின்றன. அவற்றை A-இன் node_modules கோப்பகத்தில் நேரடியாக நிறுவலாம்.

A
+--B
+--C

B-தொகுப்பு ‘C’-ஐச் சார்ந்துள்ளது. ஆனால், ஏற்கனவே அது நிறுவப்பட்டுள்ளதால், இங்கே தனியாக அதை நிறுவவேண்டியதில்லை.
C-தொகுப்பு ‘D’-ஐச் சார்ந்துள்ளது. இயன்றவரை மரத்தின் தண்டினையொட்டியே சார்புகளை சேர்க்கவேண்டும் என்பதால், இதனையும் நாம் A-இன் node_modules கோப்பகத்தில் நேரடியாகவே நிறுவலாம்.
அனைத்து சார்புகளையும் தீர்மானித்தபின், கோப்பக வடிவம் கீழ்கண்டவாறு அமைகிறது.

A
+--B
+--C
+--D

ஒருவேளை, சார்புகள் கீழ்கண்டவாறு இருப்பின்,

தொகுப்பு சார்புகள்
A B, C
B C, D@1.0.0
C D@2.0.0

இங்கே D-யின் இருவேறு பதிப்புகளை Bயும், Cயும் சார்ந்திருக்கின்றன. மேற்கண்ட வழிமுறையின் படி, முதல் நிலையில் எந்தவொரு மாற்றமும் இல்லை. A-இன் node_modulesகோப்பகத்தில், B மற்றும் C சார்புகள் நேரடியாக நிறுவப்படும்.

A
+--B
+--C

B-இன் சார்புகளில், C-ஏற்கனவே நிறுவப்பட்டுள்ளது. எனவே, D@1.0.0 மட்டும் A-இன் node_modules-இல் நேரடியாக நிறுவப்படும்.

A
+--B
+--C
+--D@1.0.0

C-இன் சார்புகளில் D உள்ளது. குறிப்பாக சொல்லவேண்டுமெனில், D-இன் இரண்டாம் பதிப்பை (D@2.0.0), C சார்ந்துள்ளது. node_modules -இல் நிறுவப்பட்டிருப்பது இதற்கு முந்தைய பதிப்பாகும். எனவே, C-இன் கோப்பகத்திற்குள் D-இன் இரண்டாம் பதிப்பு நிறுவப்படவேண்டும்.
வழிமுறையின் இறுதியில், கோப்பகம் கீழ்கண்ட வடிவத்தை பெற்றிருக்கும்.

A
+--B
+--C
   +--D@2.0.0
+--D@1.0.0

7 Comments

  1. sekar

    I appreciate you much to write this tutorial in our tamil language. But i would like to suggest you to use same english technical words like saarpu,thoguppu . It would be understand tutorial better. Thanks

    Reply
    1. கலாராணி (Post author)

      தங்கள் பரிந்துரைக்கு நன்றி. தமிழில் கலைச்சொற்களை அறிமுகப்படுத்தி பயன்படுத்துவதும் இப்பதிவின் நோக்கம் என்பதால், நேரடியாக ஆங்கிலச்சொற்களைப் பயன்படுத்தவில்லை. முதன்முறை தமிழ் கலைச்சொற்களை பயன்படுத்தும்போது அடைப்புக்குள் அதற்கு இணையான ஆங்கிலச்சொல்லையும் கொடுத்திருக்கிறேன். சார்புக்கு இணையான சொல்லையும் (dependency) சேர்த்துவிடுகிறேன். நன்றி.

      Reply
  2. karuthan

    package = தொகுப்பு என்பதில் பிழை எதுமில்லை.

    Package is a wrapping / container for the programmes.

    ————————————–
    package = பொட்டணம் / பொட்டலம்
    package manager = பொட்டண மேலாளர்
    ————————————–
    packet = பொதி
    packet header = பொதித் தலைப்பு
    encapsulation = உறைபொதியாக்கம்
    ————————————–

    Reply
  3. karuthan

    devDependencies = ஆக்கச்சார்புகள்

    Reply
    1. Kalarani

      அருமை. பரிந்துரைத்ததற்கு நன்றி.

      runtime dependencies என்பதை இயக்கச்சார்புகள் என்று எழுதலாமா?

      Reply
  4. karuthan

    runtime = இயக்குநிரல் (jre)
    runtime library = இயக்குநிரல் திரட்டு (libcmt.lib)
    runtime dependency = இயங்குநிலைச் சார்புகள்

    Reply
  5. karuthan

    global , local
    ————————–

    local install = உள்ளமைந்த நிறுவுமுறை
    global install = முழும நிறுவுமுறை
    local variable = உள்ளமைந்த மாறி
    global install = முழும மாறி
    local scope = உள்ளமைந்த வரையெல்லை
    global install = முழும வரையெல்லை

    Reply

Leave a Reply

%d bloggers like this: