29 Temmuz 2016 Cuma

Tomcat üzerinde Connection Pool nasıl kullanılır?

Merhaba, bu yazımda Connection Pool nedir, Tomcat üzerinde nasıl connection pool oluşturulur, neden oluşturulur gibi başlıklara değineceğim.

Connection(Bağlantı) nedir?
Connection bir veritabanı üzerinde işlem yapabilmek için açtığımız bağlantıdır.

Bağlantı açarken nelere dikkat etmemiz lazım?
Kaynakların verimli kullanılması açısından DB(database) ye bağlanıp işlem yaptıktan sonra bağlantıyı kapatmamız lazım. Tüm program döngüsü boyunca ortalıkta boş boş takılan bağlantılar olmasını istemeyiz. Bu durumdada her işlem için bağlantı açmamız gerekecektir. Bağlantı açma ise biraz masraflıdır (yaklaşık 10ms), özellikle geniş trafiğe sahip sistemleri düşündüğümüzde sürekli bağlantı açma-kapama db mizi sıkıntıya sokabilir.

Peki en ideal bağlantı açma yöntemi nedir?
Connection Pool dediğimiz kavram burada devreye giriyor. Çevirisidende anlaşılacağı üzere bağlatılarımızın depolandığı bir havuz. Bu havuzun çalışma mantığıda şöyle.

  1. Tomcat serverimiz çalıştırıldığında belirtilen sayı kadar bağlantı açar. (20,30,40...)
  2. Client işlem yapmak istediğinde bağlantıları artık db den değilde tomcat üzerinden ister.
  3. İşlemi bitince bağlantıyı tekrardan havuza yollar ve kaynakların verimli kullanılmasını sağlar.

 
Bağlantı istekleri Pool üzerinden yapılır.


Anlattığım gibi server ayağa kalktığında 1 defaya mahsus olarak gerekli bağlantılar açılır ve depolanır. Sonraki erişimler yaklaşık 3ms sürecektir. Kabaca işlem başına 7ms kardayız. 

Tomcat Server üzerinden pool nasıl ayarlanır?

1. tomcat/contex.xml dosyamıza datasource tanımlaması yapılır. 


    <ResourceLink type="javax.sql.DataSource" name="jdbc/poolTest" global="jdbc/poolTest"/>
    // verdiğimiz name üzerinden erişim sağlayacağız.

2. tomcat/server.xml dosyamıza pool bilgilerini gireriz. 
// GlobalNamingResources tag ı arasına eklenecek.

 <Resource type="javax.sql.DataSource"
       auth="Container"
        name="jdbc/poolTest"
        driverClassName="com.mysql.jdbc.Driver"
       factory="org.apache.tomcat.jdbc.pool.DataSourceFactory"
        url="jdbc:mysql://127.0.0.1:3306/testDB"  // db adresimiz
        username="testUser" // db username
        password="testUser" // db password
  initialSize="10"  // standart bağlantı sayısı
        maxActive="20"  // max bağlantı sayısı
        maxIdle="10"  // max boş bağlantı sayısı
        minIdle="5"/>  // min boş bağlantı sayısı

3. Projemizin web.xml dosyasına poolu tanıtalım.

  <resource-ref>
<description>DB Connecion Pool Source</description>
<res-ref-name>jdbc/testDB</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>

Bu eklemelerden sonra server çalıştığı esnada bağlantılar açılacaktır. 



 ** Benim Veritabanım üzerinde açık bağlantılar. Ve gördüğünüz gibi kurtlar hep uyku modunda ve atıl kurt dememizi bekliyorlar. Mysql Workbench ile bakılmıştır. İsimler değişiklik gösterebilir.

Son olarak bu bağlantıları nasıl kullancağımıza bakalım. Java projelerimizde bu bağlantıları çağırabilmek için verileri serverden okuyup bir datasource içinde tutacağız. Daha sonra bu kaynaktan bağlantılarımızı isteyip kullanabiliriz.


private Connection getConnectionFromPool() throws NamingException, SQLException {
Context envCtx = (Context) new InitialContext();
// Look up our data source
DataSource ds = (DataSource) envCtx.lookup("java:comp/env/jdbc/testDB");
Connection conn = ds.getConnection();
logger.debug("Connection taken");
return conn;
}

Son olarak bağlantılar ile işiniz bittikten sonra havuza geri göndermeyi unutmayın. conn.close() ile kapatabilirsiniz. Sonraki yazımda görüşmek üzere :D






Hiç yorum yok:

Yorum Gönder