Docker Cheat Sheet

## Docker Version and Info
docker -v
docker info

## List Images
docker images

## List Containers (running, all)
docker container ls
docker container ls –all
docker ps
docker ps -a

## Run a New Container
docker run <image-name>
docker run –name <name> <image-name>
docker run -p <outer-port>:<inner-port> <image-name>
docker run -d -p <outer-port>:<inner-port> <image-name>

## Start a Container
docker start <name>

## Stop a Container
docker stop <name>

## Remove a Container
docker rm <container-id>
docker rm -f <container-id>

## Remove a Image
docker rmi <image-name>

## Remove All Stopped Containers
docker container prune

## Remove All Unused Images
docker image prune -a

## Connect to Docker via Bash
docker exec -it <name> bash

Docker kategorisine gönderildi | Yorum yapın

SSH Key Pair Oluşturmak

Güvenlik amaçlı bağlandığım yerlere çoğunlukla “username”/”password” kullanmaktansa SSH Key Pair oluşturarak “Public Key”i paylaşıp bağlanmayı tercih ediyorum.

Bu yazıda da Mac OS işletim sistemi için nasıl anahtar çifti oluşturulur detaylı bir şekilde anlatmaya çalışacağım.

SSH Key Pair Nedir? (Güvenli Kabuk Anahtar Çifti)

Secure Shell (Güvenli Kabuk), güvensiz bir ağ üzerinde güvenli haberleşmeye olanak sağlayan bir kriptografik ağ protokolüdür.

Amacım şu an private-public key pair (özel-genel anahtar çifti) oluşturmak olduğu için “asimetrik şifreleme” ile RSA anahtar çifti üreteceğim. Aşağıda ssh-keygen aracının özelliklerini bulabilirsiniz.

  1. Terminal üzerindeki aşağıdaki komutu çalıştıracağım. RSA anahtar çifti oluşturmama yardımcı olacak.
    ssh-keygen -t rsa
  2. Hangi dosyaya kaydetmek istediğimizi soracak, istediğiniz ismi verebilirsiniz.
  3. Bu adımdam sonra isterseniz bu anahtarları kullanmak için şifre koyabilirsiniz.
  4. Çıktı aşağıdaki gibi olacaktır. Sizin bir private bir de public olmak üzere iki anahtar oluşturuldu. Private olanı kimse ile paylaşmamanız lazım.
  5. Public olanının (sonu .pub ile bitiyor) içinden anahtarı alıp artık paylaşabilirsiniz.

Kolay gelsin.

Application Servers kategorisine gönderildi | , , ile etiketlendi | Yorum yapın

Java 11-12-13 ve …

Merhabalar, Java 11 ile beraber Java kullanan herkesin hayatında önemli değişiklikler olacak. Bu yazımda onlardan bahsedeceğim.

JDK (Java Development Kit) artık her 6 ayda bir güncellenecek, bunlar da yıl içinde Mart ve Eylül aylarına denk geliyor. LTS (Long Term Support) dediğimiz “Uzun Dönem Destek” paketleri de 3 yılda bir çıkacak.

  • 2018 Eylül – Java 11
  • 2021 Eylül – Java 17
  • 2024 Eylül – Java 23
  • … gibi

Ve tabi ki ücretini ödeyen 3 seneden sonra da desteğini alabilir 🙂

Lisanslama – Oracle JDK & Open JDK

Java 11 ile artık karşımızda Oracle JDK ve Open JDK kavramları var. Bundan sonra

Oracle JDK – Oracle Binary Code License Aggrement

Open JDK – GPL2

ile lisansları ile hayatımızda yer alacak. GPL2 tamamen açık kaynak ve ücretsiz. Oracle Binary Code Lisansı ise geliştirme yaparken yine ücretsiz kullanılabilecek ama üretim (production) ortamlarına ücretli olacak.

Modası Geçen ve Kaldırılanlar

Enterprise API’lerden aşağıdakiler JDK içerisinden çıkarıldı.

  • JAXB – xml binding
  • JAX-WS – xml web services and endpoint technology
  • CORBA – distributed object technology
  • JTA – java transaction api
  • JavaBeans Activation

Detayına şu adresten ulaşabilirsiniz; https://openjdk.java.net/jeps/320

Ayrıca Thread sınıfından destroy() ve stop(Throwable obj) metodları çıkarıldı.

JDK 10 – Thread
JDK 11 – Thread

JavaFX jdk içerisinden çıkarılarak ayrı bir kütüphane haline getirildi, adı da OpenJFX oldu.

Dil ve Kütüphane Yenilikleri

JDK 9 ve 10’da deneysel olarak bulunan HTTP isteği gönderip yanıtını almak için kullanılabilen HttpClient sınıfı artık canlıda. HTTP2 desteği sunduğundan dolayı çoğu yeni proje için Java 11’e geçiş sebebi 🙂 API’yi tanımak için aşağıya bağlantılarını ekledim.

HttpClient API
HttpRequest API
HttpResponse API

 

String sınıfına yeni kullanışlı metodlar eklendi.

repeat() – herhangi bir string i tekrarlamak için
isBlank() – string in boş olup olmadığına bakar
strip() – string’in önü ve arkasındaki boşluk karakterlerini trim() metodundan farklı olarak unicode karakterleri ile temizler
lines() – string in içindeki satırları “\r\n” yani line feed ve carriage return karakterleri stream olarak almamızı sağlar

Ayrıca Files sınıfına aşağıdaki yeni metodlar gelmiş;
Unicode 10 desteği de yine JDK 11 ile geliyor.

Ben burada sadece en çok kullanabileceklerimi yazdım. Tam listeyi yazının en altına ekliyorum.

Performans ve Güvenlik İyileştirmeleri

G1 Garbage Collector ile Java 11, Java 8’e göre %60 daha iyi performans sergiliyor. Bu da yazdığımız kodda herhangi bir değişiklik yapmadan Java 11’e geçirsek bile daha iyi bir performans alabileceğimizin göstergesi.

Ayrıca Epsilon GC ve Z GC adında iki yeni GC eklendi. İkisi de henüz deneysel.

Epsilon Garbage Collector, performans ölçüm amaçlı kullanılabilir, aşağıdaki parametrelerle açılabiliyor.
XX:+UnlockExperimentalVMOptions
XX:+UseEpsilonGC

Z Garbage Collector, multi-terabytes heap e çıkmayı sağlıyor. Sadece 64 bit Linux makinelerde çalışıyor.
XX:+UnlockExperimentalVMOptions
XX:+UseZGC

Güvenlik konusuna gelirsek, TLS 1.3 desteği sağlanmış ve eski güvenliğini kaybetmiş kriptografik algoritmalar çıkarılmış ve yeni daha güvenli algoritmalar eklenmiş. Handshake sırasındaki ilk mesaj hariç hepsi şifrelenmiş. Detaylarına aşağıdaki linkten erişilebilir.
https://openjdk.java.net/jeps/332

Son olarak Oracle’ın açıkladığı Java 11 değişiklikler listesi bağlantıdadır.

Java kategorisine gönderildi | , , , , , ile etiketlendi | Yorum yapın

CentOS 7 Üzerine MySQL Kurmak

CentOS package manager olarak yum kullanıyor. O sebeple önce bunu güncellememiz lazım. Aşağıdaki komutla yapabiliriz.

sudo yum update

Güncelleme bittikten sonra indireceğimiz mysql server versiyonunu belirlememiz lazım. Mysql download sayfasından (http://dev.mysql.com/downloads/repo/yum/) versiyonumuzu seçelim.

Ben versiyon olarak bu örnekte aşağıdaki versiyonu seçtim.
https://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpm

Şimdi sırasıyla bu versiyonu indirelim.

sudo rpm -Uvh https://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpm

İndirme işlemi bitince kurulumu başlatalım.

sudo yum install mysql-community-server

Kurulum da bitince MySQL Community Server’ı başlatabiliriz.

sudo service mysqld start

Sunucunun durumuna aşağıdaki komut ile bakabiliriz.

sudo service mysqld status

Active(running) şeklinde görebildiysek başarılıyız.

Şimdi aklımızda sorular olması lazım 🙂 Kurdum ama şifrem ne, hangi porttan erişebilirim gibi…
Öncelikle şifremizi belirleyelim. Kurulum aşamasında bize rastgele bir şifre verildi, onu önce bi alalım.

sudo grep 'temporary password' /var/log/mysqld.log

Süper artık random password elimizde. O zaman değiştirelim, bunun için MySQL Server’a bağlanmamız lazım.

mysql -uroot -p

MySQL konsoluna düşmemiz lazım. “mysql>” şeklinde görebiliriz. Şifreyi değiştirelim.

ALTER USER 'root'@'localhost' IDENTIFIED BY 'YeniSifrem123!';

Portu da kontrol edip yazımızı bitirelim.

select @@port;

Bu arada mysql konsolundan çıkmak için “exit;” yazıp entera basın, kalmayın orada 🙂

Database Management Systems, MySQL kategorisine gönderildi | Yorum yapın

Oracle’da Kullanıcı Açmak ve Yetki Vermek

Merhaba, Oracle DB üzerinde kullanıcı açmak için gerekli komutlar aşağıdaki gibi olabilir. Bu arada yetkili bir kullanıcı ile bağlandığımızı farz ediyorum. Kullanıcı adını SUKRU olarak belirledim.

Kullanıcı tanımlamak için

CREATE USER SUKRU IDENTIFIED BY SUKRU

Bağlanma hakkı vermek için

GRANT CREATE SESSION TO SUKRU

Tablo oluşturma hakkı vermek için

GRANT CREATE TABLE TO SUKRU

Sequence oluşturma hakkı vermek için

GRANT CREATE SEQUENCE TO SUKRU

Tablespace alanını kullanabilmek için

GRANT UNLIMITED TABLESPACE TO SUKRU

Güncel sürüm Oracle’da SELECT, INSERT, UPDATE, DELETE için yetki gerekmiyor ama gerekirse

GRANT
  SELECT,
  INSERT,
  UPDATE,
  DELETE
ON
  schema.table
TO
  SUKRU
Oracle kategorisine gönderildi | , , , , ile etiketlendi | Yorum yapın

Spring Security + PrimeFaces Yönlendirme Problemi Çözümü

Spring Security, Java EE dünyasında kabul görmüş ve java uygulamaları için -bence- güvenlik için bulunmaz bir nimet. Ayrıntılı bilgiye sitesinden ulaşabilirsiniz.
PrimeFaces da JSF dünyasında kabul gören en başarılı bileşen kütüphanesi, yine bu adresten detaylı bilgiye ulaşabilirsiniz.

JSF 2.2 + Spring 4 + Hibernate 4 + PrimeFaces 5 şeklinde altyapısını kurguladığım projemde fark ettim ki başarılı bir giriş (login) işlemi sonrası sayfa gitmesi gereken URL’e gitmiyor. Spring Security loglarını incelediğimde ise herhangi bir problem olmadan “sendRedirect” ile konfigürasyondaki belirttiğim URL’e gönderiyor. Her şeyin bu kadar mükemmel olduğu yerde nasıl olur da bu çalışmaz diye kafayı sıyırdım tabi ki 🙂

Spring Security logu aşağıdaki gibi. /login sayfasından istediğim gibi /pages/home sayfasına yönlendirmiş.

[DEBUG] ..access.intercept.FilterSecurityInterceptor - Authorization successful
[DEBUG] ..security.web.FilterChainProxy            - /pages/home.xhtml reached end of additional filter chain; proceeding with original chain
[DEBUG] ..web.access.ExceptionTranslationFilter    - Chain processed normally
[DEBUG] ..web.context.SecurityContextPersistenceFilter - SecurityContextHolder now cleared, as request processing completed

Başladım daha detaylı incelemeye, önce tarayıcı üzerinde gelen-giden akışı izledim.

İstek (Request):

javax.faces.partial.ajax:true
javax.faces.source:loginButton
javax.faces.partial.execute:loginForm
javax.faces.partial.render:loginForm
loginButton:loginButton
loginForm:loginForm
username:test
password:123456
_csrf:49756ca7-38fd-4777-bea8-58fcfe7deb73
javax.faces.ViewState:-3601270081246135757:6121484162719565648

Yanıt (Response):

<?xml version='1.0' encoding='UTF-8'?>
<partial-response id="j_id1"><changes><update id="j_id1:javax.faces.ViewState:0"><!&#91;CDATA&#91;-6140875972550706628:-2367790204853062502&#93;&#93;></update></changes></partial-response>

Bunları görünce tabi ki “Aman Tanrım didim”, neden mi? 🙂
Çünkü gelen yanıtta “redirect-url” yok! Sadece “update” var! Yani ajax işinde hata yapmışız (javax.faces.partial.ajax:true) ve bunu aşmak için önümüzde iki yol var;

  1. Primefaces commandButton özelliklerinde ajax=”false” demek
  2. Primefaces butonu yerine klasik JSF butonu kullanmak

Kullandığım buton

<p:commandButton value="Giriş Yap" />

1. yol

<p:commandButton value="Giriş Yap" ajax="false"/>

2. yol (primefaces butonunun css’inden faydalanamazsınız, elle eklemeniz lazım)

<h:commandButton value="Giriş Yap" />

Sonuç olarak bu kadar basit görünse de tarayıcı üzerindeki trafiği izlemeden ben anlayamadım. Bu arada tüm tarayıcılarda neredeyse standart haline geldi, “Developer Tools” deniliyor genelde ve F12 tuşu ile açabiliyorsunuz, bilmeyenler olabilir diye bahsedeyim dedim.

Bunların dışında Spring Security’nin “sendRedirect” yaptığı yeri ezerek (override) de bu işi yapabilirdik ama daha maliyetli olurdu. Nasıl yapılabileceği şuradaki cevapta üstad BalusC tarafından verilmiş 🙂

Sorunun temeline de şu kaynaktan bakılabilir.

Java, JSF, Primefaces, Spring kategorisine gönderildi | Yorum yapın

JSF 2 + PrimeFaces

PrimeFaces, JSF 2 için yazılmış bileşen kütüphanelerinin en başında gelmektedir. Şu an itibariyle de NetBeans geliştirme ortamında hazır gelen tek bileşen kütüphanesidir. Gelişmiş bir çok bileşenini ve detaylarını demo sayfalarında bulabilirsiniz.

Bu yazıya başlamadan önce…
Daha önce yazmış olduğum şu yazıları, bu makaleye başlamadan önce okumanızı tavsiye ederim.

  1. JSF Life Cycle
  2. JSF Model-View-Controller
  3. JSF 2’ye Giriş

Konular hakkında bilgili olanlar tabi ki okumasına gerek yok, lakin JSF 2’ye giriş yazısında oluşturduğumuz geliştirme ortamı üzerinden bu yazıya devam edeceğim için, en azından ona bakmanızda fayda var.

PrimeFaces ile Güçlenmek
JSF 2 projemizi PrimeFaces ile güçlendirmek sadece iki adımdan oluşmaktadır.

  1. PrimeFaces indirme sayfasından en son kararlı sürümü indirmek ve projenin kütüphaneleri arasına eklemek
  2. xhtml sayfalarının başındaki xmlns tanımları arasına aşağıdaki satırı eklemek.
xmlns:p="http://primefaces.org/ui"

Evet, sadece bu kadar! Bundan sonra sayfalarımız içinde

Görüldüğü üzere index.xhtml sayfası içerisine bileşenini eklemiş bulunmaktayız. Projeyi çalıştırıp index.jsf sayfasını çalıştırdığımızda aşağıdaki gibi bir görümüne sahip oluruz.

Bir sonraki yazıda bu JSF 2 + PrimeFaces uygulamamızı Ajax kullanarak geliştireceğiz.

Kolay gelsin.


Java, JSF kategorisine gönderildi | , , , ile etiketlendi | 5 Yorum

JavaServer Faces 2 (JSF 2)

JavaServer Faces (JSF), Java Komitesi tarafından standart web teknolojisi olarak kabul edilmiştir. Java ile web programlama yapmak isteyen bir kişinin mutlaka öğrenmesi tavsiye edilir. Ayrıntılı bilgiye http://javaserverfaces.java.net/ adresinden erişebilirsiniz.

JSF, Model-View-Controller (MVC) tabanlı olduğundan Java sınıflarımız ile görsel sayfalarımız yani önyüzümüz farklı farklı katmanlarda bulunmaktadır. Bu konuyu detaylı bir şekilde şu sayfada anlatmıştım.

Şimdi JSF 2 ile ilk uygulamamızı yapalım. Bize aşağıdaki malzemeler lazım daha doğrusu ben bunları kullanacağım;

Tomcat
Eclipse başlatıp yeni bir çalışma alanı (workspace) açalım. İlk olarak “Server”ı tanıtalım. Server tabında sağ tıklayarak New > Server yolunu takip ettikten sonra Tomcat’in yerini aşağıdaki gibi gösterebilirsiniz.

Proje Oluşturma
Şimdi “Package Explorer” ya da “Project Explorer” görünümünde New > Dynamic Web Project yolu ile aşağıdaki gibi projeyi oluşturuyoruz. Önce proje ismi gibi alanları dolduruyoruz.

Sonra ileri ve tekrar ileri diyerek aşağıdaki gibi “web.xml” dosyasını oluşturmasını sağlayıp “finish” butonuna basarız.

JSF 2 için Gerekli Jarlar
JSF 2 uygulamamızın çalışması için yapmamız gereken bir kaç adım var, ilk olarak en başta belirttiğimiz 2 adet jar dosyasını WEB-INF/lib dizini altına kopyalayalım, projemizin görünümü aşağıdaki gibi olmalı.

web.xml Ayarları
JSF 2 uygulamamızın server tarafından yorumlanabilmesi için web.xml içine şu satırları eklememiz lazım.

        <!-- Faces Servlet -->
	<servlet>
		<servlet-name>Faces Servlet</servlet-name>
		<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
		<load-on-startup> 1 </load-on-startup>
	</servlet>

	<!-- Faces Servlet Mapping -->
	<servlet-mapping>
		<servlet-name>Faces Servlet</servlet-name>
		<url-pattern>*.jsf</url-pattern>
	</servlet-mapping>

Bu satırları ekledikten sonra web.xml dosyasının görünümü aşağıdaki gibi olacaktır.

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
	id="WebApp_ID" version="2.5">
	<display-name>jsf2-helloworld</display-name>

	<!-- Faces Servlet -->
	<servlet>
		<servlet-name>Faces Servlet</servlet-name>
		<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
		<load-on-startup> 1 </load-on-startup>
	</servlet>

	<!-- Faces Servlet Mapping -->
	<servlet-mapping>
		<servlet-name>Faces Servlet</servlet-name>
		<url-pattern>*.jsf</url-pattern>
	</servlet-mapping>

	<welcome-file-list>
		<welcome-file>index.html</welcome-file>
	</welcome-file-list>
</web-app>

xhtml Sayfası Oluşturmak
Artık tüm altyapı hazırlıklarımız tamam, sıra geldi bir sayfa oluşturup çalıştırmaya. WebContent dizini altına index.xhtml adında bir dosya oluşturup aşağıdaki gibi düzenliyoruz.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
	xmlns:h="http://java.sun.com/jsf/html"
	xmlns:f="http://java.sun.com/jsf/core"
	xmlns:ui="http://java.sun.com/jsf/facelets">
<h:head>
	<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
	<title>jsf2-helloworld</title>
</h:head>
<h:body>

	Merhaba JSF 2
	
</h:body>
</html>

Projenin Çalıştırılması
Tomcat’in menüsünden Add and Remove aracılığı ile projemizi Tomcat altına ekliyoruz.

Daha sonra Tomcat’i başlatıyoruz. Herhangi bir port değişikliği yapmadıysanız http://localhost:8080/jsf2-helloworld/index.jsf bağlantısına gidince karşımıza aşağıdaki ekran gelir.

En saf haliyle bir JSF 2 uygulamasına sahibiz. Bundan sonraki derste bu uygulamamıza, PrimeFaces component suite eklemesi yapacağız. Uygulamayı sade halinden PrimeFaces’ın sağladığı bileşenlerle zenginleştireceğiz.

Kolay gelsin.

Java, JSF kategorisine gönderildi | , , , ile etiketlendi | 5 Yorum