Apache Presto - Kurulum
Bu bölüm, Presto'nun makinenize nasıl kurulacağını açıklayacaktır. Presto'nun temel gereksinimlerini inceleyelim,
- Linux veya Mac OS
- Java sürüm 8
Şimdi Presto'yu makinenize kurmak için aşağıdaki adımlara devam edelim.
Java yüklemesini doğrulama
Umarım şu anda makinenize Java sürüm 8'i yüklemişsinizdir, bu nedenle aşağıdaki komutu kullanarak doğrulamanız yeterlidir.
$ java -version
Java, makinenize başarıyla yüklendiyse, yüklü Java sürümünü görebilirsiniz. Java yüklü değilse, makinenize Java 8 yüklemek için sonraki adımları izleyin.
JDK'yı indirin. Aşağıdaki bağlantıyı ziyaret ederek JDK'nın en son sürümünü indirin.
http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
En son sürüm JDK 8u 92 ve dosya "jdk-8u92-linux-x64.tar.gz" dir. Lütfen dosyayı makinenize indirin.
Bundan sonra, dosyaları çıkarın ve belirli bir dizine gidin.
Ardından Java alternatiflerini ayarlayın. Sonunda Java makinenize yüklenecek.
Apache Presto Kurulumu
Aşağıdaki bağlantıyı ziyaret ederek Presto'nun en son sürümünü indirin,
https://repo1.maven.org/maven2/com/facebook/presto/presto-server/0.149/
Şimdi "presto-server-0.149.tar.gz" nin son sürümü makinenize indirilecektir.
Tar Dosyalarını Çıkarın
Ayıkla tar aşağıdaki komutu kullanarak dosya -
$ tar -zxf presto-server-0.149.tar.gz
$ cd presto-server-0.149
Yapılandırma ayarları
"Veri" dizini oluşturun
Kurulum dizininin dışında, günlükleri, meta verileri vb. Depolamak için kullanılacak bir veri dizini oluşturun, böylece Presto'yu yükseltirken kolayca korunabilir. Aşağıdaki kod kullanılarak tanımlanır -
$ cd
$ mkdir data
Bulunduğu yolu görüntülemek için "pwd" komutunu kullanın. Bu konum sonraki node.properties dosyasında atanacaktır.
"Etc" dizini oluşturun
Aşağıdaki kodu kullanarak Presto kurulum dizini içinde bir etc dizini oluşturun -
$ cd presto-server-0.149
$ mkdir etc
Bu dizin yapılandırma dosyalarını tutacaktır. Her dosyayı tek tek oluşturalım.
Düğüm Özellikleri
Presto düğüm özellikleri dosyası, her düğüme özgü ortam yapılandırmasını içerir. Aşağıdaki kod kullanılarak etc dizininde (etc / node.properties) oluşturulur -
$ cd etc
$ vi node.properties
node.environment = production
node.id = ffffffff-ffff-ffff-ffff-ffffffffffff
node.data-dir = /Users/../workspace/Presto
Tüm değişiklikleri yaptıktan sonra dosyayı kaydedin ve terminalden çıkın. Burayanode.data yukarıda oluşturulan veri dizininin konum yoludur. node.id her düğüm için benzersiz tanımlayıcıyı temsil eder.
JVM Yapılandırması
Etc dizini (etc / jvm.config) içinde bir “jvm.config” dosyası oluşturun. Bu dosya, Java Sanal Makinesi'ni başlatmak için kullanılan komut satırı seçeneklerinin bir listesini içerir.
$ cd etc
$ vi jvm.config
-server
-Xmx16G
-XX:+UseG1GC
-XX:G1HeapRegionSize = 32M
-XX:+UseGCOverheadLimit
-XX:+ExplicitGCInvokesConcurrent
-XX:+HeapDumpOnOutOfMemoryError
-XX:OnOutOfMemoryError = kill -9 %p
Tüm değişiklikleri yaptıktan sonra dosyayı kaydedin ve terminalden çıkın.
Yapılandırma Özellikleri
Etc dizini (etc / config.properties) içinde bir “config.properties” dosyası oluşturun. Bu dosya, Presto sunucusunun yapılandırmasını içerir. Test için tek bir makine kuruyorsanız, Presto sunucusu yalnızca aşağıdaki kod kullanılarak tanımlanan koordinasyon süreci olarak işlev görebilir -
$ cd etc
$ vi config.properties
coordinator = true
node-scheduler.include-coordinator = true
http-server.http.port = 8080
query.max-memory = 5GB
query.max-memory-per-node = 1GB
discovery-server.enabled = true
discovery.uri = http://localhost:8080
Buraya,
coordinator - ana düğüm.
node-scheduler.include-coordinator - Koordinatör üzerinde zamanlama çalışmasına izin verir.
http-server.http.port - HTTP sunucusu için bağlantı noktasını belirtir.
query.max-memory=5GB - Maksimum dağıtılmış bellek miktarı.
query.max-memory-per-node=1GB - Düğüm başına maksimum bellek miktarı.
discovery-server.enabled - Presto, kümedeki tüm düğümleri bulmak için Keşif hizmetini kullanır.
discovery.uri - Discovery sunucusuna URI.
Birden fazla makine Presto sunucusu kuruyorsanız, Presto hem koordinasyon hem de çalışan süreç olarak işlev görür. Presto sunucusunu birden fazla makinede test etmek için bu yapılandırma ayarını kullanın.
Koordinatör için Yapılandırma
$ cd etc
$ vi config.properties
coordinator = true
node-scheduler.include-coordinator = false
http-server.http.port = 8080
query.max-memory = 50GB
query.max-memory-per-node = 1GB
discovery-server.enabled = true
discovery.uri = http://localhost:8080
İşçi için Yapılandırma
$ cd etc
$ vi config.properties
coordinator = false
http-server.http.port = 8080
query.max-memory = 50GB
query.max-memory-per-node = 1GB
discovery.uri = http://localhost:8080
Günlük Özellikleri
Etc dizini (etc / log.properties) içinde bir “log.properties” dosyası oluşturun. Bu dosya, adlandırılmış günlükçü hiyerarşileri için minimum günlük seviyesini içerir. Aşağıdaki kod kullanılarak tanımlanır -
$ cd etc
$ vi log.properties
com.facebook.presto = INFO
Dosyayı kaydedin ve terminalden çıkın. Burada DEBUG, INFO, WARN ve ERROR gibi dört günlük düzeyi kullanılır. Varsayılan günlük düzeyi BİLGİ'dir.
Katalog Özellikleri
Etc dizini (etc / catalog) içinde bir "katalog" dizini oluşturun. Bu, verileri bağlamak için kullanılacaktır. Örneğin, oluşturunetc/catalog/jmx.properties aşağıdaki içeriklerle jmx connector jmx kataloğu olarak -
$ cd etc
$ mkdir catalog
$ cd catalog
$ vi jmx.properties
connector.name = jmx
Presto'yu Başlat
Presto, aşağıdaki komut kullanılarak başlatılabilir,
$ bin/launcher start
Daha sonra buna benzer bir yanıt göreceksiniz,
Started as 840
Presto'yu çalıştır
Presto sunucusunu başlatmak için aşağıdaki komutu kullanın -
$ bin/launcher run
Presto sunucusunu başarıyla başlattıktan sonra, günlük dosyalarını “var / log” dizininde bulabilirsiniz.
launcher.log - Bu günlük, başlatıcı tarafından oluşturulur ve sunucunun stdout ve stderr akışlarına bağlanır.
server.log - Bu, Presto tarafından kullanılan ana günlük dosyasıdır.
http-request.log - Sunucu tarafından alınan HTTP isteği.
Şu an itibariyle, Presto konfigürasyon ayarlarını makinenize başarıyla yüklediniz. Presto CLI'yi kurma adımlarına devam edelim.
Presto CLI'yi yükleyin
Presto CLI, sorguları çalıştırmak için terminal tabanlı etkileşimli bir kabuk sağlar.
Aşağıdaki bağlantıyı ziyaret ederek Presto CLI'yi indirin,
https://repo1.maven.org/maven2/com/facebook/presto/presto-cli/0.149/
Şimdi “presto-cli-0.149-execable.jar” makinenize yüklenecek.
CLI'yi çalıştır
Presto-cli'yi indirdikten sonra, onu çalıştırmak istediğiniz konuma kopyalayın. Bu konum, koordinatöre ağ erişimi olan herhangi bir düğüm olabilir. Önce Jar dosyasının adını Presto olarak değiştirin. Sonra onu çalıştırılabilir hale getirinchmod + x aşağıdaki kodu kullanarak komut -
$ mv presto-cli-0.149-executable.jar presto
$ chmod +x presto
Şimdi aşağıdaki komutu kullanarak CLI'yi çalıştırın,
./presto --server localhost:8080 --catalog jmx --schema default
Here jmx(Java Management Extension) refers to catalog and default referes to schema.
Aşağıdaki yanıtı göreceksiniz,
presto:default>
Şimdi terminalinize "jps" komutunu yazın ve çalışan arka plan programları göreceksiniz.
Presto'yu durdur
Tüm yürütmeleri gerçekleştirdikten sonra, aşağıdaki komutu kullanarak presto sunucusunu durdurabilirsiniz -
$ bin/launcher stop