پرو ہوسٹر > بلاگ > انتظامیہ > قطاریں اور JMeter: پبلشر اور سبسکرائبر کے ساتھ اشتراک کرنا
قطاریں اور JMeter: پبلشر اور سبسکرائبر کے ساتھ اشتراک کرنا
ہیلو، حبر! یہ میرا ایک سیکوئل ہے۔ پچھلی اشاعت، جس میں میں JMeter کا استعمال کرتے ہوئے قطاروں میں پیغامات رکھنے کے اختیارات کے بارے میں بات کروں گا۔
ہم ایک بڑی وفاقی کمپنی کے لیے ڈیٹا بس بنا رہے ہیں۔ درخواست کے مختلف فارمیٹس، تبدیلیاں، پیچیدہ روٹنگ۔ جانچ کے لیے، آپ کو قطار میں بہت سارے پیغامات بھیجنے کی ضرورت ہے۔ دستی طور پر ایک درد ہے جو ہر chiropractor کو سنبھال نہیں سکتا۔
تعارف
اگرچہ مجھے پہلے اس درد کو برداشت کرنا پڑا۔ یہ سب RFHUtil کے ساتھ شروع ہوا۔ طاقتور، لیکن عجیب اور خوفناک: ٹھیک ہے، آپ روس کو جانتے ہیں۔
بعض صورتوں میں ناگزیر، لیکن فعال استعمال کی صورت میں مسلسل کم ہو رہا ہے۔
اس کے ساتھ آسان ٹیسٹنگ ناممکن ہے۔
JMeter کے ساتھ سب کچھ آسان ہو گیا ہے۔ مہارت حاصل کرنے اور اس کی عادت ڈالنے کے پہلے مرحلے کے بعد، امید خوش کن امتحان کے لیے طلوع ہونے لگی۔
میں فعال طور پر JMS پبلشر اور JMS سبسکرائبر کے نمونے استعمال کرتا ہوں۔ JMS پوائنٹ ٹو پوائنٹ کے برعکس، یہ جوڑا استعمال کرنے میں زیادہ آسان معلوم ہوتا ہے۔ مثال کے طور پر، JMS سلیکٹر میں سبسکرائبر کے ساتھ آپ ایک متغیر کی وضاحت کر سکتے ہیں، لیکن پوائنٹ ٹو پوائنٹ کے ساتھ آپ نہیں کر سکتے (یا یہ طریقہ زیادہ واضح نہیں ہے)۔
نمونے تیار کرنا
جے ایم ایس پبلیشر
سیٹ اپ - ہر ایک نمونہ۔ اپاچی تجویز کرتا ہے اس اختیار کو استعمال کریں اگر قطار/موضوعات متغیرات کے ذریعے بیان کیے گئے ہوں۔
میعاد ختم ہونے (ms) = 120000۔ ناکامی کی صورت میں، ٹیسٹ کی درخواستیں 2 منٹ کے بعد قطار سے غائب ہو جائیں گی۔
غیر مستقل ڈیلیوری موڈ استعمال کریں؟ --.سچ آئی بی ایم منظوریہ مستقل موڈ اچانک ناکامی کی صورت میں منتقل شدہ پیغامات کے قابل اعتماد تحفظ کو یقینی بناتا ہے۔ اور غیر مستقل موڈ میں تیزی سے تبادلہ۔ جانچ کے مقاصد کے لیے، رفتار زیادہ اہم ہے۔
ہر پبلشر میں میں ایک jms پراپرٹی سیٹ کرتا ہوں جسے سبسکرائبر JMS سلیکٹر میں استعمال کرے گا۔ ہر جمع کرانے کے لیے، صارف کے پیرامیٹرز ٹیسٹ پلان کے عنصر میں ایک بے ترتیب قدر تیار کی جاتی ہے:
اس طرح آپ یقین کر سکتے ہیں کہ صحیح پیغام پڑھا گیا ہے۔
پہلے سے تشکیل شدہ JMS پبلیشر کا حتمی "خالی":
JMS سبسکرائبر
سیٹ اپ - ہر ایک نمونہ۔ ٹھیک ہے، آپ سمجھتے ہیں.
ٹائم آؤٹ (ms) = 100000۔ اگر 100 سیکنڈ انتظار کے بعد بھی درخواست قطار میں نہیں آتی ہے، تو کچھ غلط ہو گیا ہے۔
نمونوں کے درمیان رکیں؟ --.سچ
JMS سلیکٹر - کافی آسان ایک ٹکڑا. حتمی JMS سبسکرائبر:
منتقل شدہ پیغامات میں سیریلک حروف تہجی سے کیسے نمٹا جائے۔ JMeter میں، پہلے سے طے شدہ طور پر، پروف ریڈنگ کے بعد، یہ ٹیڑھی شکل سے ظاہر ہوتا ہے۔ اس سے بچنے اور ہمیشہ اور ہر جگہ عظیم اور طاقتور سے لطف اندوز ہونے کے لیے، آپ کو یہ کرنے کی ضرورت ہے:
JMeter "لانچر" میں JVM دلیل شامل کریں:
-Dfile.encoding=UTF-8
گرووی لائن کے ساتھ سبسکرائبر میں JSR223 پوسٹ پروسیسر شامل کریں:
prev.setDataEncoding("UTF-8")
متن بھیجیں۔
سست ترین آپشن۔ تازہ تحریری ٹیسٹوں کو ڈیبگ کرنے کے لیے موزوں ہے۔ یا ایسے معاملات کے لیے جب آپ کو کم از کم کوئی چھوٹی چیز بھیجنے کی ضرورت ہو۔ آپشن منتخب کریں۔ پیغام کا ذریعہ - Textarea اور پیغام کے باڈی کو ٹیکسٹ بلاک میں رکھیں:
فائل کی منتقلی
سب سے عام آپشن۔ زیادہ تر منظرناموں کے لیے موزوں ہے۔ آپشن منتخب کریں۔ پیغام کا ذریعہ - فائل سے اور فیلڈ میں پیغام کے راستے کی نشاندہی کریں۔ فائل - فائل کا نام:
فائل کو ٹیکسٹ فیلڈ میں منتقل کرنا
سب سے زیادہ ورسٹائل آپشن۔ زیادہ تر منظرناموں کے لیے موزوں + کو JMS Point-to-Point میں استعمال کیا جا سکتا ہے جہاں دوسرا بھیجنے کا اختیار نہیں ہے:
بائٹ سرنی کو پاس کرنا
سب سے مشکل آپشن۔ بغیر تحریف، ایس ایم ایس اور ہنگامہ آرائی کے بائٹ تک درخواستوں کی ناقابل یقین حد تک درست ترسیل کو چیک کرنے کے لیے موزوں ہے۔ آپ ڈیفالٹ JMeter میں ایسا نہیں کر پائیں گے۔ یہاں مجھے اس بارے میں ضرور بتایا گیا تھا۔
تو مجھے ڈاؤن لوڈ کرنا پڑا ذرائع اور ترمیم کریں کوڈ JMS سبسکرائبر۔
طریقہ کار میں بدل دیا گیا۔ extractContent(..) لائن:
buffer.append(bytesMessage.getBodyLength() + " bytes received in BytesMessage");
میں نے قطاروں میں پیغامات بھیجنے کے چار طریقے بیان کیے، جنہیں میں ہر روز عملی طور پر استعمال کرتا ہوں۔ مجھے امید ہے کہ یہ معلومات آپ کی زندگی کو آسان بنا دے گی۔ تسلسل میں، میں ایک ایکسچینج کی جانچ کے اپنے تجربے کے بارے میں بات کرنے کا ارادہ رکھتا ہوں جہاں ایک سرے پر قطار اور دوسرے سرے پر ڈیٹا بیس یا فائل سسٹم ہو۔