Aracılığıyla paylaş


İşlev uygulamanızı yönetme

Azure İşlevleri bir işlev uygulaması, tek tek işlevleriniz için yürütme bağlamı sağlar. İşlev uygulaması davranışları, belirli bir işlev uygulaması tarafından barındırılan tüm işlevler için geçerlidir. İşlev uygulamasındaki tüm işlevler aynı dilde olmalıdır.

İşlev uygulamasındaki tek tek işlevler birlikte dağıtılır ve birlikte ölçeklendirilir. Aynı işlev uygulamasındaki tüm işlevler, işlev uygulaması ölçeklendirildikçe örnek başına kaynakları paylaşır.

Bağlantı dizeleri, ortam değişkenleri ve diğer uygulama ayarları her işlev uygulaması için ayrı ayrı tanımlanır. İşlev uygulamaları arasında paylaşılması gereken tüm veriler kalıcı bir depoda harici olarak depolanmalıdır.

Azure portalını kullanmaya başlama

Not

Azure portalında işlev kodunu düzenlemeyle ilgili sınırlamalar nedeniyle işlevlerinizi yerel olarak geliştirmeniz ve kod projenizi Azure'daki bir işlev uygulamasında yayımlamanız gerekir. Daha fazla bilgi için bkz . Azure portalında geliştirme sınırlamaları

İşlev uygulamanızdaki uygulama ayarlarını görüntülemek için şu adımları izleyin:

  1. Azure hesabınızı kullanarak Azure portalda oturum açın. İşlev uygulamanızı arayın ve seçin.

  2. İşlev uygulamanızın sol bölmesinde Ayarlar'ı genişletin, Ortam değişkenleri'ni ve ardından Uygulama ayarları sekmesini seçin.

    İşlev uygulamasında Uygulama ayarları sayfasının nasıl seçildiğini gösteren ekran görüntüsü.

Uygulama ayarlarıyla çalışma

Azure İşlevleri tarafından kullanılan önceden tanımlanmış uygulama ayarlarına ek olarak işlev kodunuzun gerektirdiği sayıda uygulama ayarı oluşturabilirsiniz. Daha fazla bilgi için bkz. Azure İşlevleri için uygulama ayarları başvurusu.

Bu ayarlar şifrelenmiş olarak depolanır. Daha fazla bilgi için bkz . Uygulama ayarları güvenliği.

Uygulama ayarlarını Azure portalından ve Azure CLI ile Azure PowerShell kullanarak yönetebilirsiniz. Uygulama ayarlarını Visual Studio Code'dan ve Visual Studio'dan da yönetebilirsiniz.

Uygulama ayarlarınızı görüntülemek için bkz . Azure portalında kullanmaya başlama.

Uygulama ayarları sekmesi, işlev uygulamanız tarafından kullanılan ayarları korur:

  1. Uygulama ayarlarının değerlerini görmek için Değerleri göster'i seçin.

  2. Ayar eklemek için + Ekle'yi seçin ve ardından yeni anahtar-değer çiftinin Adı ve Değeri'ni girin.

    bir işlev uygulamasında Uygulama ayarları sayfasını gösteren ekran görüntüsü.

Uygulama ayarlarını kullanma

İşlev uygulaması ayarları değerleri, kodunuz içinde ortam değişkenleri olarak da okunabilir. Daha fazla bilgi için bu dile özgü başvuru makalelerinin Ortam değişkenleri bölümüne bakın:

Bir işlev uygulamasını yerel olarak geliştirirken, bu değerlerin yerel kopyalarını local.settings.json proje dosyasında tutmanız gerekir. Daha fazla bilgi için bkz . Yerel ayarlar dosyası.

FTPS dağıtım ayarları

Azure İşlevleri, FTPS kullanarak işlev uygulamanıza proje kodu dağıtmayı destekler. Bu dağıtım yöntemi tetikleyicileri eşitlemenizi gerektirdiği için önerilmez. Proje dosyalarını güvenli bir şekilde aktarmak için her zaman FTP'yi değil FTPS'yi kullanın.

FTPS dağıtımı için gereken kimlik bilgilerini almak için şu yöntemlerden birini kullanın:

İşlev uygulamanızın yayımlama profilini indirerek Azure portalında FTPS yayımlama kimlik bilgilerini alabilirsiniz.

Önemli

Yayımlama profili önemli güvenlik kimlik bilgilerini içerir. İndirilen dosyanın güvenliğini her zaman yerel bilgisayarınızda sağlayın.

İşlev uygulamanızın yayımlama profilini indirmek için:

  1. İşlev uygulamasının Genel Bakış sayfasını ve ardından Yayımlama profilini al'ı seçin.

    Yayımlama profilini indir

  2. Dosyanın içeriğini kaydedin ve kopyalayın.

  1. dosyasında özniteliğine publishProfile publishMethod="FTP"sahip öğesini bulun. Bu öğede publishUrl, , userNameve userPWD öznitelikleri FTPS yayımlama için hedef URL'yi ve kimlik bilgilerini içerir.

Barındırma planı türü

bir işlev uygulaması oluşturduğunuzda, uygulamanın çalıştığı bir barındırma planı da oluşturursunuz. Bir planda bir veya daha fazla işlev uygulaması olabilir. İşlevlerinizin işlevselliği, ölçeklendirmesi ve fiyatlandırması planın türüne bağlıdır. Daha fazla bilgi için bkz. Azure İşlevleri barındırma seçenekleri.

İşlev uygulamanız tarafından kullanılan plan türünü Azure portalından veya Azure CLI veya Azure PowerShell API'lerini kullanarak belirleyebilirsiniz.

Aşağıdaki değerler plan türünü gösterir:

Plan türü Azure portal Azure CLI/PowerShell
Tüketim Tüketim Dynamic
Premium ElasticPremium ElasticPremium
Ayrılmış (App Service) Çeşitli Çeşitli
  1. İşlev uygulamanız tarafından kullanılan plan türünü belirlemek için Azure portalındaki işlev uygulamasının Genel Bakış sayfasındaki App Service Planı'na bakın.

    İşlev uygulamasının Genel Bakış sayfasındaki App Service Planı bağlantısını gösteren ekran görüntüsü.

  2. Fiyatlandırma katmanını görmek için App Service Planının adını seçin ve ardından sol bölmeden Ayarlar > Özellikleri'ni seçin.

Geçişi planlama

İşlev uygulamasını Tüketim planı ile Windows'ta Premium plan arasında geçirebilirsiniz. Planlar arasında geçiş yaparken aşağıdaki noktaları göz önünde bulundurun:

  • Ayrılmış (App Service) planına doğrudan geçiş desteklenmez.
  • Linux'ta geçiş desteklenmez.
  • Kaynak plan ve hedef plan aynı kaynak grubunda ve coğrafi bölgede olmalıdır. Daha fazla bilgi için bkz . Uygulamayı başka bir App Service planına taşıma.
  • Belirli CLI komutları geçişin yönüne bağlıdır.
  • İşlev uygulaması planlar arasında geçirilirken işlev yürütmelerinizde kapalı kalma süresi oluşur.
  • Aynı Azure Dosyalar paylaşımı uygulama tarafından geçiş öncesinde ve sonrasında kullanıldığından, duruma ve uygulamaya özgü diğer içerik korunur.

Planınızı şu araçları kullanarak geçirebilirsiniz:

Farklı bir plana geçmek için Azure portalını kullanabilirsiniz.

Windows'ta uygulamanız için geçiş yönünü seçin.

  1. Azure portalında Tüketim planı uygulamanıza gidin ve App Service planı altında App Service planını değiştir'i seçin.

  2. Plan türü altında Premium'u seçin, yeni bir Premium plan oluşturun ve Tamam'ı seçin.

Daha fazla bilgi için bkz . Uygulamayı başka bir App Service planına taşıma.

İşlev erişim anahtarlarınızı alma

HTTP ile tetiklenen işlevler genellikle şu biçimde bir URL kullanılarak çağrılabilir: https://<APP_NAME>.azurewebsites.net/api/<FUNCTION_NAME>. İşlevinizin yetkilendirmesi dışında anonymousbir değer ayarlandığında, isteğinizde bir erişim anahtarı da sağlamanız gerekir. Erişim anahtarı, sorgu dizesi kullanılarak ?code= URL'de veya istek üst bilgisinde sağlanabilir. Daha fazla bilgi için bkz . İşlev erişim anahtarları. Erişim anahtarlarınızı almanın birkaç yolu vardır.

  1. Azure portalında oturum açın, ardından İşlev Uygulaması'nı arayın ve seçin.

  2. Doğrulamak istediğiniz işlevi seçin.

  3. Sol bölmede İşlevler'i genişletin ve uygulama anahtarları'nı seçin.

    Uygulama anahtarları sayfası görüntülenir. Bu sayfada konak anahtarları görüntülenir ve bu anahtarlar uygulamadaki herhangi bir işleve erişmek için kullanılabilir. Sistem anahtarı da görüntülenir ve bu da herkese tüm işlev uygulaması API'lerine yönetici düzeyinde erişim sağlar.

Ayrıca, belirli bir işlevin anahtarını kullanarak da en az ayrıcalık uygulayabilirsiniz. Bunu yapmak için HTTP ile tetiklenen işlevinizde Geliştirici'nin altında İşlev anahtarları'nı seçin.

Azure portalında geliştirme sınırlamaları

İşlevlerinizi Azure portalında geliştirirken şu sınırlamaları göz önünde bulundurun:

  • Portal içi düzenleme yalnızca Azure portalında oluşturulan veya en son değiştirilen işlevler için desteklenir.
  • Portal içi düzenleme yalnızca JavaScript, PowerShell, Python ve C# Betik işlevleri için desteklenir.
  • Flex Consumption planının önizleme sürümünde portal içi düzenleme desteklenmez.
  • Azure portalının dışından bir işlev uygulamasına kod dağıttığınızda, artık portalda bu işlev uygulamasının kodlarından hiçbirini düzenleyemezsiniz. Bu durumda yerel geliştirmeyi kullanmaya devam edin.
  • Derlenmiş C# işlevleri ve Java işlevleri için, işlev uygulamasını ve ilgili kaynakları portalda oluşturabilirsiniz. Ancak işlev kodu projesini yerel olarak oluşturup Azure'da yayımlamanız gerekir.

Mümkün olduğunda işlevlerinizi yerel olarak geliştirin ve kod projenizi Azure'daki bir işlev uygulamasında yayımlayın. Daha fazla bilgi için bkz. Yerel olarak Azure İşlevleri kod ve test.

Uzantıları el ile yükleme

C# sınıf kitaplığı işlevleri, uzantıları doğrudan sınıf kitaplığı projesinde bağlamaya yönelik NuGet paketlerini içerebilir. Diğer non-.NET dilleri ve C# betiği için uzantı paketlerini kullanmanız gerekir. Uzantıları el ile yüklemeniz gerekiyorsa, Azure İşlevleri Core Tools'u yerel olarak kullanarak bunu yapabilirsiniz. Uzantı paketlerini kullanamıyorsanız ve yalnızca portalda çalışabiliyorsanız, extensions.csproj dosyasını doğrudan sitede el ile oluşturmak için Gelişmiş Araçlar'ı (Kudu) kullanmanız gerekir. önce öğesini host.json dosyasından kaldırdığınızdan extensionBundle emin olun.

Aynı işlem, uygulamanıza eklemeniz gereken diğer tüm dosyalarda da çalışır.

Önemli

Mümkün olduğunda, dosyaları doğrudan Azure'daki işlev uygulamanızda düzenlemeyin. Uygulama dosyalarınızı yerel olarak indirmenizi, uzantıları ve diğer paketleri yüklemek için Core Tools'u kullanmanızı, değişikliklerinizi doğrulamanızı ve ardından Core Tools veya desteklenen diğer dağıtım yöntemlerinden birini kullanarak uygulamanızı yeniden yayımlamanızı öneririz.

Azure portalında yerleşik olarak bulunan İşlevler düzenleyicisi, işlev kodunuzu ve yapılandırma dosyalarınızı doğrudan portalda güncelleştirmenizi sağlar:

  1. İşlev uygulamanızı seçin, ardından İşlevler'in altında İşlevler'i seçin.

  2. İşlevinizi seçin ve Geliştirici'nin altında Kod + test'i seçin.

  3. Düzenlemek istediğiniz dosyayı seçin ve bitirdiğinizde Kaydet'i seçin.

Uygulamanın kökündeki function.proj veya extensions.csproj gibi dosyaların Gelişmiş Araçlar (Kudu) kullanılarak oluşturulması ve düzenlenmesi gerekir:

  1. İşlev uygulamanızı seçin, Geliştirme araçları'nı genişletin ve ardından Gelişmiş araçlar>Git'i seçin.

  2. İstenirse, Azure kimlik bilgilerinizle Kaynak Denetim Yöneticisi (SCM) sitesinde oturum açın.

  3. Hata ayıklama konsolu menüsünden CMD'yi seçin.

  4. adresine .\site\wwwrootgidin, üstteki artı (+) düğmesini seçin ve Yeni dosya'yı seçin.

  5. Dosyaya gibi extensions.csprojbir ad verin ve Enter tuşuna basın.

  6. Yeni dosyanın yanındaki düzenle düğmesini seçin, dosyaya kod ekleyin veya güncelleştirin ve ardından Kaydet'i seçin.

  7. extensions.csproj gibi bir proje dosyası için aşağıdaki komutu çalıştırarak extensions projesini yeniden oluşturun:

    dotnet build extensions.csproj
    

Platform özellikleri

İşlev uygulamaları, bunların bakımını yapan Azure Uygulaması Hizmeti platformunda çalışır. Bu nedenle işlev uygulamalarınız Azure'ın temel web barındırma platformunun özelliklerinin çoğuna erişebilir. Azure portalını kullandığınızda, sol bölmede App Service platformunun işlev uygulamalarınızda kullanabileceğiniz birçok özelliğine erişebilirsiniz.

Aşağıdaki matris, barındırma planı ve işletim sistemi ile Azure portalı özellik desteğini gösterir:

Özellik Tüketim planı Premium planı Ayrılmış plan
Gelişmiş araçlar (Kudu) Windows: ✔
Linux: X
App Service düzenleyicisi Windows: ✔
Linux: X
Windows: ✔
Linux: X
Windows: ✔
Linux: X
Yedeklemeler X X
Konsol Windows: komut satırı
Linux: X
Windows: komut satırı
Linux: SSH
Windows: komut satırı
Linux: SSH

Bu makalenin geri kalanında portalda işlev uygulamalarınız için yararlı olan aşağıdaki özelliklere odaklanılır:

App Service ayarlarıyla çalışma hakkında daha fazla bilgi için bkz. Azure Uygulaması Hizmet Ayarlarını Yapılandırma.

App Service düzenleyicisi

App Service düzenleyicisi, JSON yapılandırma dosyalarını ve kod dosyalarını değiştirmek için kullanabileceğiniz gelişmiş bir portal içi düzenleyicidir. Bu seçeneğin seçilmesi, temel bir düzenleyici ile ayrı bir tarayıcı sekmesi başlatır. Bu düzenleyici Git deposuyla tümleştirmenize, kodu çalıştırmanıza ve hatalarını ayıklamanıza ve işlev uygulaması ayarlarını değiştirmenize olanak tanır. Bu düzenleyici, yerleşik işlev düzenleyicisine kıyasla işlevleriniz için gelişmiş bir geliştirme ortamı sağlar.

App Service düzenleyicisini gösteren ekran görüntüsü.

İşlevlerinizi yerel bilgisayarınızda geliştirmeyi düşünmenizi öneririz. Yerel olarak geliştirip Azure'da yayımladığınızda, proje dosyalarınız Azure portalında salt okunur olur. Daha fazla bilgi için bkz. Yerel olarak Azure İşlevleri kod ve test.

Konsol

Komut satırından işlev uygulamanızla etkileşime geçmek istediğinizde portal içi konsol ideal bir geliştirici aracıdır. Yaygın komutlar, dizin ve dosya oluşturma ve gezintinin yanı sıra toplu iş dosyalarını ve betiklerini yürütmeyi içerir.

İşlev uygulaması konsolunu gösteren ekran görüntüsü.

Yerel olarak geliştirme yaparken Azure İşlevleri Core Tools ve Azure CLI'yi kullanmanızı öneririz.

Gelişmiş araçlar (Kudu)

App Service için gelişmiş araçlar (Kudu olarak da bilinir), işlev uygulamanızın gelişmiş yönetim özelliklerine erişim sağlar. Kudu'dan sistem bilgilerini, uygulama ayarlarını, ortam değişkenlerini, site uzantılarını, HTTP üst bilgilerini ve sunucu değişkenlerini yönetirsiniz. Kudu'yu, işlev uygulamanızın SCM uç noktasına göz atarak da başlatabilirsiniz; örneğin: https://<myfunctionapp>.scm.azurewebsites.net/.

App Service (Kudo) için gelişmiş araçları gösteren ekran görüntüsü.

Dağıtım Merkezi

İşlev kodunuzu geliştirmek ve korumak için bir kaynak denetimi çözümü kullandığınızda, Dağıtım Merkezi kaynak denetiminden derlemenizi ve dağıtmanızı sağlar. Güncelleştirmeler yaptığınızda projeniz oluşturulur ve Azure'a dağıtılır. Daha fazla bilgi için bkz. Azure İşlevleri dağıtım teknolojileri.

Çıkış noktaları arası kaynak paylaşma

İstemcide kötü amaçlı kod yürütülmesini önlemek için modern tarayıcılar, web uygulamalarından ayrı bir etki alanında çalışan kaynaklara yönelik istekleri engeller. Çıkış noktaları arası kaynak paylaşımı (CORS), üst Access-Control-Allow-Origin bilginin işlev uygulamanızda uç noktaları çağırmasına izin verilen kaynakları bildirmesine olanak tanır.

İşlev uygulamanız için İzin verilen çıkış noktaları listesini yapılandırdığınızda, Access-Control-Allow-Origin üst bilgi işlev uygulamanızdaki HTTP uç noktalarındaki tüm yanıtlara otomatik olarak eklenir.

İşlev uygulamanızın CORS listesini yapılandırmayı gösteren ekran görüntüsü.

Başka bir etki alanı girişi varsa joker karakter (*) yoksayılır.

Kimlik Doğrulaması

İşlevler bir HTTP tetikleyicisi kullandığında, çağrıların önce kimlik doğrulamasının yapılmasını gerektirebilirsiniz. App Service, Microsoft Entra kimlik doğrulamasını ve Facebook, Microsoft ve Twitter gibi sosyal sağlayıcılarla oturum açmayı destekler. Belirli kimlik doğrulama sağlayıcılarını yapılandırma hakkında bilgi için bkz. hizmet kimlik doğrulamasına genel bakış Azure Uygulaması.

İşlev uygulaması için kimlik doğrulamasını yapılandırmayı gösteren ekran görüntüsü.