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