$lang['tuto'] = "টিউটোরিয়াল"; ?> CI জবস কাজ করছে না: 29

CI জবস কাজ করছে না: 29 সেপ্টেম্বর, 2024 এর পরে স্প্রিং বুট 2.5.3 সহ OpenFeign সংকলন সমস্যা

Temp mail SuperHeros
CI জবস কাজ করছে না: 29 সেপ্টেম্বর, 2024 এর পরে স্প্রিং বুট 2.5.3 সহ OpenFeign সংকলন সমস্যা
CI জবস কাজ করছে না: 29 সেপ্টেম্বর, 2024 এর পরে স্প্রিং বুট 2.5.3 সহ OpenFeign সংকলন সমস্যা

CI পরিবেশে স্প্রিং বুট 2.5.3 সহ অপ্রত্যাশিত সংকলন সমস্যা

29 সেপ্টেম্বর, 2024 থেকে শুরু করে, স্প্রিং বুট 2.5.3 ব্যবহারকারী ডেভেলপাররা অপ্রত্যাশিত সংকলন ত্রুটির সম্মুখীন হয়েছে বলে জানিয়েছেন। উল্লেখযোগ্যভাবে, কোডবেসে কোনো পরিবর্তন না হওয়া সত্ত্বেও এই ত্রুটিগুলি ঘটে, যার ফলে কন্টিনিউয়াস ইন্টিগ্রেশন (CI) ওয়ার্কফ্লোতে যথেষ্ট ব্যাঘাত ঘটে। এই সমস্যাটি মাভেন বিল্ডের মধ্যে নির্ভরতা রেজোলিউশনের সাথে যুক্ত বলে মনে হচ্ছে, বিশেষ করে স্প্রিং ক্লাউড নির্ভরতা ব্যবহার করে প্রকল্পগুলিকে প্রভাবিত করে।

ম্যাভেন অনুপস্থিত নির্ভরতা নির্দেশ করে ত্রুটির সাথে ব্যর্থ হওয়ার কারণে সমস্যাটি প্রকাশ পায়। বিশেষ করে, প্যাকেজ org.springframework.cloud.openfeign অস্তিত্বহীন হিসাবে পতাকাঙ্কিত। এটি OpenFeign নির্ভরতার সাথে একটি সমস্যাকে নির্দেশ করে, যার ফলে "চিহ্ন খুঁজে পাওয়া যায় না" এবং অনুপস্থিত ক্লাসগুলি উল্লেখ করার মতো ত্রুটি সৃষ্টি করে FeignClient.

এই পরিস্থিতির সম্মুখীন ডেভেলপারদের জন্য, প্রথাগত ডিবাগিং পদ্ধতি যেমন নির্ভরতা গাছ তৈরি করা বা মাভেনকে অফলাইনে যেতে বাধ্য করা কার্যকর হয়নি। এই দৃশ্যটি সম্ভবত নির্ভরতা আপডেট বা সংগ্রহস্থলের পরিবর্তনের সাথে সম্পর্কিত একটি গভীর সমস্যা প্রস্তাব করে।

এই নিবন্ধে, আমরা এই সংকলন ত্রুটিগুলির প্রকৃতি, সম্ভাব্য কারণগুলি অন্বেষণ করব এবং আপনাকে আপনার Maven বিল্ডগুলির উপর নিয়ন্ত্রণ পুনরুদ্ধার করতে সহায়তা করার জন্য কিছু সমস্যা সমাধানের পদক্ষেপগুলি সরবরাহ করব।

আদেশ ব্যবহারের উদাহরণ
mvn নির্ভরতা: ট্রি -ডভারবোস এই কমান্ডটি প্রকল্পের সমস্ত নির্ভরতার একটি বিশদ ট্রি ভিউ তৈরি করে, ভার্বোজ আউটপুট সহ সরাসরি এবং ট্রানজিটিভ নির্ভরতা দেখায়। এটি সংকলন সমস্যা সৃষ্টিকারী দ্বন্দ্ব বা অনুপস্থিত নির্ভরতা সনাক্ত করতে সহায়তা করে।
mvn নির্ভরতা: যান-অফলাইন এই কমান্ডটি সমস্ত প্রয়োজনীয় নিদর্শন ডাউনলোড করে একটি অফলাইন বিল্ডের জন্য প্রকল্প নির্ভরতা প্রস্তুত করে। এটি নিশ্চিত করে যে Maven একটি সক্রিয় ইন্টারনেট সংযোগ ছাড়াই তৈরি করতে পারে, যা নির্ভরতা রেজোলিউশন বাহ্যিক সংগ্রহস্থলের সমস্যাগুলির দ্বারা প্রভাবিত হয়েছে কিনা তা নিশ্চিত করতে কার্যকর।
mvn ক্লিন প্যাকেজ -Dmaven.repo.local=./custom-m2 প্রকল্পটি পরিষ্কার এবং পুনরায় প্যাকেজ করার জন্য ব্যবহৃত, এই কমান্ডটি একটি কাস্টম স্থানীয় সংগ্রহস্থলের পথ নির্দিষ্ট করার অনুমতি দেয়। এই পদ্ধতিটি নির্ভরতার জন্য মাভেনকে একটি নতুন অবস্থান ব্যবহার করতে বাধ্য করে ডিফল্ট সংগ্রহস্থলের সাথে সম্ভাব্য সমস্যাগুলিকে আলাদা করতে পারে।
rm -rf ~/.m2/repository/org/springframework/cloud/openfeign এই Unix/Linux কমান্ড নির্দিষ্ট OpenFeign প্যাকেজের জন্য স্থানীয় সংগ্রহস্থল ক্যাশে মুছে দেয়। এটি করার মাধ্যমে, Maven নির্ভরতা পুনরায় ডাউনলোড করতে বাধ্য হয়, সম্ভাব্যভাবে একটি দূষিত বা পুরানো শিল্পকর্মের কারণে সৃষ্ট সমস্যার সমাধান করে।
@RunWith(SpringRunner.class) এই টীকাটি স্প্রিং বুট পরীক্ষার জন্য নির্দিষ্ট। এটি ইঙ্গিত করে যে ক্লাসটি স্প্রিং-এর টেস্টিং সমর্থনের সাথে চালানো উচিত, স্প্রিং প্রেক্ষাপট শুরু করা এবং পরীক্ষার ক্ষেত্রে ফেইন ক্লায়েন্টের মতো শিমের ইনজেকশন দেওয়ার অনুমতি দেওয়া।
@অটোওয়ায়ার্ড একটি স্প্রিং টীকা স্বয়ংক্রিয়ভাবে একটি শিম ইনজেক্ট করতে ব্যবহৃত হয়, যেমন অ্যাপ্লিকেশন প্রসঙ্গ বা একটি Feign ক্লায়েন্ট উদাহরণ। স্প্রিং বুট অ্যাপ্লিকেশনে মটরশুটির অস্তিত্ব এবং কনফিগারেশন পরীক্ষা করার জন্য এটি অত্যন্ত গুরুত্বপূর্ণ।
assertNotNull(feignClient) এই JUnit দাবীটি পরীক্ষা করে যে একটি নির্দিষ্ট বিন, যেমন একটি Feign ক্লায়েন্ট, বসন্ত প্রসঙ্গে বিদ্যমান। এই বৈধতা ডিবাগিং সমস্যাগুলির জন্য গুরুত্বপূর্ণ যেখানে নির্ভরতাগুলি ভুলভাবে কনফিগার করা বা অনুপস্থিত হতে পারে।
assertEquals("https://api.example.com", client.getUrl()) এই দাবীটি পরীক্ষা করে যে Feign ক্লায়েন্টের জন্য কনফিগার করা URL প্রত্যাশিত মানের সাথে মেলে। এটি নিশ্চিত করে যে বৈশিষ্ট্য বা টীকা থেকে লোড করা কনফিগারেশন রানটাইম পরিবেশে সঠিকভাবে প্রয়োগ করা হয়েছে।

মাভেনে স্প্রিং বুট সংকলন সমস্যা বিশ্লেষণ এবং সমাধান করা

আগে দেওয়া স্ক্রিপ্টগুলি একটি জটিল সমস্যা সমাধানের উপর ফোকাস করে যেখানে মাভেন বিল্ডগুলি 29 সেপ্টেম্বর, 2024 এর পরে স্প্রিং বুট অ্যাপ্লিকেশনগুলিতে সংকলন ত্রুটিগুলির সাথে ব্যর্থ হতে শুরু করে। এই ত্রুটিগুলি অনুপস্থিতগুলির চারপাশে কেন্দ্রীভূত হয় OpenFeign নির্ভরতা, ক্লাস ঘটাচ্ছে FeignClient অনুপলব্ধ হয়ে প্রাথমিক পদ্ধতির মধ্যে নির্দিষ্ট Maven কমান্ডের মাধ্যমে এই অনুপস্থিত নির্ভরতা চিহ্নিত করা এবং সমাধান করা জড়িত। উদাহরণস্বরূপ, 'mvn নির্ভরতা: ট্রি -ডভারবোস' কমান্ডটি বিকাশকারীদের সম্পূর্ণ নির্ভরতা শ্রেণিবিন্যাসের বিস্তারিতভাবে কল্পনা করতে দেয়। এটি অত্যন্ত গুরুত্বপূর্ণ কারণ এটি ট্রানজিটিভ নির্ভরতাগুলিকে হাইলাইট করে যা অনুপস্থিত বা ভুলভাবে সমাধান হতে পারে, যা পর্যবেক্ষণ করা ত্রুটির দিকে পরিচালিত করে।

আরেকটি মূল কমান্ড, `mvn নির্ভরতা:গো-অফলাইন`, অফলাইন মোডে একটি নির্ভরতা সমাধান প্রক্রিয়া সক্ষম করে। একটি বহিরাগত সংগ্রহস্থল সমস্যাটির কারণ কিনা তা নির্ধারণের জন্য এটি বিশেষভাবে কার্যকর। CI পরিবেশে, নেটওয়ার্ক-সম্পর্কিত সমস্যা বা বাহ্যিক সংগ্রহস্থলের পরিবর্তনের ফলে নির্ভরতাগুলির রেজোলিউশনে অসঙ্গতি দেখা দিতে পারে স্প্রিং ক্লাউড ওপেনফেইন. অফলাইন মোডে ম্যাভেন চালানোর ফলে সমস্যাটি স্থানীয় ক্যাশে অনুপস্থিত বা দূষিত শিল্পকর্ম থেকে উদ্ভূত কিনা তা যাচাই করতে সহায়তা করে।

আরও, সমাধান একটি নির্দিষ্ট করা জড়িত কাস্টম স্থানীয় সংগ্রহস্থল ম্যাভেন বিল্ডের জন্য `mvn ক্লিন প্যাকেজ -Dmaven.repo.local=./custom-m2` কমান্ড ব্যবহার করে। এই পদ্ধতিটি কার্যকরভাবে মাভেনকে একটি তাজা, খালি ডিরেক্টরিতে নির্দেশ করে ডিফল্ট মাভেন সংগ্রহস্থলকে বিচ্ছিন্ন করে, এটিকে সমস্ত প্রয়োজনীয় নির্ভরতা পুনরায় ডাউনলোড করতে বাধ্য করে। এটি কোনও স্থানীয় ক্যাশিং সমস্যাগুলিকে বাতিল করতে সাহায্য করে যা একটি দূষিত বা পুরানো নির্ভরতা সংস্করণের দিকে নিয়ে যেতে পারে। উপরন্তু, স্থানীয় সংগ্রহস্থল থেকে ম্যানুয়ালি নির্দিষ্ট প্যাকেজগুলি সাফ করা, যেমন `org/springframework/cloud/openfeign`, নিশ্চিত করে যে Maven এই আর্টিফ্যাক্টগুলির একটি নতুন সংস্করণ ডাউনলোড করে।

অবশেষে, সমস্যার সমাধান নিশ্চিত করার জন্য, এটি পরিচালনা করা অপরিহার্য ইউনিট পরীক্ষা. পূর্বে প্রদত্ত স্ক্রিপ্টটি ফেইন ক্লায়েন্টের কনফিগারেশন যাচাই করার জন্য JUnit ব্যবহার করে পরীক্ষার ক্ষেত্রে প্রবর্তন করে। এই পরীক্ষাগুলি স্প্রিং বুট টেস্ট ফ্রেমওয়ার্ক ব্যবহার করে অ্যাপ্লিকেশানের প্রসঙ্গ লোড করে এবং মটরশুটির উপস্থিতি এবং কনফিগারেশন পরীক্ষা করে, যেমন ফেইন ক্লায়েন্ট। 'assertNotNull' এবং 'assertEquals'-এর মত দাবীগুলি যাচাই করতে সাহায্য করে যে বিনগুলি সঠিকভাবে শুরু করা হয়েছে এবং প্রত্যাশিত বৈশিষ্ট্যগুলির সাথে কনফিগার করা হয়েছে৷ এই পরীক্ষাগুলি বাস্তবায়নের মাধ্যমে, বিকাশকারীরা সমস্যাটি সমাধান করা হয়েছে এবং ফেইন ক্লায়েন্ট কনফিগারেশনগুলি প্রকল্পে সঠিকভাবে প্রয়োগ করা হয়েছে তা যাচাই করার জন্য একটি প্রক্রিয়া অর্জন করে।

সমাধান 1: মাভেন নির্ভরতা রিফ্রেশ করা এবং পুনঃপ্রমাণ করা

এই সমাধানটি ব্যবহার করে একটি ব্যাকএন্ড স্ক্রিপ্ট ব্যবহার করে অ্যাপাচি মাভেন স্থানীয় সংগ্রহস্থলকে রিফ্রেশ ও পুনঃপ্রমাণ করে অনুপস্থিত নির্ভরতা সমাধান করতে।

# Step 1: Generate a fresh dependency tree to inspect possible issues
mvn dependency:tree -Dverbose > dependency-tree.log

# Step 2: Run Maven in offline mode to identify missing or outdated artifacts
mvn dependency:go-offline > dependency-offline.log

# Step 3: Clear your local Maven repository (optional, ensures a clean state)
rm -rf ~/.m2/repository/org/springframework/cloud/openfeign

# Step 4: Rebuild the project with debug information and custom local repository
mvn clean package -Dmaven.repo.local=./custom-m2 -DskipTests -X > build-debug.log

# Step 5: Review the generated logs for errors and fix any missing dependencies

সমাধান 2: নির্ভরতা সমস্যা সমাধানের জন্য একটি কাস্টম ম্যাভেন সংগ্রহস্থল যোগ করা

এই সমাধানটি একটি নির্দিষ্ট উৎস থেকে সরাসরি নির্ভরতা আনতে একটি কাস্টম রিপোজিটরি URL সহ Maven কনফিগার করা জড়িত। এই কনফিগারেশনের জন্য Maven সেটিংস XML ব্যবহার করুন।

# Step 1: Create or update a custom settings.xml file in your Maven configuration directory
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0">
  <mirrors>
    <mirror>
      <id>custom-mirror</id>
      <url>https://repo.spring.io/milestone/</url>
      <mirrorOf>central</mirrorOf>
    </mirror>
  </mirrors>
</settings>

# Step 2: Specify the custom settings file during the Maven build
mvn clean install -s ./settings.xml -DskipTests

# Step 3: Validate if the dependency resolution issue is fixed

সমাধান 3: ফিন ক্লায়েন্ট কনফিগারেশন যাচাই করার জন্য ইউনিট পরীক্ষা বাস্তবায়ন করা

এই সমাধান একটি মৌলিক ইউনিট পরীক্ষা অন্তর্ভুক্ত জাভা Feign ক্লায়েন্টদের অস্তিত্ব এবং কনফিগারেশন যাচাই করতে JUnit এবং Mockito ব্যবহার করে।

@RunWith(SpringRunner.class)
@SpringBootTest
public class FeignClientTest {

  @Autowired
  private ApplicationContext context;

  @Test
  public void testFeignClientBeanExists() {
    Object feignClient = context.getBean("feignClientName");
    assertNotNull(feignClient);
  }

  @Test
  public void testFeignClientConfiguration() {
    FeignClient client = (FeignClient) context.getBean("feignClientName");
    // Add relevant assertions for configurations
    assertEquals("https://api.example.com", client.getUrl());
  }

}

মাভেন প্রকল্পগুলিতে নির্ভরতা দ্বন্দ্ব এবং আপডেটগুলি মোকাবেলা করা

একটি মূল দিক যা স্প্রিং বুট অ্যাপ্লিকেশনগুলিতে মাভেন বিল্ড ব্যর্থতায় অবদান রাখতে পারে নির্ভরতা দ্বন্দ্ব. ওপেনফেইন বা স্প্রিং ক্লাউড লাইব্রেরির মতো মূল স্প্রিং বুট নির্ভরতাগুলির ওভারল্যাপিং সংস্করণ বা বেমানান আপডেটের কারণে এই দ্বন্দ্বগুলি প্রায়শই দেখা দেয়। নির্ভরতা দ্বন্দ্বের ফলে রানটাইম ত্রুটি হতে পারে এবং কিছু ক্ষেত্রে, জটিল প্যাকেজের অনুপস্থিতি যেমন org.springframework.cloud.openfeign. এই দ্বন্দ্বগুলিকে মোকাবেলা করার জন্য সাধারণত প্রজেক্টের নির্ভরতা ব্যবস্থাপনার গভীরে ডুব দেওয়া প্রয়োজন, যাতে কোনও বিরোধপূর্ণ বা পুরানো সংস্করণ নেই তা নিশ্চিত করে।

ডেভেলপাররা অপ্রত্যাশিত বিল্ড সমস্যার সম্মুখীন হতে পারে যখন নির্দিষ্ট রিপোজিটরি বা আর্টিফ্যাক্ট নোটিশ ছাড়াই পরিবর্তন করা হয়। মাভেন প্রকল্পগুলি প্রায়শই বাহ্যিক সংগ্রহস্থলগুলির উপর নির্ভর করে, যা নির্দিষ্ট সংস্করণগুলিকে পরিবর্তন বা অবমূল্যায়ন করতে পারে, যা পূর্বে উপলব্ধ নির্ভরতাগুলিকে অস্থায়ীভাবে বা স্থায়ীভাবে অনুপলব্ধ করে তোলে। নিয়মিত প্রকল্পের পর্যালোচনা নির্ভরতা ব্যবস্থাপনা কনফিগারেশন এবং লকিং নির্ভরতা সংস্করণগুলি এই ধরনের ঝুঁকি কমাতে পারে। অতিরিক্তভাবে, একটি আপডেটেড অভ্যন্তরীণ সংগ্রহস্থল বা আয়না বজায় রাখা বিভ্রাট বা বহিরাগত সংগ্রহস্থলে অপ্রত্যাশিত পরিবর্তনের ক্ষেত্রে একটি ব্যাকআপ হিসাবে কাজ করতে পারে।

বিবেচনা করার আরেকটি অপরিহার্য দিক হল ব্যাপক ব্যবহার লগিং এবং ডিবাগিং. Maven বিল্ড ব্যর্থ হলে, ত্রুটি বার্তা সবসময় সম্পূর্ণ তথ্য প্রদান নাও হতে পারে। `-X` পতাকার মাধ্যমে ডিবাগ লগিং সক্ষম করা ডেভেলপারদের পর্দার আড়ালে কী ঘটছে তার বিশদ অন্তর্দৃষ্টি সংগ্রহ করতে দেয়। এই অনুশীলনটি অনুপস্থিত নির্ভরতা, ভুল কনফিগারেশন বা সংগ্রহস্থল অ্যাক্সেস সমস্যা সম্পর্কিত সমস্যাগুলি প্রকাশ করতে পারে। পদ্ধতিগত লগিং এবং ডিবাগিং পদ্ধতিগুলি অন্তর্ভুক্ত করা জটিল ত্রুটিগুলিকে আরও কার্যকরভাবে চিহ্নিত করতে এবং বিচ্ছিন্ন করতে সহায়তা করবে।

স্প্রিং বুটে মাভেন বিল্ড ফেইলিউর সম্পর্কে প্রায়শই জিজ্ঞাসিত প্রশ্ন

  1. কেন আমার মাভেন বিল্ড কোন কোড পরিবর্তন ছাড়াই ব্যর্থ হচ্ছে?
  2. থাকতে পারে dependency conflicts, বাহ্যিক সংগ্রহস্থলে পরিবর্তন, বা নিখোঁজ শিল্পকর্ম বিল্ড ব্যর্থতার কারণ। দৌড়ানোর কথা বিবেচনা করুন mvn dependency:tree -Dverbose সমস্যা চিহ্নিত করতে।
  3. FeignClient এর সাথে সম্পর্কিত "চিহ্ন খুঁজে পাচ্ছি না" ত্রুটিটি আমি কীভাবে ঠিক করতে পারি?
  4. নিশ্চিত করুন যে spring-cloud-starter-openfeign নির্ভরতা সঠিকভাবে সংজ্ঞায়িত এবং সমাধান করা হয়। যদি না হয়, আপনার স্থানীয় Maven সংগ্রহস্থল বা ব্যবহার রিফ্রেশ করুন mvn dependency:go-offline.
  5. `-Dmaven.repo.local` প্যারামিটারের উদ্দেশ্য কী?
  6. -Dmaven.repo.local বিকল্পটি ম্যাভেনকে একটি কাস্টম স্থানীয় সংগ্রহস্থল ব্যবহার করার নির্দেশ দেয়, যা ডেভেলপারদের ডিফল্ট সংগ্রহস্থলের সাথে সম্ভাব্য সমস্যাগুলিকে আলাদা করতে এবং নির্ভরতাগুলিকে নতুন করে ডাউনলোড করতে দেয়।
  7. আমি কীভাবে মাভেনে অনুপস্থিত নির্ভরতাগুলি পরিচালনা করব?
  8. ব্যবহার করে নির্দিষ্ট নির্ভরতার জন্য স্থানীয় ক্যাশে সাফ করুন rm -rf ~/.m2/repository/path-to-dependency এবং ম্যাভেনকে পুনরায় ডাউনলোড করতে বাধ্য করার জন্য আপনার প্রকল্পটি পুনর্নির্মাণ করুন।
  9. Maven বিল্ড সমস্যা ডিবাগ করার সময় অফলাইন মোড কেন সহায়ক?
  10. ব্যবহার করে অফলাইন মোডে Maven চালানো হচ্ছে mvn dependency:go-offline প্রয়োজনীয় নির্ভরতা স্থানীয়ভাবে ক্যাশে করা হয়েছে কিনা তা যাচাই করতে সাহায্য করে এবং বিল্ডটিকে বাহ্যিক পরিবর্তন বা নেটওয়ার্ক সমস্যা থেকে বিচ্ছিন্ন করে।

নির্ভরতা সংক্রান্ত বিষয়ে চূড়ান্ত চিন্তাভাবনা:

যখন অপ্রত্যাশিত সংকলন ত্রুটি দেখা দেয়, তখন বিকাশকারীদের নির্ভরতা দ্বন্দ্ব সনাক্তকরণ, অনুপস্থিত প্যাকেজগুলি এবং সংগ্রহস্থলের সমস্যাগুলি সমাধানের উপর ফোকাস করা উচিত। যেমন কমান্ড ব্যবহার করে mvn নির্ভরতা: গাছ এবং নির্দিষ্ট আর্টিফ্যাক্টগুলি সাফ করা গুরুত্বপূর্ণ অন্তর্দৃষ্টি দিতে পারে।

মজবুত CI পাইপলাইন বজায় রাখা এবং পুঙ্খানুপুঙ্খ পরীক্ষার পদ্ধতি ব্যবহার করা নিশ্চিত করে যে প্রকল্পগুলি বাহ্যিক নির্ভরতার পরিবর্তনের জন্য স্থিতিস্থাপক থাকে। ব্যাপক নির্ভরতা ব্যবস্থাপনার সাথে পদ্ধতিগত ডিবাগিং একত্রিত করে, বিকাশকারীরা স্প্রিং বুট অ্যাপ্লিকেশনগুলিতে বিল্ড ব্যর্থতাগুলি সক্রিয়ভাবে সমাধান করতে পারে।

Maven সংকলন সমস্যা সমাধানের জন্য উত্স এবং রেফারেন্স
  1. এই নিবন্ধটি সমস্যা সমাধানের নির্দেশিকা এবং অফিসিয়াল Maven ওয়েবসাইটে উপলব্ধ ডকুমেন্টেশনের উপর ভিত্তি করে তৈরি করা হয়েছিল। নির্ভরতা রেজোলিউশন কমান্ড এবং ব্যবহার সম্পর্কে আরো বিস্তারিত জানার জন্য, দেখুন মাভেন গাইড .
  2. স্প্রিং বুট নির্ভরতা কনফিগারেশন এবং সমস্যা সমাধানের তথ্য অফিসিয়াল স্প্রিং বুট ডকুমেন্টেশন থেকে উল্লেখ করা হয়েছে, এখানে উপলব্ধ স্প্রিং বুট রেফারেন্স ডকুমেন্টেশন .
  3. ওপেনফেইন সহ স্প্রিং ক্লাউড নির্ভরতা পরিচালনার জন্য সমাধান এবং কৌশলগুলি স্প্রিং ক্লাউড অফিসিয়াল ডকুমেন্টেশন থেকে নেওয়া হয়েছিল। এই গাইড অ্যাক্সেস করুন বসন্ত মেঘ প্রকল্প পাতা .