Bekerja dengan perwakilan layanan Azure menggunakan Azure CLI

Alat otomatis yang menggunakan layanan Azure harus selalu memiliki izin terbatas. Sebagai alternatif membuat aplikasi masuk sebagai pengguna dengan hak istimewa penuh, Azure menawarkan perwakilan layanan.

Apa itu perwakilan layanan Azure?

Perwakilan layanan Azure adalah identitas yang dibuat untuk digunakan dengan aplikasi, layanan yang dihosting, dan alat otomatis untuk mengakses sumber daya Azure. Akses ini dibatasi oleh peran yang ditetapkan untuk perwakilan layanan, yang memberi Anda kontrol atas sumber daya mana yang dapat diakses dan pada tingkat mana. Untuk alasan keamanan, selalu disarankan untuk menggunakan perwakilan layanan dengan alat otomatis dibanding mengizinkan mereka masuk dengan identitas pengguna.

Artikel ini berisi langkah-langkah untuk membuat, mendapatkan informasi tentang, dan mengatur ulang perwakilan layanan Azure dengan Azure CLI.

1. Buat perwakilan layanan

Buat perwakilan layanan Azure dengan perintah az ad sp create-for-rbac.

Kunci appId dan tenant muncul dalam output az ad sp create-for-rbac dan digunakan dalam autentikasi perwakilan layanan. Catat nilainya, tetapi nilai dapat diambil kapan saja dengan daftar az ad sp.

Saat membuat perwakilan layanan, pilih jenis autentikasi masuk yang digunakannya. Ada dua jenis autentikasi yang tersedia untuk perwakilan layanan Azure: autentikasi berbasis kata sandi dan autentikasi berbasis sertifikat.

Peringatan

Saat Anda membuat perwakilan layanan Azure menggunakan perintah az ad sp create-for-rbac, output akan menyertakan info masuk yang harus dilindungi. Pastikan Anda tidak menyertakan info masuk ini dalam kode atau memasukkan info masuk ke dalam kontrol sumber Anda. Sebagai alternatif, pertimbangkan untuk menggunakan identitas terkelola jika tersedia untuk mencegah penggunaan info masuk.

Untuk mengurangi risiko perwakilan layanan disusupi, tetapkan peran yang lebih spesifik dan persempit cakupan ke sumber daya atau grup sumber daya. Untuk informasi selengkapnya, lihat Langkah-langkah untuk menambahkan penetapan peran.

Autentikasi berbasis kata sandi

Dengan autentikasi berbasis kata sandi, kata sandi acak akan dibuat untuk Anda. Jika Anda tidak menentukan nilai parameter --name, nama yang berisi stempel waktu akan dibuat untuk Anda. Anda harus menentukan --scopes karena nilai ini tidak memiliki default. Jika ingin, Anda dapat mengatur penetapan peran nanti menggunakan az role assignment create.

# Create a service principal with required parameter
az ad sp create-for-rbac --scopes /subscriptions/mySubscriptionID

# Create a service principal for a resource group using a preferred name and role
az ad sp create-for-rbac --name myServicePrincipalName \
                         --role reader \
                         --scopes /subscriptions/mySubscriptionID/resourceGroups/myResourceGroupName

Anda juga dapat membuat perwakilan layanan menggunakan variabel.

let "randomIdentifier=$RANDOM*$RANDOM"  
servicePrincipalName="msdocs-sp-$randomIdentifier"
roleName="azureRoleName"
subscriptionID=$(az account show --query id -o tsv)
# Verify the ID of the active subscription
echo "Using subscription ID $subscriptionID"
resourceGroup="myResourceGroupName"

echo "Creating SP for RBAC with name $servicePrincipalName, with role $roleName and in scopes /subscriptions/$subscriptionID/resourceGroups/$resourceGroup"
az ad sp create-for-rbac --name $servicePrincipalName --role $roleName --scopes /subscriptions/$subscriptionID/resourceGroups/$resourceGroup

Output perwakilan layanan dengan autentikasi kata sandi menyertakan kunci password. Pastikan Anda menyalin nilai ini - nilai itu tidak dapat diambil kembali. Jika lupa kata sandi, atur ulang info masuk perwakilan layanan.

Autentikasi berbasis sertifikat

Untuk autentikasi berbasis sertifikat, gunakan parameter --cert. Parameter ini mewajibkan Anda memiliki sertifikat yang ada. Pastikan alat apa pun yang menggunakan perwakilan layanan ini memiliki akses ke kunci privat sertifikat. Sertifikat harus dalam format ASCII seperti PEM, CER, atau DER. Teruskan sertifikat sebagai string, atau gunakan format @path untuk memuat sertifikat dari file.

Catatan

Saat menggunakan file PEM, CERTIFICATE harus ditambahkan ke PRIVATE KEY di dalam file.

az ad sp create-for-rbac --name myServicePrincipalName \
                         --role roleName \
                         --scopes /subscriptions/mySubscriptionID/resourceGroups/myResourceGroupName \
                         --cert "-----BEGIN CERTIFICATE-----
...
-----END CERTIFICATE-----"
az ad sp create-for-rbac --name myServicePrincipalName \
                         --role roleName \
                         --scopes /subscriptions/mySubscriptionID/resourceGroups/myResourceGroupName \
                         --cert @/path/to/cert.pem

Parameter --keyvault dapat ditambahkan untuk menggunakan sertifikat di Azure Key Vault. Dalam hal ini, nilai --cert adalah nama sertifikat.

az ad sp create-for-rbac --name myServicePrincipalName \
                         --role roleName \
                         --scopes /subscriptions/mySubscriptionID/resourceGroups/myResourceGroupName \
                         --cert certificateName \
                         --keyvault vaultName

Untuk membuat sertifikat yang ditandatangani sendiri untuk autentikasi, gunakan parameter --create-cert:

az ad sp create-for-rbac --name myServicePrincipalName \
                         --role roleName \
                         --scopes /subscriptions/mySubscriptionID/resourceGroups/myResourceGroupName \
                         --create-cert

Output konsol:

Creating a role assignment under the scopes of "/subscriptions/myId"
Please copy C:\myPath\myNewFile.pem to a safe place.
When you run 'az login', provide the file path in the --password parameter
{
  "appId": "myAppId",
  "displayName": "myDisplayName",
  "fileWithCertAndPrivateKey": "C:\\myPath\\myNewFile.pem",
  "name": "http://myName",
  "password": null,
  "tenant": "myTenantId"
}

Isi file PEM baru:

-----BEGIN PRIVATE KEY-----
myPrivateKeyValue
-----END PRIVATE KEY-----
-----BEGIN CERTIFICATE-----
myCertificateValue
-----END CERTIFICATE-----

Catatan

Perintah az ad sp create-for-rbac --create-cert membuat perwakilan layanan dan file PEM. File PEM berisi PRIVATE KEY dan CERTIFICATE diformat dengan benar.

Parameter --keyvault dapat ditambahkan untuk menyimpan sertifikat di Azure Key Vault. Saat menggunakan --keyvault, parameter --certwajib ada.

az ad sp create-for-rbac --name myServicePrincipalName \
                         --role roleName \
                         --scopes /subscriptions/mySubscriptionID/resourceGroups/myResourceGroupName \
                         --create-cert \
                         --cert certificateName \
                         --keyvault vaultName

Jika sertifikat tidak disimpan di Key Vault, output tidak akan menyertakan kunci fileWithCertAndPrivateKey. Nilai kunci ini memberi tahu Anda lokasi penyimpanan sertifikat yang dihasilkan. Pastikan Anda menyalin sertifikat ke lokasi yang aman, atau Anda tidak dapat masuk dengan perwakilan layanan ini.

Jika Anda kehilangan akses ke kunci privat sertifikat, atur ulang info masuk perwakilan layanan.

Mengambil sertifikat dari Key Vault

Untuk sertifikat yang disimpan di Key Vault, ambil sertifikat dengan kunci privatnya dengan az keyvault secret show dan konversi menjadi file PEM. Di Key Vault, nama rahasia sertifikat sama dengan nama sertifikat.

az keyvault secret download --file /path/to/cert.pfx --vault-name VaultName --name CertName --encoding base64
openssl pkcs12 -in cert.pfx -passin pass: -out cert.pem -nodes

Mengonversi file PKCS12 yang ada

Jika Anda sudah memiliki file PKCS#12, Anda dapat mengonversinya ke format PEM menggunakan OpenSSL. Jika Anda memiliki kata sandi, ubah passin argumen .

openssl pkcs12 -in fileName.p12 -clcerts -nodes -out fileName.pem -passin pass:

2. Dapatkan perwakilan layanan yang ada

Daftar perwakilan layanan di penyewa dapat diambil dengan az ad sp list. Secara default, perintah ini menampilkan 100 perwakilan layanan pertama untuk penyewa Anda. Untuk mendapatkan semua perwakilan layanan penyewa, gunakan parameter --all. Diperlukan waktu yang lama untuk mengambil daftar ini, jadi sebaiknya Anda memfilter daftar dengan salah satu parameter berikut:

  • --display-name meminta perwakilan layanan yang memiliki awalan yang sesuai dengan nama yang disediakan. Nama tampilan perwakilan layanan adalah nilai yang ditetapkan dengan parameter --name selama pembuatan. Jika Anda tidak mengatur --name selama pembuatan perwakilan layanan, awalan namanya adalah azure-cli-.
  • --spn memfilter dengan pencocokan persis nama perwakilan layanan. Nama perwakilan layanan selalu dimulai dengan https://. jika nilai yang digunakan untuk --name bukan URI, nilai ini adalah https:// diikuti oleh nama tampilan.
  • --show-mine hanya meminta perwakilan layanan yang dibuat oleh pengguna yang masuk.
  • --filter mengambil filter OData, dan melakukan pemfilteran sisi server. Metode ini lebih direkomendasikan dari pemfilteran sisi klien dengan parameter --query CLI. Untuk mempelajari filter OData, lihat Sintaks ekspresi OData untuk filter.

Informasi yang ditampilkan untuk objek perwakilan layanan bersifat verbose. Untuk mendapatkan informasi yang diperlukan untuk masuk saja, gunakan string kueri [].{id:appId, tenant:appOwnerTenantId}. Misalnya, untuk mendapatkan informasi masuk untuk semua perwakilan layanan yang dibuat oleh pengguna yang saat ini masuk:

az ad sp list --show-mine --query "[].{id:appId, tenant:appOwnerTenantId}"

Penting

az ad sp list atau az ad sp show mendapatkan pengguna dan penyewa, tapi bukan rahasia autentikasi maupun metode autentikasi. Rahasia untuk sertifikat di Key Vault dapat diambil dengan az keyvault secret show, tapi rahasia lainnya tidak disimpan secara default. Jika Anda lupa metode atau rahasia autentikasi, atur ulang info masuk perwakilan layanan.

3. Kelola peran perwakilan layanan

Azure CLI memiliki perintah berikut untuk mengelola penetapan peran:

Peran Kontributor memiliki izin penuh untuk membaca dan menulis ke akun Azure. Peran Pembaca lebih ketat, dengan akses baca-saja. Untuk informasi selengkapnya tentang Kontrol Akses Berbasis Peran (RBAC) dan peran, lihat RBAC: Peran bawaan.

Contoh ini menambahkan peran Pembaca dan menghapus peran Kontributor:

az role assignment create --assignee appID \
                          --role Reader \
                          --scope /subscriptions/mySubscriptionID/resourceGroups/myResourceGroupName

az role assignment delete --assignee appID \
                          --role Contributor \
                          --scope /subscriptions/mySubscriptionID/resourceGroups/myResourceGroupName

Penambahan peran tidak membatasi izin yang ditetapkan sebelumnya. Ketika membatasi izin perwakilan layanan, peran Kontributor sebaiknya dihapus jika sebelumnya telah ditetapkan.

Perubahan ini dapat diverifikasi dengan mencantumkan peran yang ditetapkan:

az role assignment list --assignee appID

4. Masuk menggunakan perwakilan layanan

Uji info masuk dan izin perwakilan layanan baru dengan masuk. Untuk masuk dengan perwakilan layanan, Anda memerlukan appId, tenant, dan info masuk.

Untuk masuk dengan perwakilan layanan menggunakan kata sandi:

az login --service-principal --username appID --password PASSWORD --tenant tenantID

Untuk masuk dengan sertifikat, ini harus tersedia secara lokal sebagai file PEM atau DER, dalam format ASCII. Jika menggunakan file PEM, PRIVATE KEY dan CERTIFICATE harus ditambahkan sekaligus di dalam file.

az login --service-principal --username appID --tenant tenantID --password /path/to/cert

Untuk mempelajari lebih lanjut cara masuk dengan perwakilan layanan, lihat Masuk dengan Azure CLI.

5. Buat sumber daya menggunakan perwakilan layanan

Bagian berikut berisi contoh cara membuat sumber daya untuk Azure Storage dengan perwakilan layanan, menggunakan perintah berikut:

Untuk masuk dengan perwakilan layanan, Anda memerlukan appID, tenantID, dan password ditampilkan sebagai respons saat Anda membuat perwakilan layanan.

  1. Masuk sebagai perwakilan layanan.

    az login --service-principal --username appID --password PASSWORD --tenant tenantID
    
  2. Buat grup sumber daya untuk menyimpan semua sumber daya yang digunakan untuk proyek mulai cepat, tutorial, atau pengembangan yang sama.

    az group create --location westus --name myResourceGroupName
    
  3. Membuat akun penyimpanan.

    Untuk Azure Storage, nilai yang valid untuk parameter <KIND> adalah:

    • BlobStorage
    • BlockBlobStorage
    • FileStorage
    • Penyimpanan
    • StorageV2
    az storage account create --name myStorageAccountName --resource-group myResourceGroupName --kind <KIND> --sku F0 --location westus --yes
    
  4. Dapatkan kunci sumber daya yang Anda gunakan dalam kode untuk melakukan autentikasi ke akun penyimpanan Azure.

    az storage account keys list --name myStorageAccountName --resource-group myResourceGroupName
    

6. Atur ulang info masuk

Jika Anda kehilangan kredensial untuk perwakilan layanan, gunakan az ad sp credential reset. Perintah reset menggunakan argumen yang sama dengan az ad sp create-for-rbac.

az ad sp credential reset --name myServicePrincipal_appID_or_name

7. Pemecahan masalah

Hak istimewa tidak memadai

Jika akun Anda tidak memiliki izin untuk membuat perwakilan layanan, az ad sp create-for-rbac akan menampilkan pesan kesalahan yang berisi "Hak istimewa tidak memadai untuk menyelesaikan operasi". Hubungi admin Azure Active Directory untuk membuat perwakilan layanan.

Penyewa tidak valid

Jika telah menentukan ID langganan yang tidak valid, Anda akan melihat pesan kesalahan "Permintaan tidak memiliki langganan atau penyedia sumber tingkat penyewa yang valid". Jika menggunakan variabel, gunakan perintah echo Bash untuk melihat nilai yang diteruskan ke perintah referensi. Gunakan az account set untuk mengubah langganan Anda atau pelajari Cara mengelola langganan Azure dengan Azure CLI.

Grup sumber daya tidak ditemukan

Jika telah menentukan nama grup sumber daya yang tidak valid, Anda akan melihat pesan kesalahan "Grup sumber daya 'nama' tidak dapat ditemukan". Jika menggunakan variabel, gunakan perintah echo Bash untuk melihat nilai yang diteruskan ke perintah langganan dan referensi. Gunakan az group list untuk melihat grup sumber daya untuk langganan saat ini, atau pelajari Cara mengelola grup sumber daya Azure dengan Azure CLI.

Otorisasi untuk menjalankan tindakan

Jika akun Anda tidak memiliki izin untuk menetapkan peran, Anda akan melihat pesan kesalahan bahwa akun Anda "tidak memiliki otorisasi untuk melakukan tindakan 'Microsoft.Authorization/roleAssignments/write'." Hubungi admin Azure Active Directory Anda untuk mengelola peran.

Lihat juga