DonanımHaber

spring-boot etiketine sahip kayıtlar gösteriliyor. Tüm kayıtları göster
spring-boot etiketine sahip kayıtlar gösteriliyor. Tüm kayıtları göster

Spring ve Spring Boot'a yapılan eleştiriler 2024, Dezavantajlar


 

Spring ve Spring Boot'a yapılan eleştiriler 2024


Spring ve Spring Boot, Java tabanlı uygulamalar geliştirmek için popüler çerçeveler olmaya devam etmektedir. 2024 yılı itibarıyla yapılan eleştirilere ve gelişmelere bakıldığında, bu teknolojilerin sunduğu yeni özellikler ve mevcut zorluklar dikkat çekmektedir.


Spring Boot 3.2 ve Spring Framework 6.1, Java 21, sanal thread'ler ve CRaC (Checkpoint/Restore in Application Continuity) gibi özellikler ekleyerek gelişmeye devam etmiştir. Sanal thread'ler, geleneksel thread'lere göre programlamayı kolaylaştırsa da, I/O işlemleri veya synchronized Java kodu bölümlerinde kilitlerle çalışırken verimlilik avantajlarını kaybedebilir. Bu, bazı JDBC sürücüleri ve Spring ekosistemine dahil kütüphaneler için geçerlidir. Ayrıca, reaktif programlama ve Kotlin coroutines desteği ile asenkron görevleri koordine etme konusunda da iyileştirmeler yapılmıştır. CRaC ise uygulamaların "sıfıra ölçeklenmesini" sağlayarak, Java uygulamalarının başlangıç sürelerini önemli ölçüde azaltmaktadır. Ancak, bu özellik yalnızca Linux'ta çalışmakta ve JDK desteği gerektirmektedir​​.


Spring Boot, Spring Framework'ün geniş ekosistemini, örneğin Spring Security ve Spring Data gibi, kullanma imkanı tanır. Mockito gibi mocking frameworkleri desteği sayesinde daha sağlam uygulamalar geliştirilebilir. TestContainer'lar ile entegrasyon testlerini hızlandırma yeteneği de dikkate değer bir özelliktir. Spring Boot'un gözlemleme ve izleme yetenekleri, özellikle mikroservisler ve karmaşık uygulama mimarileri için önemlidir. Actuator Endpoints, Micrometer entegrasyonu ve loglama gibi özellikler, uygulamaların üretim ortamlarında izlenmesi ve teşhis edilmesi konusunda büyük kolaylıklar sunmaktadır​​.


GitHub'daki Spring Boot projesi, Spring ile güçlendirilmiş üretim kalitesinde uygulama ve servisler oluşturmayı kolaylaştıran, görüş sahibi bir yapı sunar. XML yapılandırma gerektirmeyen ve kod üretimi yapmayan bu yaklaşım, Spring geliştirmesi için çok daha hızlı ve erişilebilir bir başlangıç deneyimi sağlamayı amaçlamaktadır​​.


Spring Boot ve JWT entegrasyonu, REST API'lerin korunmasında önemli bir rol oynar. Spring Security ve JWT bağımlılıklarının eklenmesi, güvenli bir şekilde kimlik doğrulama ve yetkilendirme işlemlerinin yapılabilmesini sağlar​​.


Bu bilgiler ışığında, Spring ve Spring Boot'un sürekli olarak geliştirildiği ve yeni özelliklerle zenginleştirildiği; ancak sanal thread'ler, reaktif programlama ve CRaC gibi özelliklerin bazı zorluklar ve trade-off'lar içerdiği görülmektedir. Bu teknolojilerin öğrenilmesi ve kullanılması, modern Java uygulamaları geliştirme konusunda önemli avantajlar sunmaktadır.


Dezavantajlar ve yapılan eleştiriler


Spring ve Spring Boot çerçeveleri, Java tabanlı uygulama geliştirmede yaygın olarak kullanılan güçlü araçlardır; ancak, her teknoloji gibi bunlar da bazı dezavantajlar ve eleştirilere maruz kalmaktadır. 2024 yılı itibarıyla yapılan eleştirilere ve gözlemlenen dezavantajlara genel bir bakış sunalım:


Sanal Thread'ler ve Verimlilik Sorunları: Spring Boot 3.2 ve Spring Framework 6.1'in Java 21 desteğiyle gelen sanal thread'ler, programlamayı kolaylaştırırken, I/O işlemleri veya synchronized kod bölümlerinde kilitlenme sorunlarına neden olabilmektedir. Bu, verimlilik avantajlarının kaybedilmesine yol açar. Bazı JDBC sürücüleri ve Spring ekosistemine ait kütüphaneler bu sorunu yaşayabilir​​.


Reaktif Programlama Karmaşıklığı: Reaktif programlama modeli, daha ölçeklenebilir uygulamalar geliştirmeyi vaat etse de, geri çağırma yönetimi (callback management) ve hata ayıklama (debugging) işlemleri daha karmaşık hale gelebilir. Bu durum, bazı geliştiriciler için öğrenme eğrisini ve uygulama geliştirme sürecini zorlaştırabilir​​.


CRaC ile İlgili Sınırlamalar ve Trade-off'lar: CRaC (Checkpoint/Restore in Application Continuity) özelliği, uygulamaların başlangıç sürelerini önemli ölçüde azaltarak "sıfıra ölçeklenmesi" için büyük bir potansiyele sahipken, yalnızca Linux ortamında çalışması, uygulama durumlarının doğruluğunu koruma konusunda bazı endişeler ve JDK desteği gereksinimi gibi sınırlamalar sunmaktadır​​.


Yapılandırma ve Karmaşıklık: Spring ve Spring Boot, geniş bir yapılandırma ve özelleştirme seçeneği sunar. Bu durum, bazen "yapılandırma cehennemi" olarak adlandırılan, projenin karmaşıklığının artmasına ve yönetilmesinin zorlaşmasına neden olabilir. Özellikle, büyük ve karmaşık projelerde, yapılandırma dosyalarının yönetimi ve anlaşılması zor olabilir.


Öğrenme Eğrisi: Spring ekosisteminin genişliği ve derinliği, yeni başlayanlar için zorlayıcı bir öğrenme eğrisi oluşturabilir. Spring'in farklı modülleri ve özellikleri arasındaki ilişkileri anlamak ve etkili bir şekilde kullanmak zaman ve pratik gerektirir.


Bellek Kullanımı ve Başlatma Süresi: Spring uygulamaları, özellikle büyük projelerde, önemli miktarda bellek kullanımı ve uzun başlatma sürelerine sahip olabilir. Bu, özellikle mikro hizmetler ve bulut tabanlı dağıtımlar için optimize edilmiş hafif çerçeveleri tercih eden geliştiriciler için bir dezavantaj oluşturabilir.


Bu eleştiriler ve dezavantajlar, Spring ve Spring Boot'un geliştirilmesi ve kullanılması sırasında dikkate alınması gereken önemli noktaları temsil eder. Ancak, Spring ekosistemi sürekli olarak gelişmekte ve bu sorunların üstesinden gelmek için yeni özellikler ve iyileştirmeler sunmaktadır. Geliştiricilerin bu araçları seçerken projelerinin gereksinimleri ve öncelikleri doğrultusunda dengeli bir karar vermesi önemlid

Official Spring Boot Starter'ları






Starters”: Spring boot bir çok starter jar'larına sahiptir. Örnek uygulamamızda pom.xml'de görebileceğiniz gibi spring-boot-starter-parent'a pom'un parent kısmında sahibiz. Bu özel starter Maven için default değerler sağlar. spring-boot-starter-parent ayrıca bağımlılık yönetimi bölümünü sağlar; böylece "kutsanmış" sürüm etiketlerini atlayabilirsiniz. Yani diğer starter bağımlılıklar için sürüm etiketi girmenize gerek kalmaz.
Diğer starterlar projenin ihtiyaçlarına göre bağımlılıkların indirilmesini sağlarlar. Mesela web uygulaması yapacaksak spring-boot-starter-web'i pom'un bağımlılıklar kısmına ekleriz.
Eğer örnek pom'umuzda  mvn dependency:tree pluginin goal'ini çalıştırısanız ,starter-web'in ihtiyacı olduğu bağımlıkları indirdiğini ve bağımlıkılık ağacını görebiliriz.(Tomcat web server'ı ve Spring Boot kendisi dahil olmak üzere.)
Offical starter'ların yazım deseni spring-boot-starter-* şeklindedir.
Eğer inherit edilmiş bağımlılıkların versiyon numarası değiştirilmek istenirse propertilerin override edilmesi yeterlidir.


 Spring Boot application starters


spring-boot-starter : Core starter, autoconfiguration destağini içerir, ayrıca logging ve YAML içindir.

spring-boot-starter-activemq :Apache ActiveMQ kullanmak için JMS messaging starter.

spring-boot-starter-amqp   : Spring AMQP ve Rabbit MQ kullanmak için gerekli starter.

spring-boot-starter-aop : Spring AOP veAspectJ kullanarak  aspect-oriented programming kullanmak için gerekli starter.

spring-boot-starter-artemis : Apache Artemis kullarak JMS messaging sağlayan starter.

spring-boot-starter-batch : Spring batch kullanmak için gerekli starter.

spring-boot-starter-cache : Spring framework'ün cach'ini kullanmak için gerekli starter.

spring-boot-starter-cloud-connectors : Heroku ve Cloud Foundry gibi cloud platformlarına bağlanmayı kolaylaştıran Spring Cloud Connectorlerini kullanmak için gerekli starter.

spring-boot-starter-data-cassandra : Dağıtık database olan Cassandra ve Spring Data Cassandra kullanmak için gerekli starter.

spring-boot-starter-data-couchbase : Document-oriented database olan Couchbase  ve Spring Data Couchbase kullanmak için gerekli starter.

spring-boot-starter-data-elasticsearch : Elasticsearch araması ve analatik motoru ve Spring Data Elastichsearch kullanmak için gerekli starter.

spring-boot-starter-data-gemfire : Gemfire veri deposu ve Spring Data Gemfire kullanmak için gerekli starter.

spring-boot-starter-data-jpa : Hibernate ile Spring Data JPA'nın kullanılması için gerekli starter.

spring-boot-starter-data-ldap : Spring data LDAP kullanılması için gerekli starter.

spring-boot-starter-data-mongodb : Document-oriented database olan MONGODB'nin ve spring data mongodb'nin kullanılması için gerekli starter.

spring-boot-starter-data-neo4j : Graph database olan neo4j'nin ve spring data neo4j'nin kullanılması için gerekli starter.

spring-boot-starter-data-redis : Key-value şeklinde veri deposu olan redisin ve spring data redisin kullanılması için gerekli olan starter.

spring-boot-starter-data-rest : Spring data repositorylerinin Spring data rest kullanılarak rest servislere açılmasını sağlamak için kullanılan starter.

spring-boot-starter-data-solr : Bir arama platformu olan Apache Solr'un Spring Data Solr ile kullanılmasını sağlayan starter.

spring-boot-starter-freemarker  :  MVC web aplikasyonlarının View kısmında Freemarker kullanmak için gerekli starter.

spring-boot-starter-groovy-templates : MVC web aplikasyonlarının View kısmında Groovy templateleri kullanmak için gerekli starter.

spring-boot-starter-hateoas : Spring MVC ve Spring HATEOAS ile hypermedia temelli rest servisler yaratmak için kullanılan starter.

spring-boot-starter-integration : Spring integration kullanmak için gerekli starter.

spring-boot-starter-jdbc : Tomcat JDBC connection pool ile JDBC kullanmak için gerekli starter.

spring-boot-starter-jersey : spring-boot-starter-web 'a alternatif olarak JAX-RS ve Jersey ile RES:Tful web aplikasyonları inşaa etmek için gerekli starter.

spring-boot-starter-jooq : spring-bootstarter-data-jpa veyaspring-boot-starter-jdbc' ye alternatif olarak SQL veritabanlarına erişmek için kullanılan JOOQ için gerekli starter.

spring-boot-starter-jta-atomikos : Atomikos kullanarak JTA transactionların kullanılmasını sağlayan starter.

spring-boot-starter-jta-bitronix : Bitronix kullanarak JTA transactionların kullanılmasını sağlayan starter.

spring-boot-starter-jta-narayana : Spring Boot Narayana JTA Starter

spring-boot-starter-mail : Java Mail ve Spring Framework’ün email gönderme desteği için kullanılan starter.

spring-boot-starter-mobile : Web aplikasyonları yaratmak için kullanılan Spring Mobile'in kullanılması için gerekli starter.

spring-boot-starter-mustache : MVC web aplikasyonlarının View kısmında mustache templateleri kullanmak için gerekli starter.

spring-boot-starter-security : Spring security kullanmak için gerekli starter.

spring-boot-starter-social-facebook : Spring social facebook kullanmak için gerekli starter.

spring-boot-starter-social-linkedin : Spring social linkedin kullanmak için gerekli starter.

spring-boot-starter-social-twitter : Spring social twitter kullanmak için gerekli starter.

spring-boot-starter-test : Spring boot uygulamalarını test etmek için ( JUnit, Hamcrest ve Mockito) gerekli starter.

spring-boot-starter-thymeleaf  : MVC web aplikasyonlarının View kısmında thymeleaf   kullanmak için gerekli starter.

spring-boot-starter-validation : Java Bean Validasyonunu Hibernate Validotor kullarak gerçekleştirmek için gerekli starter.

spring-boot-starter-web  : Spring MVC kullanarak RESTfuşl dahil olmak üzere web uygulamaları inşaa etmek için kullanılan starter. Tomcat'i default gömülü web container olarak kullanır.

spring-boot-starter-web-services : Spring web servislerini kullanmak için gerekli starter.

spring-boot-starter-websocket  : Spring Framework'in Websocket desteğini kullanrak Websocket uygulamaları geliştirmeyi sağlayan starter.

Spring Boot production starters


spring-boot-starter-actuator : Spring boot uygulamanızı monitor ve yönetme işlemini gerçekleştiren ve production-ready özellikler taşıyan Spring boot Actuator uygulamasının kullanımını sağlayan starter.

spring-boot-starter-remote-shell : CRaSH remote shell kullanarak uygulamanızı ssh ile bağlanarak uzaktan yönetmenizi ve monitor etmenizi sağlayan starter. Spring Boot 1.5.10 sürümünden sonra deprecated olmuştur.


Spring Boot technical starters 


spring-boot-starter-jetty : spring-bootstarter-tomcat'a alternatif olarak gömülü olarak jetty servlet container'ını kullanmanızı sağlayan starter.

spring-boot-starter-log4j2 : spring-boot-starterlogging'a alternatif olarak logging işlemleri için log4j2 kullanmanıza olanak sağlayan starter.

spring-boot-starter-logging : Logback kullanrak logging işleminizi gerçekleştiren starter. Default olarak gelen logging starter budur.

spring-boot-starter-tomcat : spring-bootstarter-web starter tarafından default olarak kullanalan tomcat server'ı gömülü olarak kullanan starter.

spring-boot-starter-undertow : spring-boot-startertomcat'a alternatif olarak gömülü olarak undertow servlet container'ı kullanan starter.

İlave olarak ekstra starterlar için listeye şuradan ulaşabilirsiniz :

https://github.com/spring-projects/spring-boot/blob/v1.5.10.RELEASE/spring-boot-starters/README.adoc 

Kaynak : https://docs.spring.io/spring-boot/docs/current/reference/pdf/spring-boot-reference.pdf

Spring Boot - Notlarım - 01




@EnableAutoConfiguration anatosyonu : Class düzeyinde bir anatosyondur. Maven'e veya gradle'e eklediğiniz bağımlılıklara göre Spring tahminlemelerde bulunur ve uygulamanız için oto konfigurasyonlar yapar.
Mesela spring-boot-starter-web Tomcat ve Spring-Mvc'yi uygulamanıza ekler ve web uygulamanızı gerçekleştirdiğinizi anlayıp default oto konfigurasyonlar yapar. Spring boot starter bağımlılıklar için oto konfigurasyonlar yaparken eklediğiniz third party jarlar için de bu işlemi en iyi şekilde yapmaya çalışır.

main metodu : Java uygulamalarını başlatmak için kullanılan geleneksel yaklaşım main metodunun çalıştırılmasıdır.Spring boot uygulamasıda bu noktadan başlatırlır. main metodu SpringApplication class'ını delegate eder ve run metodunu çalıştırır.SpringApplication  class'ı uygulamayı bootstrap eder ve gömülü oto configure edilmiş tomcat'i başlatır. SpringApplication clasına main metodunun bulunduğu class primary Spring Component olarak verilir.




 4.0.0
 com.example
 myproject
 0.0.1-SNAPSHOT
 
 org.springframework.boot
 spring-boot-starter-parent
 1.5.10.RELEASE
 
 

 
 org.springframework.boot
 spring-boot-starter-web
 




import org.springframework.boot.*;
import org.springframework.boot.autoconfigure.*;
import org.springframework.stereotype.*;
import org.springframework.web.bind.annotation.*;
@RestController
@EnableAutoConfiguration
public class Example {
 @RequestMapping("/")
 String home() {
 return "Hello World!";
 }
 public static void main(String[] args) throws Exception {
 SpringApplication.run(Example.class, args);
 }
}

Starters”: Spring boot bir çok starter jar'larına sahiptir. Örnek uygulamamızda pom.xml'de görebileceğiniz gibi spring-boot-starter-parent'a pom'un parent kısmında sahibiz. Bu özel starter Maven için default değerler sağlar. spring-boot-starter-parent ayrıca bağımlılık yönetimi bölümünü sağlar; böylece "kutsanmış" sürüm etiketlerini atlayabilirsiniz. Yani diğer starter bağımlılıklar için sürüm etiketi girmenize gerek kalmaz.
Diğer starterlar projenin ihtiyaçlarına göre bağımlılıkların indirilmesini sağlarlar. Mesela web uygulaması yapacaksak spring-boot-starter-web'i pom'un bağımlılıklar kısmına ekleriz.
Eğer örnek pom'umuzda  mvn dependency:tree pluginin goal'ini çalıştırısanız ,starter-web'in ihtiyacı olduğu bağımlıkları indirdiğini ve bağımlıkılık ağacını görebiliriz.(Tomcat web server'ı ve Spring Boot kendisi dahil olmak üzere.)
Offical starter'ların yazım deseni spring-boot-starter-* şeklindedir.
Eğer inherit edilmiş bağımlılıkların versiyon numarası değiştirilmek istenirse propertilerin override edilmesi yeterlidir.


 Fowler-SR2

Offical starter listesine bu yazım'dan ulaşabilirsiniz.

Java Version : Parent pom'dan default olarak Java 1.6 set edilerek gelmektedir. Java versiyonun değiştirlmesi için de propertisi override edilmelidir.

 1.8





 mvn spring-boot:run :  spring-boot-starter-parent sebebiyle POM çok faydalı olan run goal'ine sahiptir. Projenin kök dizininde maven komutu olarak  mvn spring-boot:run yazarsak projeyi bşlatabiliriz.
$ mvn spring-boot:run



Proje ayağa kalktığına göre tarayıcıdan localhost:8080 adresine girersek Hello World! çıktısını aldığı mızı görebiliriz.

Çalıştırılabilir Jar Elde Etmek : Örneğimizi, içinde çalıştırabileceğimiz tamamen kendi başına yürütülebilir bir jar dosyası oluşturarak tamamlayalım. Çalıştırılabilir jarlar (bazen "fat jar" olarak anılır), derlenmiş sınıflarınızı içeren arşivlerdir
Kodunuzun çalıştırılacağı jar tüm bağımlılıklarıyla birlikte paketlenir.
Java iç içe geçmiş jar dosyalarına izin vermez (i.e. jar dosyalarının içinde jar dosyalarının olması).
Bu self-contained uygulamanın dağıtımında sorun olabilir.
Bu problemi çözmek için,çoğu developer“uber” jarları kullanır. Bir Uber jar basitçe bağımlı olduğu jarlardan bütün classları bir jar arşivi içine paketler
Bu yaklaşımdaki problem hangi kütüphaneyi gerçekten kullandığınızı görememenizdir. Farklı jarlarda aynı sınıfı adına sahip dosyalarda kafa karıiıklığına sebep olabilimektedir. Spring boot içi içe jar işlemindeki bu problemeri çözmek için farklı bir yaklaşım sergilemektedir. Bunu ileride daha ayrıntıılı bir şekilde inceleceğiz.
Çalıştırılabilir jar elde etmek için spring-boot-maven-plugin', pom.xml'e eklememiz gerekmekte. Bu pluginin ayarları parent pom'da default değerlerini almıştır.

dependencies bölümünün altına :

 
 
 org.springframework.boot
 spring-boot-maven-plugin
 

Not : spring-boot-starter-parent POM repackage goal'i için konfigurasyonlara sahiptir.
Eğer bu parent pom'u pom'a dahil etmediyseniz bu konfigurasyonu kendiniz deklare
etmelisizniz.
pom.xml'i kaydedip proje dizininde mvn package'i çalıştırırsanız :



target klasörünün altında yaklaşık 10 MB boyutunda myproject-0.0.1-SNAPSHOT.jar dosyasının oluştuğunu göreceksiniz.
Eğer jar içindeki dosyalara bakmak istiyorsanız :

 jar tvf target/myproject-0.0.1-SNAPSHOT.jar

komutunu kullanabilirsiniz.

Ayrıca spring-boot'un repacakeg ettiği dosya haricinde maven'in oluşturduğu orjinal jar dosyası olan
myproject-0.0.1-SNAPSHOT.jar.original dosyasını da target klasörü altında görebilirsiniz.
Uygulamayı çalıştırmak içim java -jar komutunu kullanıyoruz :


Uygulamayı kapatmak için Ctrl + C tuşlarını kullanabiliriz.


main class'ı konumlandırmak :  Main class'ı kök pakete koymak tercih edilmelidir. Mesela  eğer JPA uygulaması yazıyorsunuz @EnableAutoConfiguration anatasyonu main class'ın bukunduğu kök dizinden başlayarak paketlerde @Entity class'larını arar.
Ayrıca kök dizinde olduğunuz için componentleri tarayan @ComponentScan anatasyonuna ilave olarak base pacakage attribut'ünü girmenize gerek kalmaz.

Örnek bir layout :





package com.example.myproject;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
@Configuration
@EnableAutoConfiguration
@ComponentScan

public class Application {
 public static void main(String[] args) {
 SpringApplication.run(Application.class, args);
 }
}

Configuration Class'ı : Spring boot uygulaması yazarken Java-based konfigurasyon en populer olandır. Elbetteki bu işlem XML temelli olarak yapılabilmekte ise de, konfigurasyon yapılacak (container için bean üretme) işini class'lara  @Configuration anatasyonu koyarak gerçekleştirirz.
Birincil (primary) kanfigurasyon sınıfı adayımız main metodunun bulunduğu sınıftır.

Enable* ile başlayan anatasyonlar konfigurasyon sınıfına daha önce tanımlanmış java konfigurasyon sınıflarının otomatik olarak import edilmesine güzel bir örnektir.

Ayrıca bir konfigurasyon sınıfı diğer konfigurasyon sınıfını @Import anatasyonuyla import ederek import ettiği konfigurasyon sınıfında yaratılan beanleri kendi konfigurasyon beanlerini şekillendirmek için kullanabilirler. Ayrıca bu işlemi alternatif olarak konfigurasyon sınıfında @ComponentScan anatasyonu kullanarak diğer konfigurasyon sınıfında bulunan beanleri kullanabilme becersi sağlarlar.

Ayrıca bir configurasyon sınıfında @ImportResource anatasyonuyla XML ile konfigure edilmiş bean'lerde import edilebilmektedir.

Auto-configuration : Spring boot projeye eklediğiniz jar'ları otomatik olarak konfigure etmeye çalışır. Örneğin kendi Datasource bean'inizi tanımlarsanız varsayılan gömülü db Datasurce tanımlamanız yok olur.
Eğer uygulamanızın auto configurationlarını görmek isterseniz uygulamanızı --debug modda çalıştırıp ve loglardan auto configurationlarınızı görebilirsiniz.

Eğer bazı class'ların auto configure edilmesini istemiyorsanız @EnableAutoConfiguration anatosyonuna exclude attribute ile classın adını vererek class'ın auto configure edilmesini önleyebilirirsiniz.(Ayrıca property seviyesinde de bu işlemi yapmak mümkündür)
import org.springframework.boot.autoconfigure.*;
import org.springframework.boot.autoconfigure.jdbc.*;
import org.springframework.context.annotation.*;
@Configuration
@EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class})
public class MyConfiguration {
}


Spring Bean'leri ve Dependency Injection : Spring Boot'da beanleri tanımlamak için Spring'de kullandığımız teknikleri kullanmakta özgürüz. Genel olarak  @ComponentScan ile beanleri bulup @Autowired ile bu beanleri uygulamamıza inject ederiz.

Eğer yapınız Spring boot uygulamanızın main methodunun bulunduğu Applicaition classı ise bu sınıfa  @ComponentScan ekleyip tüm @Component, @Service, @Repository, @Controller gibi componentleri uygulamanıza register edebilirsiniz.

Tek Constructor ve field'ın final olması :  Eğer compnent'iniz tek constructor'a sahipse @Autowired'a ihtiyacınız kalmayacaktır : (İlk örenkteki final field için @Autowired kullanımına gerek kalmayacaktır)
package com.example.service;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class DatabaseAccountService implements AccountService {
 private final RiskAssessor riskAssessor;
 @Autowired
 public DatabaseAccountService(RiskAssessor riskAssessor) {
 this.riskAssessor = riskAssessor;
 }
 // ...
}

@Service
public class DatabaseAccountService implements AccountService {
 private final RiskAssessor riskAssessor;
 public DatabaseAccountService(RiskAssessor riskAssessor) {
 this.riskAssessor = riskAssessor;
 }
 // ...
}




@SpringBootApplication anatasyonu kullanımı :  Eğer sınıfınızda @Configuration, @EnableAutoConfiguration ve@ComponentScan anatasyonlarını beraber kullanıyorsanız tüm bu
üç anatasyonu karşılıyan @SpringBootApplication anatasyonunu kullanabilirsiniz. Bu şekilde kullanımda  @Configuration ve @EnableAutoConfiguration'ın attribute'larını @SpringBootApplication'da özelleştirebilirisiniz.

package com.example.myproject;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication // same as @Configuration @EnableAutoConfiguration @ComponentScan
public class Application {
 public static void main(String[] args) {
 SpringApplication.run(Application.class, args);
 }
}


Uygulamanızı Çalıştırmak : Burada oluşturduğunuz jar dosyalarınızı çalıştırmaktan bahsedeceğiz. Eğer uygulamanız web uygulaması ise içinde gömülü tomcat olacaktır. Eğer war şeklinde paketlemeyi seçtiyseniz uygulama sunucunuzun war'ı nasıl çalıştırdığına bakmanız gerekmektedir.

Eğer uygulamanızı ide'den çalıştırıyorsanız :

Uygulamanızı maven veya gradle uygulaması olarak import ettikten sonra run as java program şeklinde çalıştırırsınız. Eğer uygulamanız web uygulaması ise ve iki kez kazara çalıştırırsanız port already in use hatası alırsınız.

Paketlenmiş uygulamayı çalıştırıyorsanız :

Eğer uygulamanızı maen veya gradle ile çalıştırılabilir paket haline getirdiyseniz, uygulamanızı  java -jar komutuyla çalıştırabilirsiniz. Öreneğin :
java -jar target/myproject-0.0.1-SNAPSHOT.jar
Aynı şekilde uygulamanızı uzaktanda çalıştırabilirsiniz :
$ java -Xdebug -Xrunjdwp:server=y,transport=dt_socket,address=8000,suspend=n \ -jar target/myproject-0.0.1-SNAPSHOT.jar

Maven plugin'i ile çalıştırmak :
Uygulamanızı paketlemeden maven plugin'i ile de çalıştırabilirsiniz.
$ mvn spring-boot:run 

Gradle ile çalıştırmak :
$ gradle bootRun 

Hot swapping : Spring boot uygulamaları sade Java uygulamaları olduğundan JVM hot-swapping bu noktada etkili oluyor. JVM hot-swapping'in bytecode değişiminde swapping kabiliyetleri sınırlı olduğundan daha derin çözümler için JRebel veya Spring Loaded projeleri bu noktada daha etkili olmaktadır. Ayrıca spring-boot-devtools modülü hızlı uygulama restart'larında destek vermektedir.


Kaynak : https://docs.spring.io/spring-boot/docs/current/reference/pdf/spring-boot-reference.pdf


Rastgele İçerik

© tüm hakları saklıdır
made with by templateszoo