$lang['tuto'] = "பயிற்சிகள்"; ?> ASP.NET பயன்பாடுகளில்

ASP.NET பயன்பாடுகளில் சீரற்ற காஃப்கா செய்தி நுகர்வைத் தீர்ப்பது

Temp mail SuperHeros
ASP.NET பயன்பாடுகளில் சீரற்ற காஃப்கா செய்தி நுகர்வைத் தீர்ப்பது
ASP.NET பயன்பாடுகளில் சீரற்ற காஃப்கா செய்தி நுகர்வைத் தீர்ப்பது

காஃப்கா நுகர்வோர் வேறுபாடுகளைப் புரிந்துகொள்வது

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

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

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

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

கட்டளை பயன்பாட்டின் உதாரணம்
PartitionAssignmentStrategy இந்த சொத்து நுகர்வோருக்கு பகிர்வுகளை வழங்குவதற்கான உத்தியை அமைக்க உங்களை அனுமதிக்கிறது. CooperativeSticky மூலோபாயம் மறுசீரமைப்பின் போது குறைந்தபட்ச பகிர்வு மறுசீரமைப்பை உறுதி செய்கிறது.
EnableAutoOffsetStore தானியங்கு ஆஃப்செட் கமிட்களை முடக்குகிறது, தரவு ஒருமைப்பாட்டை உறுதிப்படுத்த செய்திகளைச் செயலாக்கிய பிறகு கைமுறையாக ஆஃப்செட்களைச் சேமிக்க டெவலப்பர் கட்டுப்பாட்டை வழங்குகிறது.
ConsumeResult.Fields தேவையற்ற புலங்களைத் தவிர்த்து நினைவக மேல்நிலையைக் குறைத்து, ConsumeResult பொருளில் எந்தப் புலங்கள் சேர்க்கப்பட்டுள்ளன என்பதைத் தனிப்பயனாக்க அனுமதிக்கிறது.
StoreOffset ஒரு செய்தியின் வெற்றிகரமான செயலாக்கத்திற்குப் பிறகு தற்போதைய ஆஃப்செட்டை கைமுறையாகச் செய்கிறது, இது சோதனைச் சாவடியில் அதிக கட்டுப்பாட்டை வழங்குகிறது.
EnablePartitionEof ஒவ்வொரு பகிர்வுக்கும் ஒரு சிறப்பு EOF சிக்னலைப் பெற நுகர்வோருக்கு உதவுகிறது, இது ஸ்ட்ரீமில் உள்ள தரவின் முடிவைக் கண்டறிய பயனுள்ளதாக இருக்கும்.
AutoOffsetReset ஆரம்ப ஆஃப்செட் இல்லாதபோது அல்லது தற்போதைய ஆஃப்செட் வரம்பிற்கு வெளியே இருந்தால் நடத்தை வரையறுக்கிறது. விருப்பங்களில் முந்தையது, சமீபத்தியது மற்றும் எதுவுமில்லை.
Assignment நுகர்வோருக்கு ஒதுக்கப்பட்ட பகிர்வுகளின் தற்போதைய பட்டியலுக்கு அணுகலை வழங்குகிறது, பகிர்வு விநியோகத்தை கண்காணிக்கவும் பிழைத்திருத்தவும் உதவுகிறது.
Rebalancer Callback பகிர்வுகள் நுகர்வோர் முழுவதும் எவ்வாறு விநியோகிக்கப்படுகின்றன என்பதை மேம்படுத்த அல்லது பிழைத்திருத்த பகிர்வு மறுசீரமைப்பின் போது தனிப்பயன் லாஜிக் செயல்படுத்தப்பட்டது.
Custom PartitionAssignmentStrategy குறிப்பிட்ட சுமை சமநிலை தேவைகளுக்கு ஏற்ப தனிப்பயன் பகிர்வு ஒதுக்கீட்டு உத்தியை செயல்படுத்த டெவலப்பர்களை அனுமதிக்கிறது.

ASP.NET இல் காஃப்கா நுகர்வோர் பணிச்சுமையை மேம்படுத்துதல்

வழங்கப்பட்ட ஸ்கிரிப்டுகள் காஃப்கா நுகர்வோர்களிடையே செய்திகளின் சீரற்ற விநியோகத்தின் சிக்கலைச் சமாளிப்பதை நோக்கமாகக் கொண்டுள்ளன. நுகர்வோர் குழு. `PartitionAssignmentStrategy` போன்ற உள்ளமைவுகளை மேம்படுத்துவதன் மூலமும், `EnableAutoOffsetStore` ஐ முடக்குவதன் மூலமும், பகிர்வுகள் எவ்வாறு ஒதுக்கப்படுகின்றன மற்றும் ஆஃப்செட்டுகள் எவ்வாறு உறுதி செய்யப்படுகின்றன என்பதற்கான சிறு கட்டுப்பாட்டைப் பெறுகிறோம். இந்த மாற்றங்கள் ஒவ்வொரு நுகர்வோரும் அதன் பகிர்வில் இருந்து வரும் செய்திகளை குறைந்தபட்ச மறுசீரமைப்பு குறுக்கீடுகளுடன், நிலைத்தன்மை மற்றும் செயல்திறனை மேம்படுத்துவதை உறுதி செய்கின்றன. உதாரணமாக, கோஆப்பரேடிவ் ஸ்டிக்கி உத்தியானது, சலசலப்பைக் குறைக்க, மறு சமநிலையின் போது நுகர்வோரை அதே பகிர்வுகளில் வைத்திருக்கும். பதிவு திரட்டல் அல்லது நிகழ்வு ஸ்ட்ரீமிங் போன்ற நிஜ உலகக் காட்சிகளில் இது மிகவும் பயனுள்ளதாக இருக்கும், அங்கு தொடர்ச்சி முக்கியமானது. 🔄

செயலாக்கத்திற்குப் பிறகு கைமுறையாக ஆஃப்செட்களைச் செய்வதற்கான தர்க்கம் மற்றொரு குறிப்பிடத்தக்க கூடுதலாகும். `EnableAutoOffsetStore` ஐ `false` என அமைப்பதன் மூலம் மற்றும் `StoreOffset` முறையைப் பயன்படுத்துவதன் மூலம், செய்திகள் வெற்றிகரமாகக் கையாளப்பட்டவுடன் மட்டுமே செயலாக்கப்பட்டதாகக் குறிக்கப்படும். இது நுகர்வோர் செயலிழப்புகள் அல்லது பயன்பாட்டு பிழைகளின் போது செய்திகளின் தடத்தை இழக்கும் அபாயத்தைக் குறைக்கிறது. ஒரு தொழிற்சாலை அசெம்பிளி லைனை கற்பனை செய்து பாருங்கள், அங்கு பணிகள் உண்மையான அசெம்பிளிக்குப் பிறகு மட்டுமே முடிந்ததாகக் குறிக்கப்படும் - இந்த முறை எந்த தயாரிப்பும் தவிர்க்கப்படுவதையோ அல்லது நகல் எடுக்கப்படுவதையோ உறுதி செய்கிறது. இதேபோல், ஸ்கிரிப்ட்டின் உள்ளமைவு தரவு இழப்பைத் தடுக்கிறது, நிகழ்நேர தரவு பைப்லைன்கள் போன்ற உயர்-செயல்திறன் காட்சிகளில் கூட நிலைத்தன்மையை உறுதி செய்கிறது. 💾

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

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

காஃப்கா நுகர்வோர் செய்தி செயலாக்கத்தை சமநிலைப்படுத்துதல்

பகிர்வு ஒதுக்கீட்டு உத்தி மற்றும் ASP.NET உள்ளமைவைப் பயன்படுத்தி தீர்வு

// Required Libraries
using Confluent.Kafka;
using System.Threading.Tasks;
using System.Collections.Generic;
using System.Linq;

// Kafka Consumer Configuration
var config = new ConsumerConfig
{
    GroupId = "consumer-group-1",
    BootstrapServers = "kafka-server:9092",
    EnableAutoOffsetStore = false,
    EnablePartitionEof = true,
    PartitionAssignmentStrategy = PartitionAssignmentStrategy.CooperativeSticky,
    AutoOffsetReset = AutoOffsetReset.Earliest
};

// Consumer Logic
using (var consumer = new ConsumerBuilder<Ignore, string>(config).Build())
{
    consumer.Subscribe("example-topic");
    var cancellationToken = new CancellationTokenSource();

    Task.Run(() =>
    {
        while (!cancellationToken.Token.IsCancellationRequested)
        {
            try
            {
                var consumeResult = consumer.Consume(cancellationToken.Token);
                // Manually commit offsets after processing
                consumer.StoreOffset(consumeResult);
            }
            catch (OperationCanceledException)
            {
                break;
            }
        }
    });

    // Clean up on application exit
    cancellationToken.Cancel();
}

உருவகப்படுத்தப்பட்ட பகிர்வு சுமைகளுடன் காஃப்கா நுகர்வோர் இருப்பைச் சோதிக்கிறது

ASP.NET காஃப்கா நுகர்வோருக்கான xUnit மற்றும் Moq உடன் அலகு சோதனை

// Required Libraries for Testing
using Xunit;
using Moq;
using Confluent.Kafka;

public class KafkaConsumerTests
{
    [Fact]
    public void TestConsumerReceivesMessagesEvenly()
    {
        var mockConsumer = new Mock<IConsumer<Ignore, string>>();
        mockConsumer.Setup(c => c.Consume(It.IsAny<CancellationToken>()))
            .Returns(new ConsumeResult<Ignore, string> { Partition = new Partition(0), Offset = new Offset(1) });

        // Simulate partitions
        var partitions = Enumerable.Range(0, 10).Select(p => new Partition(p));
        mockConsumer.Setup(c => c.Assignment).Returns(partitions.ToList());

        // Assert partitions are assigned evenly
        Assert.Equal(10, mockConsumer.Object.Assignment.Count);
    }
}

மேம்படுத்தப்பட்ட மறு சமநிலை உத்திகளை செயல்படுத்துதல்

சிறந்த பகிர்வு விநியோகத்திற்கான தனிப்பயன் மறுசீரமைப்பு

// Custom Rebalancer for Kafka Consumers
public class CustomRebalancer : IPartitionAssignmentStrategy
{
    public List<TopicPartition> AssignPartitions(
        List<ConsumerGroupMember> members,
        List<TopicPartition> partitions)
    {
        // Custom logic for fair partition distribution
        return partitions.OrderBy(p => Guid.NewGuid()).ToList();
    }
}

// Apply to Consumer Configuration
config.PartitionAssignmentStrategy = new CustomRebalancer();

காஃப்கா நுகர்வோரில் பகிர்வு சுமை வளைவை நிவர்த்தி செய்தல்

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

மற்றொரு குறிப்பிடத்தக்க கருத்தில் தாக்கம் நுகர்வோர் பின்னடைவு. ஒரு நுகர்வோர் செய்தி உற்பத்தி விகிதத்தை வைத்திருக்க முடியாதபோது பின்னடைவு ஏற்படுகிறது. காஃப்கா கருவிகளைப் பயன்படுத்தி ஒவ்வொரு பகிர்வுக்கும் நுகர்வோர் பின்னடைவைக் கண்காணித்தல் kafka-consumer-groups.sh தடைகளை அடையாளம் காண உதவும். பின்னடைவு போக்குகளை பகுப்பாய்வு செய்வதன் மூலம், மெதுவான நுகர்வோர் அல்லது சிக்கலான பகிர்வுகளை நீங்கள் குறிப்பிடலாம். தீர்வுகளில் நுகர்வோரை அளவிடுதல், செய்தி செயலாக்க தர்க்கத்தை மேம்படுத்துதல் அல்லது செயல்திறன் திறனை அதிகரிப்பது ஆகியவை அடங்கும். செயலில் பின்னடைவு கண்காணிப்பு செய்தி பின்னடைவு அபாயத்தை குறைக்கிறது மற்றும் கணினி பின்னடைவை மேம்படுத்துகிறது. 🚀

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

காஃப்கா நுகர்வோர் சுமை சமநிலை பற்றிய பொதுவான கேள்விகள்

  1. காஃப்கா நுகர்வோர் பின்னடைவு என்றால் என்ன?
  2. காஃப்கா நுகர்வோர் பின்னடைவு என்பது ஒரு பகிர்வில் கடைசியாக உறுதி செய்யப்பட்ட ஆஃப்செட்டிற்கும் மிக சமீபத்திய ஆஃப்செட்டிற்கும் உள்ள வித்தியாசம். போன்ற கருவிகள் kafka-consumer-groups.sh இந்த அளவீட்டைக் கண்காணிக்க உதவும்.
  3. எப்படி செய்கிறது PartitionAssignmentStrategy தாக்க சுமை சமநிலை?
  4. தி PartitionAssignmentStrategy பகிர்வுகள் நுகர்வோர் மத்தியில் எவ்வாறு விநியோகிக்கப்படுகின்றன என்பதை அமைப்பு தீர்மானிக்கிறது. போன்ற உத்திகள் CooperativeSticky குழப்பத்தை குறைத்து சமநிலையை மேம்படுத்துகிறது.
  5. சீரற்ற நுகர்வோர் பணிச்சுமைக்கு என்ன காரணம்?
  6. பகிர்வுகள் முழுவதும் செய்தியின் அளவு, அளவு அல்லது சிக்கலான மாறுபாடுகளால் சீரற்ற பணிச்சுமைகள் ஏற்படலாம். கண்காணிப்பு மற்றும் அளவீடுகள் இந்த ஏற்றத்தாழ்வுகளை அடையாளம் காண உதவும்.
  7. தனிப்பயன் பகிர்வு ஒதுக்கீடு சமநிலையை மேம்படுத்த உதவுமா?
  8. ஆம், தனிப்பயன் பகிர்வு ஒதுக்கீட்டு உத்தியைப் பயன்படுத்துவது, டெவலப்பர்கள் உயர்-செயல்திறன் பகிர்வுகளுக்கு முன்னுரிமை அளிப்பது போன்ற குறிப்பிட்ட பணிச்சுமை தேவைகளின் அடிப்படையில் விநியோகத்தை வடிவமைக்க அனுமதிக்கிறது.
  9. காஃப்கா நுகர்வோரைக் கண்காணிக்க என்ன கருவிகள் உள்ளன?
  10. போன்ற கருவிகள் kafka-consumer-groups.sh, JMX அளவீடுகள் மற்றும் மூன்றாம் தரப்பு கண்காணிப்பு தளங்கள் நுகர்வோர் ஆரோக்கியம், பின்னடைவு மற்றும் பகிர்வு விநியோகத்தை கண்காணிக்க முடியும்.

காஃப்கா சுமை சமநிலை பற்றிய இறுதி எண்ணங்கள்

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

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

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