सतत एकीकरण - डेटाबेस

सतत डेटाबेस एकीकरण किसी भी समय किसी प्रोजेक्ट के संस्करण नियंत्रण रिपॉजिटरी में लागू होने पर आपके डेटाबेस और डेटा के पुनर्निर्माण की प्रक्रिया है।

डेटाबेस एकीकरण में, आमतौर पर डेटाबेस एकीकरण से संबंधित सभी कलाकृतियाँ -

  • एक संस्करण नियंत्रण प्रणाली में रहना चाहिए।
  • कठोरता के लिए परीक्षण किया जा सकता है और नीति अनुपालन के लिए निरीक्षण किया जा सकता है।
  • अपनी बिल्ड स्क्रिप्ट का उपयोग करके उत्पन्न किया जा सकता है।

सतत डेटाबेस एकीकरण में शामिल होने वाली गतिविधियाँ निम्नलिखित में से कोई भी हो सकती हैं -

Drop a Database - डेटाबेस को ड्रॉप करें और संबंधित डेटा को हटा दें, ताकि आप उसी नाम से एक नया डेटाबेस बना सकें

Create a new Database - डेटा डेफिनिशन लैंग्वेज (DDL) का उपयोग करके एक नया डेटाबेस बनाएं।

Insert the Initial Data - किसी भी प्रारंभिक डेटा (जैसे, लुकअप टेबल) को डालें जो कि आपके सिस्टम को डिलीवर करते समय होने की उम्मीद है।

Migrate Database and Data - डेटाबेस स्कीमा और डेटा को समय-समय पर (यदि आप किसी मौजूदा डेटाबेस के आधार पर सिस्टम बना रहे हैं) माइग्रेट करें।

Modify Column Attributes - आवश्यकताओं और रीफैक्टरिंग के आधार पर टेबल कॉलम की विशेषताओं और बाधाओं को संशोधित करें।

Modify Test Data - कई वातावरणों के लिए आवश्यकतानुसार ऑल्टर टेस्ट डेटा।

हमारे सतत डेटाबेस उदाहरण में, हम निम्नलिखित कदम करने जा रहे हैं -

  • हम एक MS SQL सर्वर डेटाबेस और एक संबंधित तालिका बनाएंगे।

  • हम SQL सर्वर प्रबंधन स्टूडियो से एक स्क्रिप्ट बनाएंगे। डेटाबेस में हमारी तालिका सेट करने के लिए इस डेटाबेस स्क्रिप्ट का उपयोग किया जाएगा।

  • हम इस डेटाबेस तक पहुँचने के लिए अपने ASP.Net प्रोजेक्ट में एक कोड लिखेंगे।

  • हम इस स्क्रिप्ट को चलाने के लिए TeamCity में अपने प्रोजेक्ट में एक कदम बनाएंगे।

  • हम अपनी स्क्रिप्ट को Git में जाँचेंगे।

AWS डेटाबेस में ऐसा करने के लिए चरण जो पहले के खंड में बनाया गया था।

Step 1- एक MS SQL सर्वर डेटाबेस और एक संबंधित तालिका बनाएं। चलो SQL सर्वर प्रबंधन स्टूडियो खोलें और एक सरल डेटाबेस और तालिका बनाएं। डेटाबेस पर राइट-क्लिक करें और क्लिक करेंNew Database

Step 2 - इसे नाम दें Demodb और ठीक पर क्लिक करें

Step 3 - नए डेटाबेस में, राइट-क्लिक करें और एक नया टेबल बनाएं।

Step 4 - आप तालिका में अपने इच्छित कॉलम जोड़ सकते हैं।

Step 5 - तालिका सहेजें और इसे नाम दें Demotb

Step 6 - अब टेबल पर राइट क्लिक करें और मेनू विकल्प चुनें Script Table as → Drop and Create to → File

Step 7 फ़ाइल को डेमो प्रोजेक्ट फ़ोल्डर में सहेजें Sample.sql

यह डेटाबेस स्क्रिप्ट की तरह दिखेगा। यह पहले एक मौजूदा तालिका को गिरा देगा यदि वर्तमान में और फिर तालिका को फिर से बनाएं।

USE [Demodb]
GO

/****** Object: Table [dbo].[Demotb] Script Date: 3/22/2016 7:03:25 AM

******

DROP TABLE [dbo].[Demotb]
GO

/****** Object: Table [dbo].[Demotb] Script Date: 3/22/2016 7:03:25 AM

******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE TABLE [dbo].[Demotb](
   [TutorialName] [nvarchar](max) NULL,
   [TutorialID] [smallint] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

GO

Step 8 - अब चलो जल्दी से हमारे बदलें ASP.Net code नए डेटाबेस का संदर्भ लें।

Step 9 - में Tutorial.cs अपने में दर्ज करें Demo project, कोड की निम्नलिखित पंक्तियाँ जोड़ें। कोड की ये लाइनें आपके डेटाबेस से कनेक्ट होंगी, सर्वर संस्करण लेगी और नाम चर में संस्करण का नाम संग्रहित करेंगी। हम इस नाम चर को अपने में प्रदर्शित कर सकते हैंDemo.aspx.cs एक के माध्यम से फ़ाइल Response.write आदेश।

using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Linq;
using System.Web;

namespace Simple {
   public class Tutorial {
      public String Name;
      
      public Tutorial() {
         string connectionString = "Data Source = WIN-50GP30FGO75;
         Initial Catalog = Demodb;
         Integrated Security = true;";
         
         using (SqlConnection connection = new SqlConnection()) {
            connection.ConnectionString = connectionString;
            connection.Open();
            Name = connection.ServerVersion;
            connection.Close();
         }
      }
   }
}

Step 10 - निम्न कोड को इसमें जोड़ें Demo.aspx.cs यह सुनिश्चित करने के लिए फ़ाइल कि यह SQL सर्वर संस्करण प्रदर्शित करता है।

using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace Simple {
   public partial class Demo : System.Web.UI.Page {
      Tutorial tp = new Tutorial();
      
      protected void Page_Load(object sender, EventArgs e){
         Response.Write(tp.Name);
      }
   }
}

अब यदि हम कोड चलाते हैं, तो आपको ब्राउज़र में निम्न आउटपुट मिलेंगे।

Step 11- अब हम TeamCity में अपना कदम जोड़ते हैं जो डेटाबेस स्क्रिप्ट को इनवाइट करेगा। अपने प्रोजेक्ट डैशबोर्ड पर जाएं और क्लिक करेंEdit Configuration Settings

Step 12 - बिल्ड स्टेप्स पर जाएं और क्लिक करें Add build step

निम्न विकल्प चुनें (ध्यान दें कि MS SQL सर्वर क्लाइंट CI सर्वर पर स्थापित होना चाहिए)।

  • रनर टाइप कमांड लाइन होनी चाहिए।

  • एक वैकल्पिक चरण नाम दें।

  • रन पैरामीटर के साथ निष्पादन योग्य होना चाहिए।

  • कमांड निष्पादन योग्य होना चाहिए C:\Program Files\Microsoft SQL Server\110\Tools\Binn\sqlcmd.exe

  • कमांड पैरामीटर होना चाहिए -S WIN-50GP30FGO75 -i Sample.sql। जहाँ -S SQL सर्वर आवृत्ति का नाम देता है।

Step 13 - क्लिक करें।

अब यह सुनिश्चित करने की जरूरत है कि बिल्ड ऑर्डर क्या है। आपको यह सुनिश्चित करना होगा कि निर्माण क्रम निम्नानुसार है।

Step 14 - आप बिल्ड चरणों को पुनः व्यवस्थित करने के विकल्प को चुनकर बिल्ड ऑर्डर को बदल सकते हैं।

  • डेटाबेस सेटअप पहले होना चाहिए - इसलिए इसका उपयोग आपके डेटाबेस को नए सिरे से बनाने के लिए किया जाएगा।

  • अगला आपके एप्लिकेशन का निर्माण है।

  • अंत में आपका टेस्ट सेटअप।

Step 15 - अब भागो git add तथा git commit ताकि आज्ञा Sample.sqlफ़ाइल Git में जाँच की है। यह एक बिल्ड को स्वचालित रूप से ट्रिगर करेगा। और यह बिल्ड पास होना चाहिए।

अब आपके पास निरंतर डेटाबेस एकीकरण पहलू के साथ-साथ आपके चक्र में पूर्ण-निर्मित बिल्ड साइकिल है। अगले भाग में, इसे और आगे ले जाएं और कंटिन्यूअस परिनियोजन देखें।

अब जब आपने स्थानीय SQL सर्वर के साथ ऐसा किया है, तो हम उसी के लिए समान चरणों को दोहरा सकते हैं AWS MS SQLसर्वर जो पहले के एक सेक्शन में बनाया गया था। Microsoft SQL सर्वर से कनेक्ट करने के लिए, आपको निम्न सम्मेलन के माध्यम से कनेक्ट करना होगा।

Step 16- पहले यह देखें कि AWS में आपके डेटाबेस उदाहरण में निर्दिष्ट नाम क्या है। जब आप AWS में लॉग-इन करते हैं, तो डेटाबेस सेक्शन के तहत RDS सेक्शन में जाएँ।

Step 17 - अगली स्क्रीन में DB इंस्टेंस पर क्लिक करें जो सामने आता है।

step 18- अपने डेटाबेस पर क्लिक करें और समापन बिंदु का एक नोट बनाएं। निम्नलिखित स्क्रीनशॉट में, यह हैdemodb.cypphcv1d87e.ap-southeast-1.rds.amazonaws.com:1433

Step 19 - अब डेटाबेस से कनेक्ट करने के लिए SQL Server Management Studio, आपको कनेक्शन के रूप में निर्दिष्ट करने की आवश्यकता है demodb.cypphcv1d87e.ap-southeast-1.rds.amazonaws.com,1433 (उदाहरण के नाम और पोर्ट नं के बीच प्रयुक्त अल्पविराम पर ध्यान दें)।

निम्न स्क्रीनशॉट डेटाबेस का एक सफल कनेक्शन दिखाता है।

फिर आप सभी समान चरणों को दोहरा सकते हैं। Sqlcmd command निम्नानुसार होगा -

इसी कमांड को TeamCity में डेटाबेस बिल्ड स्टेप में बदला जा सकता है। जब आप निष्पादित करते हैंsqlcmd command, तालिका AWS में आपके SQL सर्वर डेटाबेस में स्वचालित रूप से बनाई जाएगी।