30 Kasım 2015 Pazartesi

Azure Depolama Servisi(Azure Storage)

Bulut teknolojisi,verileri için ölçeklenebilirlik,süreklilik,güvenlik vs. gereken uygulamalar için depolama servisini sunabilmektedir.Azure Storage,"big data" konseptli bilimsel, finans,analiz ,media tarzı uygulamaların yüzlerce terabyte'lık verilerini işleme ve depolama imkanını sağlamakla birlikte küçük miktarda verilerin depolanmasınıda sağlamaktadır.Kullandığın kadar öde prensibiyle çalışmaktadır ve anlık olarak milyonlarca kullanıcı isteyine karşılık vermektedir. Azure Storage dunyanın heryerinden erişilebilir olmakla birlikde istekde bulunan uygulamanın tipinden ve çalıştığı platformdan bagımsız olarak hizmet vermektedir.Java,C++,.NET vs gibi proramlama dillerini desteklemektedir.Azure Storage hizmetini kulanabilmek  için bir Storage Account'a(depolama hesabı) sahip olunması gerekir.İki tür depolama bulunmaktadır.Standart Storage Account: Bu hesap türü Blob Storage,Table Storage,Queue Storage,File Storage depolama türlerini barındırır.

  • Blob Storage dosya verilerini depolar.Bir blob döküman,media dosyası vs. gibi herhangi bir metin tipi veya binary veri olabilir.Blob Storage bazen Object Storage olarakda bilinir.
  • Table Storage. yapılandırılmış veri kümelerini  depolar.Table storage hızlı geliştirme(development) ve büyük miktardaki veriye hızlı erişim sağlayan bir NoSQL anahtar özellikli depodur.
  • Queue Storage iş akışını işleme ve bulut hizmetlerinin bileşenleri  arasında güvenli mesajlaşma sağlar.
  • File Storage  standart SMB protokolünü kullanan uygulamalar için ortak paylaşımlı depolama sağlar. 
Premium Storage Account  üzerinde I\O yoğunluklu işyüklerinin çalıştırıldığı  sanal  makineler için yüksek performanslı ve düşük gecikmeli disk desteyi sağlamaktadır.Uygulamalarınızın VM disklerini bu depolama birimine taşıyarak performans ve hız artışı sağlanabilir.
Blob Storage'e daha yakından bakarak örnekle gösterelim.Örnekde bir web sayfası bizden resim dosyası alsın ve bu resim dosyasını  daha önceden oluşturduğumuz  storage hesabımıza yüklesin. Öncelikle Blob Storage;

  • Blob Storage,büyük miktarda yapılandırılmamış verilerinizi tuttabileceyiniz dünyanın heryerinden HTTP veya HTTPS protokolleri ile erişilebilir olan bir servisdir. Verilerinizi herkese açık veya özel olarak tutabilirsiniz
    Genel olarak aşağıdaki işlemler için kullanılmaktadır;
  • Resim veya dökümanların web browsera servis edilmesi.
  • Dosyaların dağıtık erişim için depolanması.
  • Video ve Audio iletimi ve diğer işlemler.
  • Blob Servisin yapısı resimdeki gibidir.
Account dan bahsetmişdik.Container farklı blob setlerini tutan bir yapıdır.Bütün bloblar containerda tutulmalıdır.Blob ise herhangi bir tipte ve boyutdadaki bir dosyadır.Yapıcağımız örnekte azure cloud üzerinde çalışan apache tomcat websitesi,azure cloudda çalışan bir storage var.Öncelikle Storage Accounta bağlanmak için bir bağlantı stringi tanımlamamız lazım.
String storageConnectionString ="DefaultEndpointsProtocol=http;" +"AccountName=hesap_adınız;" +"AccountKey=hesap_anahtarı";
Bunlara azure platformundan erişe bilirsiniz.Storage ile ilgili java üzerinden işlemler yapabilmemiz için Azure Storage SDK for Java ya ihtiyaç vardır.Jar dosyası  bu adresden indirilebilir.Bununla beraber daha birkaç .jar dosyalarını indirmemiz lazım.Bunlar ;

  • jackson-core-2.x.x.jar
  •  slf4j-api-1.x.x.jar
  • slf4j-simple-1.x.x.jar
     
    web sayfamızın ana sayfası index.jsp 
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>Dosya Yukleme Formu</title>
</head>
<body>
yuklemek icin dosya secin: <br />
<form action="main.jsp" method="post"
                        enctype="multipart/form-data">
<input type="file" name="file" size="50" />
<br />
<input type="submit" value="Yukle" />
</form>
</body>
</html>


Burada dosya seçildikden sonra sunucuda bir yere kaydedilicek ve sonra Blob storage e gönderilicek.Bunun için main.jsp
<%@ page import="java.io.*,java.util.*, javax.servlet.*" %>
<%@ page import="javax.servlet.http.*" %>
<%@ page import="org.apache.commons.fileupload.*" %>
<%@ page import="org.apache.commons.fileupload.disk.*" %>
<%@ page import="org.apache.commons.fileupload.servlet.*" %>
<%@ page import="org.apache.commons.io.output.*" %>
<%@ page import="com.microsoft.azure.storage.* "%>
<%@ page import="com.microsoft.azure.storage.blob.*" %>

<%
   File file ;
   int maxFileSize = 5000 * 1024;
   int maxMemSize = 5000 * 1024;
   //yuklenecek olan dosyanın serverde tutulacak dizinini belirle
   String filePath = "d:\\home\\site\\wwwroot\\bin\\apache-tomcat-8.0.28\\data\\";
   String fileName="";
   // formdan gelen içeriyin tipini dogrula
   String contentType = request.getContentType();
   if ((contentType.indexOf("multipart/form-data") >= 0)){

      DiskFileItemFactory factory = new DiskFileItemFactory();
      // bellekte depolanacak maksimum boyut
      factory.setSizeThreshold(maxMemSize);
      // yuklemek için handler oluştur
      ServletFileUpload yukle = new ServletFileUpload(factory);
      // yuklemek için maximum doya boyutunu belirle
      yukle.setSizeMax( maxFileSize );
      try{ 
         // yuklenen dosyanın parametrelerini parse et.
         List fileItems = yukle.parseRequest(request);

         // yuklenen dosyaları işle
         Iterator i = fileItems.iterator();

         
         out.println("<title>JSP Dosya Yukleme</title>");  
         while ( i.hasNext () ) {
            FileItem fi = (FileItem)i.next();
            if ( !fi.isFormField () )  
            {
                  // dosyanın parametrelerini al
                  String fieldName = fi.getFieldName();
                  fileName = fi.getName();
                  boolean isInMemory = fi.isInMemory();
                  long sizeInBytes = fi.getSize();
                  // dosyanın ismini bul ve oluştur
                  if( fileName.lastIndexOf("\\") >= 0 ){
                    file = new File( filePath + 
                    fileName.substring( fileName.lastIndexOf("\\"))) ;
                  }else{
                    file = new File( filePath + 
                    fileName.substring(fileName.lastIndexOf("\\")+1)) ;
                  }
                  //dosyayı yaz
                  fi.write( file ) ;
                  out.println("Upload edilen dosya: " + filePath + 
                         fileName + "<br>");
            }
         }
      }catch(Exception ex) {
         System.out.println(ex);
      }
   }
   else{
      out.println("Dosya Yüklenemedi <br>"); 
   }
   
   //Bağlantı stringi oluştur
   String storageConnectionString ="DefaultEndpointsProtocol=http;" +"AccountName=hesap_adi;" +
           "AccountKey=hesap_anahtari";
   try{
      // storage hesabını elde et
      CloudStorageAccount storageAccount = CloudStorageAccount.parse(storageConnectionString);

      // istemci oluştur
      CloudBlobClient istemciBlob = storageAccount.createCloudBlobClient();

      // container oluştur
      CloudBlobContainer container = istemciBlob.getContainerReference("resimler");
      container.createIfNotExists();
      //storage e yuklenecek olan resim için yolu belirle
      String YuklenmisfilePath = filePath+fileName;
      // blob oluştur.
      CloudBlockBlob blob = container.getBlockBlobReference(fileName);
      File dosya = new File(YuklenmisfilePath);
      //yükle
      blob.upload(new FileInputStream(dosya), dosya.length());
      out.println("Dosyayi Storage e Yukleme Basarili <br>");

      //resim yüklendiyse,resmin containerde olup olmadıgını goster
      int i=1;//blobları numaralandırmak için
      for (ListBlobItem blobItem : container.listBlobs()) {
             //blob veya sanal dizin oldgunu kontrol et,blob ise 
             if (blobItem instanceof CloudBlob) {
                 // uygun blob u oluştur.
                  CloudBlob blob1 = (CloudBlob) blobItem;
                  //container daki butun dosyalari listele
                  out.println(i+".blob:"+blob1.getName()+"<br>");
                  i++;
              }
          }
      }
      catch (Exception e)
      {
          out.println("Dosya Storage e yüklenemedi.... <br>");
      }
%>
Burada belirtmemiz gereken iki jar dosyası daha var,bu jarlar form üzerinden upload işlemi için gerekli doslardır.Bunlar;

  • commons-io- 2.x.jar
  • commons-fileupload-1.x.x.jar

  Uygulamanın kkodlari bunlardır.Bu kodlar jar dosyalarının classpath e eklenerek yerelde veya sunucu üzerinde çalıştırılabilir.Upload işlemi yapıldıkdan sonra uygulamanın çıktısı;

 Buradan  bu web uygulamasına erişebilinir.Aşağıdaki video da Azure platformu üzerinden Storage oluşturma ve buna erişim için gereken bilgilerin nasıl elde edileceği anlatılmaktadır.







21 Kasım 2015 Cumartesi

Java Native Interface(JNI)

Java Native Interface(JNI),Java Software Development Kit(Java Yazılım Geliştirme Kit'i)'in bir parçası olan doğal programlama arayüzüdür.JNI, C\C++ gibi diğer dillerde yazılmış kod ve kod kütüphanelerini Java kodu içerisinde kullanmamıza olanak sağlar.Buna karşılık bir Java kodunuda C/C++ kodu içerisine ekleyebiliriz ve ya içerisinden çağırabiliriz diyelim.JVM'nin bütün platformlarda sorunsuz çalıştırılabilmesi,büyük ölçüde JNI sayesinde gerçekleştirilmişdir.Eğer Java ile yazılım geliştiriyorsak,Bellek Yönetimi,Performans,alt seviyeli bir donanıma erişim gibi işlemlerde C\C++ kullanmamız gerekebilir.Bu yazıda Java sınıfları içerisinden C\C++ kod çağırımı yapılmaya bakılacakdır.

  • Kullanma şekli(Windows ortamında)
                           Windows ortamında bu tarz uygulamalar geliştirebilmemiz için lazım olan birkaç araç vardır.
                              1.Java Derleyicisi(javac.exe)
                              2.Java Sanal Makinesi(JVM veya java.exe)
                              3.Native method barındıran Java Class'dan .h dosyası oluşturucu(javah.exe)
                              4. JNI'i tanımlayan kütüphane dosyaları ve header dosyaları(jni.h,jvm.lib,jvm.dll)
                              5.C/C++ Derleyicisi(örn:Mingw(gcc,g++))
                              6.IDE(gerekli değil)
           Not:Bunlardan ilk dördü sisteminizde JDK kuruluysa vardır demekdir.
Örnek1:Bir Java sınıfı içerisinden C kodu çağıralım.(ornek1.java)
public class ornek1{
    
    static{
        System.loadLibrary("lib1");//ornek1 sınıfı belleğe yüklendiyinde lib1.dll
                                  //kütüphanesini kalıcı olarak bellege getir
    }
    private native void merhaba_dunya();//c kodunu bu metotla çagır

    public static void main(String[] args) {
        new ornek1().merhaba_dunya();//c kodunu çalıştır
    }
}
Buradaki static initializer(başlatıcı) ornek1 sınıfının yüklenmesi sırasında System.loadLibrary()'yi lib1.dll native kütüphanesini yüklemek için çağıracakdır.Bu kütüphane(lib1.dll),program çalıştırılırken  Java Library Path yoluna eklenmiş olması lazım,aksi takdirde JVM UnsatisfiedLinkError hatasını vericekdir.Buradaki native anahtar kelimesi bu metotun bir C/C++ metotu oldugunu göstermekdedir,C/C++ kodlarını çagırabilmemiz için native metotlara ihtiyacımız vardır.Şimdi ise çağırılacak olan C kodunu yazalım.Bunun için ilk once yazacağımız C kodu için bir header dosyası oluşturmamız gerekli.Bunu yapmak için ilk once Java kodunu derlememiz lazım,oluşacak olan class dosyamızdan javah.exe programıyla bu header dosyamızı oluşturabiliriz.ornek1.java dosyamızı cmd'yi açarak derleyelim. 
javac ornek1.java
Aynı dizinde ornek1.class dosyası oluşturuldu,şimdi bunu kullanarak C header dosyası oluşturalım.
javah ornek1
Bu komutdan sonra ornek1.h dosyası oluşturuldu.Bu dosyanın içeriği aşağıdaki şekildedir.
ornek1.h 
/* DO NOT EDIT THIS FILE - it is machine generated */
#include jni.h
/* Header for class ornek1 */

#ifndef _Included_ornek1
#define _Included_ornek1
#ifdef __cplusplus
extern "C" {
#endif
/*
 * Class:     ornek1
 * Method:    merhaba_dunya
 * Signature: ()V
 */
JNIEXPORT void JNICALL Java_ornek1_merhaba_1dunya
  (JNIEnv *, jobject);

#ifdef __cplusplus
}
#endif
#endif
Buradaki extern “C” C++ derleyicisi tarafından algılanır ve fonksiyonların C'nin isimlendirme protokolü kullanılarak derleneceğini söyler.Java_ornek1_merhaba_1dunya metot ismi ornek1  sınıfının içerisindeki merhaba_dunya() metoduna karşılık gelmektedir.Metot isimleri Java_{package_and_classname}_{function_name}(JNI arguments) şeklinde bir standartdır.JNIEnv  parametresi bütün  JNI fonksiyonlarina erişim sağlayan JNI ortam değişkenidir.jobject ise Java daki this nesnesine karşılık gelmektedir.Şimdi ise bu metodun C implementasyonunu yapalım.
ornek1.c
#include "ornek1.h"
#include  "stdio.h"

//merhaba_dunya() metodunun implementasyonu
JNIEXPORT void JNICALL Java_ornek1_merhaba_1dunya(JNIEnv *env, jobject jthis){
    printf("Merhaba Dunya\n");
    return;
  }
Bu C kodunu Java sınıfı içerisinden kullana bilmemiz için yukarıda bahsetdiyimiz gibi .dll dosyasına ihtiyacımız var.Yani ornek1.c dosyasını derleyip .dll uzantılı dosyaya  çevirmemiz lazım.
gcc -I"%JAVA_HOME%\include" -I"%JAVA_HOME%\include\win32" -shared -o  lib1.dll ornek1.c
  • JAVA_HOME:JDK nın kurulu oldugu dizini göstermekde.
  • -shared paylaşımlı bir dll olması gerekdiyini göstermekde.                                              
  • gcc C compiler.
Bu komutu yazdıkdan sonra dizinimizde lib1.dll dosyası oluşturuldu.ornek1.java dosyamızı çalıştırdığımızda bu kütüphanenin java_library_path'e eklenmesi gerek,aksi takdirde öncedende belirtildiyi gibi UnsatisfiedLinkError hatası verilecekdir.Şimdi ise ornek1 sınıfını(Java Kodu) çalıştıralım.
java -Djava.library.path="C:\\Users\heydar\Desktop\calismalar" ornek1
           Aşağıdaki gibi bir çıktı alınmasi lazım.
 Evet,görüldüyü gibi ornek1.c dosyası içerisindeki printf("Merhaba Dunya\n"); kod satırı  ornek1.java dosyasi içerisinde tanımlanmış ornek1 sınıfında çalıştırılmaktadır.
          Şimdi bir C++ örnegine bakacak olursak.
ornek2.java 
public class ornek2{

    static{
        System.loadLibrary("lib2");
    }
    private native double ortalama(int n1,int n2);//iki tam sayının ortalamasını dödüren metod

    public static void main(String[] args) {
        System.out.println("Ortalama:"+new ornek2().ortalama(4,5)); 
    }
}
Yukarıdaki örnekteki gibi kodu derledikden sonra javah.exe ile oluşan header kodumuz.
ornek2.h
/* DO NOT EDIT THIS FILE - it is machine generated */
#include <jni.h>
/* Header for class ornek2 */

#ifndef _Included_ornek2
#define _Included_ornek2
#ifdef __cplusplus
extern "C" {
#endif
/*
 * Class:     ornek2
 * Method:    ortalama
 * Signature: (II)D
 */
JNIEXPORT jdouble JNICALL Java_ornek2_ortalama
  (JNIEnv *, jobject, jint, jint);

#ifdef __cplusplus
}
#endif
#endif
         Şimdi ise C++ implementasyonunu yapalım.
ornek2.cpp
#include "ornek2.h"
#include <iostream>
using namespace std;
JNIEXPORT jdouble JNICALL Java_ornek2_ortalama(JNIEnv *env, jobject jthis, jint n1, jint n2){
    jdouble ortalama;
    cout<<"C++ daki sayilar:"<<n1<<","<<n2<<endl;
    ortalama=((jdouble)n1+n2)/2.0;
    return ortalama;
}
         lib2.dll isminde bir dll dosyası oluşturalım.
NOT:Bazen windowsda “__int64” tipi “long long” tanımlı olmayabiliyor. Bu durumda  gcc/g++ ye aşağıdaki seçenekle bu tip kullanımını soylemelisiniz.
gcc/g++ -D __int="long long"

lib2.dll
g++ -I"%JAVA_HOME%\include" -I"%JAVA_HOME%\include\win32" -D__int64="long long"  -shared -o lib2.dll ornek2.cpp
          Şimdi ise ornek2.java kodumuzu çalıştırdığımızda aşağıdaki gibi çıktı alırız.

20 Kasım 2015 Cuma

16F877 MicroController ve PicBasic Pro ile LED kontrolü

Devre Şeması(ISIS):


Picbasic Kodu:
'****************************************************************
'****************************************************************
'*  Name    : LED_Kontrol.BAS                                      *
'*  Author  : [select VIEW...EDITOR OPTIONS]                    *
'*  Notice  : Copyright (c) 2015 [select VIEW...EDITOR OPTIONS] *
'*          : All Rights Reserved                               *
'*  Date    : 20.11.2015                                        *
'*  Version : 1.0                                               *
'*  Notes   :                                                   *
'*          :                                                   *
'***************************************************************
TRISB=%00000000 'B0-B7 portlarini çıkış olarak ayarla
ikili VAR BYTE  '1 byte'lık bir değişken tanımla
ikili=0
PORTB=ikili     'B portlarinin çıkış degerlerini 00000000 yap
main:
     ikili=ikili+1
     PORTB=ikili
     PAUSE 100  '100 milli saniye dur
     IF ikili=127 THEN   ikili=0
goto main
Bu PicBasic kodu,0-127 arası sayıları saymakda ve bu sayıların ikili karşılıklarini portb'e gondererek,led ler uzerinde göstermekdedir.Yanan led'ler 1'e,yanmayanlar 0'a karşılık gelmektedir.