Javascript is required

portfolio.rottigni.tech

फ़्रंट एंड

  • Nuxt3

  • TailwindCSS 5

  • Typescript

बैकएंड

  • SQLite3

  • Prisma

  • Nitro

8 बोली

6 रंग

रंग

  • एसएसआर (सर्वर साइड रेंडरिंग)
  • TSX सूची, टोस्ट, मोडल रेंडरिंग
  • एसईओ के अनुकूल पारिस्थितिकी तंत्र
  • विटेस्ट द्वारा पूरी तरह से यूनिट-परीक्षण किया गया
  • नाइट्रो एपीआई रिज़ॉल्वर
  • पूर्ण ब्राउज़र संगतता
  • SQLite3 DB स्रोत
  • Linting Eslint + Stylelint + Prettier
मुख्य निर्भरताएँ
बोने की व्यवस्था

हर दिन आधी रात को, मेरे पोर्टफोलियो का SQLite डेटाबेस स्वचालित रूप से मेरे VPS पर समर्पित डॉकर सेवा के माध्यम से अपडेट हो जाता है।

यह सेवा एक Node.js क्रॉन जॉब चलाती है जो Vimeo, GitHub, GitLab API, puppeteers web scraping, और स्थैतिक स्रोतों सहित विभिन्न स्रोतों से डेटा को कंपोज़ और अपडेट करती है।https://storage.rottigni.tech/.

अद्यतन SQLite डेटाबेस का उपयोग करने के लिए लागू होते हैं@prisma/clientऔर VPS फाइल सिस्टम और Nuxt3 कंटेनर दोनों में परिलक्षित होते हैं, जो डॉकर वॉल्यूम के माध्यम से अपडेट रहते हैं।

सीडर कंटेनर सीडिंग प्रक्रिया के दौरान लॉग उत्पन्न करता है, जिसमें लॉग.लॉग, एरर.लॉग और डीबग.लॉग शामिल हैं, जो मेरे निजी रिपॉजिटरी में भेजे जाते हैंhttps://s3.rottigni.tech/portfolio.rottigni.tech/seeding/logs/प्रत्येक रन पर।

कंटेनर प्रत्येक सीड ऑपरेशन से पहले SQLite3 डेटाबेस का बैकअप भी बनाएगा, इसे स्टोर करेगाhttps://s3.rottigni.tech/portfolio.rottigni.tech/seeding/backup/,, डेटा सुरक्षा सुनिश्चित करने के लिए।

सीडर की एक उल्लेखनीय विशेषता कैश्ड डेटा प्रदाता के रूप में मेरे निजी स्टोर का उपयोग करने की क्षमता है।

जब सीडर किसी स्रोत प्रदाता से डेटा का अनुरोध करता है, तो यह मेरे संग्रह में एक नई JSON API प्रतिक्रिया फ़ाइल अपलोड करता है जिसमें इसके फ़ाइल नाम में ऑपरेशन का UTC टाइमस्टैम्प होता है

(https://s3.rottigni.tech/portfolio.rottigni.tech/seeding/history/)

कैशिंग सक्षम होने पर, सीडर मूल प्रदाता से डेटा का अनुरोध करने के बजाय संग्रह से नवीनतम फ़ाइल पढ़ता है।

यह सब सीडिंग रूट डायरेक्टरी में स्थित सीड.कॉन्फिग.टीएस फाइल के माध्यम से ऑर्केस्ट्रेटेड है।

यह फ़ाइल निर्दिष्ट करती है कि किन निकायों और संबंधों को पॉप्युलेट किया जाना चाहिए, किसे कैश किया जाना चाहिए, और वे पथ जहां डेटा लोड किया जाना चाहिए।

कुल मिलाकर, यह सिस्टम डेटा सुरक्षा सुनिश्चित करते हुए और कैश्ड डेटा के उपयोग के माध्यम से मूल विक्रेताओं के अनुरोधों को कम करते हुए मेरे पोर्टफोलियो के SQLite डेटाबेस को स्वचालित अपडेट प्रदान करता है।

Coded withby Lorenzo Rottigni