🌞

Amsterdam JSNation 2019

yaklaşık 1 yıl önce

7 Haziran’da, Hollanda’nın başkenti güzide kent Amsterdam’da düzenlenen JSNation konferansına Zingat Yazılım Ekibi’ni temsilen katılma fırsatım oldu. Avrupa’nın gezginler tarafından en fazla ziyaret edilen şehirlerinden biri olan Amsterdam’ın merkezi sayılabilecek bir noktada, Zuiderkerk adlı eski bir kilisede gerçekleşen konferans, aynı zamanda Rembrandt’ın ünlü tablosu The Night Watch’u yarattığı yer olmasıyla da ilgi çekiyor.

Amsterdam JSNation bu sene iki ayrı konumda gerçekleşti. Zuiderkerk ana konferans merkeziydi, kiliseye beş dakika yürüme mesafesinde bulunan Uilenburg sinagogunda ise Node.js merkezli sunumlar yapıldı. Her ne kadar lokasyonlar birbirlerine yakın ve Amsterdam’ın tarihi sokaklarını adımlamak keyifli olsa da, özellikle sunumları canlı izleme gayretinde olduğum için iki lokasyon arasında bayağı bir mekik dokumak durumunda kaldım diyebilirim.

Zuiderkerk - Ana Salon

JavaScript Zingat’ta code stack’imizin en önemli unsurlarından biri. Platformumuzun önemli parçalarından MVC bir Node.js — Express uygulaması olan zingat.com website’ı başta olmak üzere, kimisi son kullanıcılara açık kimisi de Zingat içerisinde, backend ya da frontend ihtiyaçlarına yönelik olarak geliştirdiğimiz çeşitli JS uygulamalarımız mevcut. Haliyle JavaScript tarafında gerçekleşen gelişmeleri sıkı şekilde takip ediyor ve uygulamalarımızı devamlı güncel tutmaya gayret ediyoruz. Bu bağlamda Amsterdam JSNation benim adıma hem arkaplan edindiği egzotik lokasyonu hasebiyle hem de JS komünitesinden takip ettiğim kimi isimlerin sunumlarıyla bünyesinde yer almalarından dolayı katılmayı ziyadesiyle arzu ettiğim bir organizasyondu.

Uilenburd - Node.js Salonu

Katıldığım sunumları mümkün mertebe çeşitli tutmaya, hem backend hem de frontend taraflarındaki konuşmalara seyirci olmaya gayret ettim. Zuiderkerk’te daha çok JavaScript’in frontend’deki kullanımına yönelik sunumlar varken, Uilenburg sinagogunda backend ağırlıklı anlatımlar vardı. Organizasyonu tertip eden GitNation ekibinin sunumları çeşitli ve ilgi çekici kılmak noktalarında iyi iş çıkardığını söyleyebilirim; zira WebGL’den tutun otomatik sayfa performansı ölçümleme metodolojilerine, fonksiyonel programlama paradigmalarından Angular geliştirmeye, oradan Node.js backend’lerde hata yönetimine uzanan geniş çerçevede bir içerik oluşturmayı başarmışlar.

Amsterdam JSNation Açılış

Benim bu yazıyı kaleme aldığım dönemde sunumları resmi Youtube sayfalarında ayrı ayrı koymamışlardı. O yüzden katıldığım sunumlar ve aldığım notlarla birlikte, sunumları stream’in tamamından başlangıç noktalarını link’leyerek sizlerle paylaşacağım.

Sabah organizasyon alanına gelip içeri girdikten ve benim için bastırılmış, üzerinde ismimin yazılı olduğu kartımı alıp boynuma astıktan sonra Kyle Simpson’ın açılış konuşmasını dinlemek üzere yerime oturdum. Kyle Simpson Github üzerindeki reposundan (https://github.com/getify/You-Dont-Know-JS)) bedava şekilde okuyabileceğiniz popüler You Don’t Know JS serisinin yazarı, uzun yıllara dayanan bir programcılık geçmişi var ve web’in yıllar içerisinde geçirdiği evrimin her evresinde bulunmuş bir geliştirici. Özellikle JavaScript’in gün geçtikçe compile target’a dönüşmesi üzerine dile getirdikleri çok hoşuma gitti. Her birimizin web geliştirmeye giriş döneminde tarayıcıda ilgimizi çeken bir web sayfasında sağ tıklayıp “Kaynağı Gör”’ü seçerek, HTML’i inceleyerek ve anlamaya çalışarak bu işi öğrenmesi üzerinden hareketle gün geçtikçe kompleksleşen Web ve JavaScript geliştirme kültürünün eğlenceli ve düşündürücü bir eleştirisini yaptı.

İlk konuşmanın ardından Node.js salonuna geçtim ve orada uzun süredir detaylı incelemek istediğim Quasar Framework üzerine yaratıcısı Razvan Stoenescu’nun sunumunu izledim. Tek bir codebase üzerinden hybrid mobile, desktop (electron) ve web geliştirme yapmanızı sağlayan, arkaplanda Vue.js kullanan overall bir çözüm sunuyor. Ufak bir uygulama yapmak için beni tavladı diyebilirim.

Waleed Ashraf’in multiple Node.js process’lerini yönetmek için RabbitMQ ve PM2 kullanmak üzerine sunumu özellikle Node.js’in built-in cluster yapısından daha yönetilebilir ve ölçeklenebilir bir mimariye geçme deneyimi olarak önemli noktalara değindi.

https://waleedashraf.me/switching-from-cluster-module-to-pm2-and-rabbitmq-in-nodejs/

Bu iki sunumdan sonra tekrar ana salona döndüm ve Webpack’in yaratıcısı Tobias Koppers’in Webpack 5'le ilgili konuşmasını dinledim. Bu sürümle birlikte bazı breaking change’ler olduğundan ve bu tercihleri neden/nasıl aldıklarından bahsetti.

Webpack 5

En ilgimi çeken sunumlardan biri Andre Staltz’ın bir fonksiyonel programlama paradigması olarak Lens’lerden bahsettiği ve Cycle.js ile React/Vue örnekleri üzerinden state yönetimine dair örneklerle süslediği konuşması oldu.

Cycle.js

Bu konuşma sonrasında ana salonu tekrar üzülerek terk ettim zira Babel mainter’ı Henry Zhu’nun açık kaynaklı bir projede görev almak/geliştirici olmak üzerine anlattıklarını merak ediyordum; lakin görev bilinciyle tekrar Node.js salonuna yöneldim.

Viktor Turskyi kendi çalıştığı firmada yaşadıkları deneyimleri ve clean architecture namına Node.js — Express üzerinde uyguladıkları taktikleri anlattığı sunumu başarılıydı, bir de kullandıkları mimariyi Github üzerinde yayınlayacaklarından bahsetti.

Matthias Dugué’nin stateless, zero-knowledge backends sunumu özellikle Node.js — Mongodb — Express stack’i üzerinde JWT kullanımı ve user authentication süreçleriyle ilgili ilginç noktalar içeriyor.

Max Gallo, RxJS’teki map ve filter operator’larını, observer’ları ve operator’ların nasıl chain edildiğini canlı kodlama sekansı üzerinden anlattı sunumunda, yine fonksiyonel programlamaya yönelik başarılı bulduğum bir içerik sundu diyebilirim.

RxJs

Paulo Lopes’in GraalVM üzerinde GraalJS kullanarak, alternatif, V8'siz bir Node.js runtime’ı üzerinde yaptığı benchmark çalışmalarıyla en az Go ya da Rust gibi dillerle kazanılan performansların ötesine nasıl geçebildiğini anlattığı sunumu yine en etkileyici içeriklerden biriydi.

Node.js core contributor’lerinden Ruben Bridgewater’ın Node.js uygulamalarında hata yönetimi sunumu özellikle promise ve async/await kullanan codebase’ler için gerçek hayattan örneklerle süslenmiş bir konuşmaydı.

Financial Times’ta çalışan Katie Koschland’in Artillery ile yük testi metodolojisi üzerine yaşanmış tecrübelerle bezediği sunumu hepimizin dönem dönem yüzleşmek durumunda kaldığı nereden çıktığı belli olmayan çılgın bug’lar temasına sahipti.

Günün son iki konuşması için ana salona geri döndüm. Christian Bromann’in otomatik performans testleri üzerine verdiği bilgiler ilgi çekiciydi, bizim de Zingat bünyesinde en fazla önem verdiğimiz konulardan biri olduğu için dikkatle dinledim.

David Rousset, organizasyonun son sunumunda VR, mobile ve web için WebGL ve Babylon.js kullanarak bir PWA olarak geliştirdiği oyunu üzerinden mevzubahis teknolojileri son derece eğlenceli biçimde izleyicilere sundu.

Katılımın son derece yoğun olduğu organizasyon geriye keyifli anılar ve yeni arkadaşlıklar bıraktı. Önümüzdeki senelerde de daha da kalabalık bir ekiple orada olmayı diliyorum.

* Bu yazı ilk olarak labs.zingat.com adresinde belirtilen tarihte yayımlanmıştır.