ServBay में Memcached का उपयोग करके PHP डेटा कैशिंग
ServBay एक शक्तिशाली लोकल वेब डेवलपमेंट वातावरण है, जिसमें उच्च प्रदर्शन वाला Memcached सॉफ़्टवेयर पैकेज (Memcached सर्वर) और संबंधित PHP एक्सटेंशन पहले से इंस्टॉल होते हैं। इससे डेवलपर्स अपने PHP एप्लिकेशन्स में कुशल डेटा कैशिंग लागू कर सकते हैं और एप्लिकेशन के प्रदर्शन में उल्लेखनीय सुधार कर सकते हैं।
इस लेख में हम विस्तार से देखेंगे कि ServBay में Memcached और इसके संबंधित PHP एक्सटेंशन को कैसे सुनिश्चित और उपयोग करें।
Memcached का परिचय
Memcached एक उच्च प्रदर्शन, वितरित इन-मेमोरी ऑब्जेक्ट कैश सिस्टम है। यह डेटा (जैसे डेटाबेस क्वेरी परिणाम, API प्रतिक्रिया, पेज फ्रैगमेंट आदि) को अस्थायी रूप से मेमोरी में स्टोर करके बैकएंड डेटा स्टोरेज (जैसे डेटाबेस) तक पहुँच को कम करता है, जिससे डायनमिक वेब एप्लिकेशन की प्रतिक्रिया गति और थ्रूपुट में वृद्धि होती है।
मुख्य विशेषताएँ
- उच्च प्रदर्शन: डेटा मेमोरी में स्टोर होता है, जिससे रीड/राइट बहुत तेज़ होता है।
- वितरित प्रणाली: यह कई सर्वरों के बीच वितरित कैश पूल बना सकता है, जिससे स्केलेबिलिटी आसानी से बढ़ती है।
- सरल और उपयोग में आसान: सिम्पल प्रोटोकॉल, ढेर सारे क्लाइंट लाइब्रेरी, और आसान इंटीग्रेशन।
- डेटाबेस लोड कम करता है: विशेषकर उच्च-ट्रैफिक वाले अनुप्रयोगों में डेटाबेस पर आने वाले बोझ को काफी कम कर देता है।
memcache
और memcached
PHP एक्सटेंशन में अंतर
PHP में, Memcached सर्वर से कनेक्ट करने के लिए दो सामान्य एक्सटेंशन हैं: memcache
और memcached
। नाम में समानता के बावजूद, ये अलग-अलग एक्सटेंशन हैं और इनकी API एवं फीचर्स अलग हैं:
memcache
एक्सटेंशन:- यह एक पुराना PHP एक्सटेंशन है।
- मुख्यतः प्रक्रिया-आधारित API देता है (
memcache_connect()
,memcache_set()
आदि)। - बेसिक फीचर्स हैं; कुछ उन्नत फीचर्स (जैसे consistent hashing) का सपोर्ट सीमित है।
memcached
एक्सटेंशन:- यह एक नया PHP एक्सटेंशन है (libmemcached लाइब्रेरी पर आधारित)।
- ऑब्जेक्ट ओरिएंटेड API देता है (
Memcached
class)। - अधिक फीचर्स जैसे consistent hashing, binary protocol, SASL authentication, flexible serialization आदि सपोर्ट करता है।
- आमतौर पर,
memcached
एक्सटेंशन को प्राथमिकता दी जाती है क्योंकि यह अधिक शक्तिशाली और अधिक सक्रिय रूप से मेन्टेन होता है।
ServBay डिफ़ॉल्ट रूप से अधिक फीचर्स वाला memcached
PHP एक्सटेंशन प्रदान करता है और इसी के लिए अनुशंसा करता है।
ServBay में Memcached सॉफ़्टवेयर पैकेज और PHP एक्सटेंशन
ServBay में न केवल Memcached सर्वर एक मैनेज किए जा सकने वाले सॉफ़्टवेयर पैकेज के रूप में शामिल है, बल्कि इसके द्वारा समर्थित सभी PHP वर्जन के लिए memcached
PHP एक्सटेंशन भी पहले से इंस्टॉल और डिफ़ॉल्ट रूप से सक्षम रहता है।
इसका अर्थ है कि आम तौर पर, ServBay स्थापित करते ही Memcached सर्वर और PHP एक्सटेंशन कार्य के लिए तैयार रहते हैं — आपको PHP के लिए कोई अतिरिक्त कॉन्फ़िगरेशन या कंपाइलिंग करने की जरूरत नहीं।
Memcached सॉफ़्टवेयर पैकेज की स्थिति जांचें:
आप ServBay के मुख्य इंटरफ़ेस या पैकेज मैनेजमेंट इंटरफ़ेस में Memcached
पैकेज देख सकते हैं और सुनिश्चित कर सकते हैं कि इसकी स्थिति "चालू" हो। यदि नहीं, तो उसे स्टार्ट करने का प्रयास करें।
जांचें कि memcached
PHP एक्सटेंशन लोड हुआ है या नहीं:
किसी विशेष PHP संस्करण में memcached
एक्सटेंशन लोड होने की जांच का सबसे आसान तरीका है phpinfo()
फंक्शन:
ServBay की वेबसाइट रूट डायरेक्टरी (डिफ़ॉल्ट
/Applications/ServBay/www
) मेंinfo.php
नाम से एक नया PHP फ़ाइल बनाएँ।फ़ाइल में निम्नलिखित जोड़ें:
php<?php phpinfo(); ?>
1
2
3ServBay के द्वारा कॉन्फ़िगर की गई लोकल साइट से यह फ़ाइल खोलें (उदाहरणस्वरूप यदि आपकी साइट का डोमेन
servbay.demo
है, तो ब्राउज़र में खोलेंhttp://servbay.demo/info.php
)।खुले हुए
phpinfo
पेज पर "memcached" सर्च करें। यदि वहाँ "memcached" के नाम से एक सेक्शन दिखाई देता है और उसमें कॉन्फ़िगरेशन और वर्शन इन्फॉर्मेशन आती है, तो एक्सटेंशन सफलतापूर्वक लोड हुआ है।
PHP कोड में Memcached का उपयोग
Memcached सर्वर चालू होने और memcached
PHP एक्सटेंशन लोड हो जाने के बाद, आप अपने PHP एप्लिकेशन में Memcached
class का इस्तेमाल करके सर्वर से कनेक्ट कर सकते हैं और कैश ऑपरेशन चला सकते हैं।
Memcached सर्वर सामान्यतः localhost
के पोर्ट 11211
पर चलता है।
उदाहरण कोड
यह एक साधारण PHP कोड उदाहरण है, जिसमें दिखाया गया है कि कैसे Memcached
class का उपयोग कर लोकल Memcached सर्वर से जुड़ें और डेटा सेट/गेट करें:
निम्नलिखित कोड को ServBay वेबसाइट डायरेक्टरी के भीतर किसी PHP फ़ाइल (जैसे /Applications/ServBay/www/memcached_test.php
) में सहेजें:
php
<?php
// Memcached सर्वर की जानकारी
$memcached_host = 'localhost';
$memcached_port = 11211;
// Memcached क्लाइंट इंस्टेंस बनाएं
$memcached = new Memcached();
// क्लाइंट कनेक्शन पूल में Memcached सर्वर जोड़ें
// addServer() का रिटर्न वैल्यू यह दर्शाता है कि सर्वर सफलतापूर्वक जोड़ दिया गया, न कि कनेक्शन सफल हुआ
if (!$memcached->addServer($memcached_host, $memcached_port)) {
// नोट: addServer में असफलता आमतौर पर कॉन्फ़िग्रेशन समस्या होती है, न कि सर्वर से कनेक्टिविटी की समस्या
die("Memcached सर्वर को क्लाइंट कनेक्शन लिस्ट में जोड़ने में विफल। कृपया होस्ट और पोर्ट कॉन्फ़िगरेशन जांचें।");
}
// कनेक्शन टेस्ट के लिए एक अस्तित्वहीन की प्राप्त करने का प्रयास करें (वैकल्पिक, लेकिन अनुशंसित)
// get() यदि की नहीं मिलती या कनेक्शन में समस्या है, तो false या खाली ऐरे लौटाता है
// Memcached::getResultCode() से विस्तृत स्टेटस कोड मिल सकता है
$test_key = 'servbay_memcached_connection_test';
$memcached->get($test_key); // एक न मिलने वाली की पाने का प्रयास
$result_code = $memcached->getResultCode();
if ($result_code !== Memcached::RES_NOTFOUND && $result_code !== Memcached::RES_SUCCESS) {
// यदि RES_NOTFOUND या RES_SUCCESS नहीं आया, तो संभवतः कनेक्शन में दिक्कत है
// नोट: रिस्पॉन्स RES_SUCCESS तब भी आ सकता है जब वैल्यू खाली हो
// कनेक्शन जांचने के लिए और भी अधिक लॉजिक की जरूरत हो सकती है या क्लाइंट के व्यवहार पर निर्भर करेगा
// लोकल डेवेलपमेंट के लिए, प्राय: addServer का सफल होना और आगे की ऑपरेशन में कोई त्रुटि न आना कनेक्शन की पुष्टि के लिए पर्याप्त है
echo "सावधानी: Memcached सर्वर से कनेक्शन में संभवतः समस्या है। Result Code: " . $result_code . "<br>";
// प्रॉडक्शन कोड में अधिक विस्तृत एरर हैंडलिंग जरूरी हो सकती है
} else {
echo "Memcached सर्वर ({$memcached_host}:{$memcached_port}) से सफलतापूर्वक कनेक्ट हुआ।<br>";
}
// --- कैश ऑपरेशन उदाहरण ---
// जो डेटा कैश करना है
$key = 'user_profile_1234';
$data = [
'id' => 1234,
'username' => 'servbay-demo',
'email' => '[email protected]',
'status' => 'active'
];
$expiration = 3600; // कैश समाप्ति समय, सेकंड्स में (यहाँ 1 घंटा)
// कैश में डेटा सेट करें
// set() रिटर्न करता है true/false कि ऑपरेशन सफल है या नहीं
if ($memcached->set($key, $data, $expiration)) {
echo "डेटा सफलतापूर्वक Memcached में कैश किया गया, key '{$key}', समाप्ति समय {$expiration} सेकंड।<br>";
} else {
echo "डेटा कैश करने में विफल!<br>";
// विफलता का कारण $memcached->getResultCode() से देख सकते हैं
echo "Result Code: " . $memcached->getResultCode() . "<br>";
}
// कैश से डेटा प्राप्त करने का प्रयास
echo "कैश से डेटा प्राप्त करने का प्रयास कर रहे हैं...<br>";
$cachedData = $memcached->get($key);
if ($cachedData !== false) { // Memcached::get() अगर कैश मिस या कोई त्रुटि होगी तो false लौटाएगा
echo "सफलतापूर्वक कैश से डेटा मिला:<br>";
echo "<pre>";
print_r($cachedData);
echo "</pre>";
} else {
echo "कैश मिस या प्राप्ति में असफलता, key '{$key}'।<br>";
echo "Result Code: " . $memcached->getResultCode() . "<br>";
}
// कैश समाप्ति के बाद के स्थिति को दर्शाना (मान लें समय बीत चुका है)
// आमतौर पर प्रॉडक्शन में आप $cachedData को false होने पर स्रोत (जैसे डेटाबेस) से डेटा लाते हैं और फिर उसे दोबारा कैश करते हैं।
// उदाहरणः कैश डेटा मिटाएं
/*
echo "कैश डेटा को हटाने का प्रयास कर रहे हैं...<br>";
if ($memcached->delete($key)) {
echo "डेटा कैश से सफलतापूर्वक हटाया गया, key '{$key}'।<br>";
} else {
echo "कैश डेटा को हटाने में विफल!<br>";
echo "Result Code: " . $memcached->getResultCode() . "<br>";
}
// हटाए गए डेटा को दोबारा पाने का प्रयास
echo "हटाए गए डेटा को दोबारा पाने का प्रयास कर रहे हैं...<br>";
$cachedDataAfterDelete = $memcached->get($key);
if ($cachedDataAfterDelete !== false) {
echo "डेटा मिला (डिलीट विफल रहा):<br>";
print_r($cachedDataAfterDelete);
} else {
echo "डेटा अब कैश में नहीं है (उम्मीद के अनुसार)।<br>";
echo "Result Code: " . $memcached->getResultCode() . "<br>";
}
*/
// उदाहरणः सभी कैश को साफ़ करें (सावधानी से उपयोग करें!)
/*
echo "सभी कैश को साफ़ करने का प्रयास कर रहे हैं...<br>";
if ($memcached->flush()) {
echo "सभी कैश डेटा साफ़ कर दिए गए।<br>";
} else {
echo "कैश साफ़ करने में विफल!<br>";
echo "Result Code: " . $memcached->getResultCode() . "<br>";
}
*/
?>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
ServBay के लोकल वेबसाइट से memcached_test.php
खोलकर आप कनेक्शन की स्थिति, डेटा सेट/गेट के परिणाम आदि देख पाएँगे।
ध्यान देने योग्य बातें
- सुनिश्चित करें कि Memcached सॉफ़्टवेयर पैकेज ServBay में चालू हो।
- Memcached डिफ़ॉल्ट रूप से
127.0.0.1
(याlocalhost
) के पोर्ट11211
पर सुनता है — सामान्य परिस्थिति में बदलाव की ज़रूरत नहीं। - PHP से कनेक्शन विफल हो तो Memcached की स्थिति और लोकल कनेक्शन पर फायरवॉल ब्लॉकिंग की जांच करें।
Memcached
क्लास काaddServer
मेथड सिर्फ़ सर्वर को कनेक्शन पूल में जोड़ता है, यह तुरंत पर्सिस्टेंट कनेक्शन या सर्वर उपलब्धता की जांच नहीं करता। असली कनेक्शन व ऑपरेशनget
,set
आदि मेथड के कॉल से होते हैं। इन ऑपरेशन्स के रिटर्न वैल्यू याgetResultCode()
से सफलता या असफलता की पुष्टि करें।
सारांश
ServBay, डेवलपर्स को Memcached को अत्यंत आसानी से उपयोग करने का साधन देता है। इसमें इंटरग्रेटेड Memcached पैकेज और प्रीइंस्टॉल्ड व डिफ़ॉल्ट रूप से सक्रिय memcached
PHP एक्सटेंशन के साथ, आपको कोई भी जटिल इंस्टॉलेशन या सेटअप की जरूरत नहीं — आप सीधे अपने लोकल विकास वातावरण में Memcached द्वारा तेज़ डेटा कैशिंग सक्षम कर सकते हैं, जिससे उच्च प्रदर्शन PHP एप्लिकेशन्स के निर्माण को सशक्त आधार मिलता है।