

Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.

# Membuat snapshot indeks di Amazon Service OpenSearch
<a name="managedomains-snapshots"></a>

Snapshot di Amazon OpenSearch Service adalah cadangan indeks dan status klaster. *Status* termasuk pengaturan klaster, informasi simpul, pengaturan indeks, dan alokasi serpihan.

OpenSearch Snapshot layanan datang dalam bentuk berikut:
+ **Snapshot otomatis** hanya untuk pemulihan klaster. Anda dapat menggunakannya untuk memulihkan domain Anda dalam peristiwa status klaster merah atau kehilangan data. Untuk informasi selengkapnya, lihat [Memulihkan snapshot](managedomains-snapshot-restore.md) di bawah ini. OpenSearch Layanan menyimpan snapshot otomatis dalam bucket Amazon S3 yang telah dikonfigurasi sebelumnya tanpa biaya tambahan.
+ **Snapshot manual** adalah untuk pemulihan klaster *atau* untuk memindahkan data dari satu klaster ke klaster lainnya. Anda harus memulai snapshot manual. Snapshot ini disimpan dalam bucket Amazon S3 Anda sendiri dan biaya S3 standar berlaku. Jika Anda memiliki snapshot dari OpenSearch kluster yang dikelola sendiri, Anda dapat menggunakan snapshot tersebut untuk bermigrasi ke domain Layanan. OpenSearch Untuk informasi selengkapnya, lihat [Migrasi ke OpenSearch Layanan Amazon](migration.md).

Semua domain OpenSearch Layanan mengambil snapshot otomatis, tetapi frekuensinya berbeda dengan cara berikut:
+ Untuk domain yang berjalan OpenSearch atau Elasticsearch 5.3 dan yang lebih baru, OpenSearch Layanan mengambil snapshot otomatis setiap jam dan mempertahankan hingga 336 di antaranya selama 14 hari. Cuplikan per jam tidak terlalu mengganggu karena sifat inkrementalnya. Mereka juga menyediakan titik pemulihan yang lebih baru jika terjadi masalah domain.
+ Untuk domain yang menjalankan Elasticsearch 5.1 dan yang lebih lama, OpenSearch Layanan mengambil snapshot otomatis harian selama jam yang Anda tentukan, mempertahankan hingga 14 di antaranya, dan tidak menyimpan data snapshot apa pun selama lebih dari 30 hari.

Jika klaster Anda memasuki status merah, semua snapshot otomatis gagal selagi status klaster tetap ada. Jika Anda tidak memperbaiki masalah dalam waktu dua minggu, Anda dapat kehilangan data di klaster Anda secara permanen. Untuk langkah-langkah pemecahan masalah, lihat [Status klaster merah](handling-errors.md#handling-errors-red-cluster-status).

## Prasyarat
<a name="managedomains-snapshot-prerequisites"></a>

Untuk membuat snapshot secara manual, Anda perlu bekerja dengan IAM dan Amazon S3. Pastikan Anda memenuhi prasyarat berikut sebelum Anda mencoba untuk mengambil snapshot:


****  

| Prasyarat  | Deskripsi | 
| --- | --- | 
| Bucket S3 | Buat bucket S3 untuk menyimpan snapshot manual untuk domain OpenSearch Layanan Anda. Untuk petunjuknya, lihat [Membuat bucket tujuan umum](https://docs.aws.amazon.com/AmazonS3/latest/userguide/create-bucket-overview.html) di *Panduan Pengguna Layanan Penyimpanan Sederhana Amazon*. Ingat nama bucket untuk menggunakannya di tempat-tempat berikut:[\[See the AWS documentation website for more details\]](http://docs.aws.amazon.com/id_id/opensearch-service/latest/developerguide/managedomains-snapshots.html)  Jangan menerapkan aturan siklus hidup Amazon Glacier ke bucket ini. Snapshot manual tidak mendukung kelas penyimpanan Amazon Glacier.  | 
| IAM Role | Buat peran IAM untuk mendelegasikan izin ke Layanan. OpenSearch Untuk petunjuk, lihat [Membuat IAM role (konsol)](https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_create_for-user.html#roles-creatingrole-user-console) di *Panduan Pengguna IAM*. Sisa dari bab ini mengacu pada peran ini sebagai `TheSnapshotRole`. **Lampirkan kebijakan IAM** Lampirkan kebijakan berikut ke `TheSnapshotRole` untuk mengizinkan akses ke bucket S3: [\[See the AWS documentation website for more details\]](http://docs.aws.amazon.com/id_id/opensearch-service/latest/developerguide/managedomains-snapshots.html) Untuk petunjuk untuk melampirkan kebijakan ke peran, lihat [Menambahkan izin identitas IAM (konsol) di Panduan](https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies_manage-attach-detach.html#add-policies-console) Pengguna *IAM*. **Edit hubungan kepercayaan** Edit hubungan kepercayaan `TheSnapshotRole` untuk menentukan OpenSearch Layanan dalam `Principal` pernyataan seperti yang ditunjukkan pada contoh berikut: [\[See the AWS documentation website for more details\]](http://docs.aws.amazon.com/id_id/opensearch-service/latest/developerguide/managedomains-snapshots.html) Untuk petunjuk untuk mengedit hubungan kepercayaan, lihat [Memperbarui kebijakan kepercayaan peran](https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_update-role-trust-policy.html) di *Panduan Pengguna IAM*. | 
| Izin |  Untuk mendaftarkan repositori snapshot, Anda harus dapat meneruskan `TheSnapshotRole` ke Layanan. OpenSearch Anda juga memerlukan akses ke tindakan `es:ESHttpPut`. Untuk memberikan kedua izin ini, lampirkan kebijakan berikut ke peran IAM yang kredensialnya digunakan untuk menandatangani permintaan: [\[See the AWS documentation website for more details\]](http://docs.aws.amazon.com/id_id/opensearch-service/latest/developerguide/managedomains-snapshots.html) Jika pengguna atau peran Anda tidak memiliki `iam:PassRole` izin untuk diteruskan`TheSnapshotRole`, Anda mungkin mengalami kesalahan umum berikut saat mencoba mendaftarkan repositori di langkah berikutnya: <pre>$ python register-repo.py<br />{"Message":"User: arn:aws:iam::123456789012:user/MyUserAccount<br />is not authorized to perform: iam:PassRole on resource:<br />arn:aws:iam::123456789012:role/TheSnapshotRole"}</pre>  | 

# Mendaftarkan repositori snapshot manual
<a name="managedomains-snapshot-registerdirectory"></a>

Anda perlu mendaftarkan repositori snapshot dengan OpenSearch Service sebelum Anda dapat mengambil snapshot indeks manual. Operasi satu kali ini mengharuskan Anda menandatangani AWS permintaan dengan kredensil yang diizinkan untuk diakses`TheSnapshotRole`, seperti yang dijelaskan dalam. [Prasyarat](managedomains-snapshots.md#managedomains-snapshot-prerequisites)

## Langkah 1: Petakan peran snapshot di OpenSearch Dasbor (jika menggunakan kontrol akses berbutir halus)
<a name="managedomains-snapshot-fgac"></a>

Kontrol akses detail memperkenalkan langkah tambahan saat mendaftarkan repositori. Bahkan jika Anda menggunakan autentikasi basic HTTP untuk semua tujuan lain, Anda perlu memetakan peran `manage_snapshots` ke IAM role Anda yang memiliki izin `iam:PassRole` untuk meneruskan `TheSnapshotRole`.

1. Arahkan ke plugin OpenSearch Dasbor untuk domain OpenSearch Layanan Anda. Anda dapat menemukan titik akhir Dasbor di dasbor domain Anda di konsol OpenSearch Layanan. 

1. Dari menu utama, pilih **Keamanan**, **Peran**, lalu pilih peran **manage\$1snapshots**.

1. Pilih **Pengguna yang Dipetakan**, **Kelola pemetaan**. 

1. Tambahkan ARN dari peran yang memiliki izin untuk lulus. `TheSnapshotRole` Letakkan peran ARNs di bawah peran **Backend**.

   ```
   arn:aws:iam::123456789123:role/role-name
   ```

1. Pilih **Peta** dan konfirmasikan pengguna atau peran muncul di bawah **Pengguna yang dipetakan**.

## Langkah 2: Mendaftarkan repositori
<a name="managedomains-snapshot-register"></a>

Tab **Snapshots** berikut menunjukkan cara mendaftarkan direktori snapshot. Untuk opsi khusus untuk mengenkripsi snapshot manual dan mendaftarkan snapshot setelah bermigrasi ke domain baru, lihat tab yang relevan.

------
#### [ Snapshots ]

Untuk mendaftarkan repositori snapshot, kirim permintaan PUT ke titik akhir domain OpenSearch Layanan. Anda dapat menggunakan [curl](https://curl.se/docs/manpage.html#--aws-sigv4), [contoh klien Python](#managedomains-snapshot-client-python)[, Postman,](https://www.getpostman.com/) atau metode lain untuk mengirim permintaan yang ditandatangani untuk mendaftarkan repositori snapshot. Perhatikan bahwa Anda tidak dapat menggunakan permintaan PUT di konsol OpenSearch Dasbor untuk mendaftarkan repositori.

Permintaan mengambil format berikut:

```
PUT domain-endpoint/_snapshot/my-snapshot-repo-name
{
  "type": "s3",
  "settings": {
    "bucket": "amzn-s3-demo-bucket",
    "base_path": "my/snapshot/directory",
    "region": "region",
    "role_arn": "arn:aws:iam::123456789012:role/TheSnapshotRole"
  }
}
```

**catatan**  
Nama repositori tidak dapat dimulai dengan “cs-”. Selain itu, Anda tidak boleh menulis ke repositori yang sama dari beberapa domain. Hanya satu domain yang harus memiliki akses tulis ke repositori.

Jika domain Anda berada dalam virtual private cloud (VPC), komputer Anda harus terhubung ke VPC agar permintaan berhasil mendaftarkan repositori snapshot. Mengakses VPC bervariasi menurut konfigurasi jaringan, tetapi kemungkinan melibatkan koneksi ke VPN atau jaringan perusahaan. Untuk memeriksa apakah Anda dapat mencapai domain OpenSearch Layanan, `https://your-vpc-domain.region.es.amazonaws.com` navigasikan ke browser web dan verifikasi bahwa Anda menerima respons JSON default.

Jika bucket Amazon S3 Anda berada di tempat lain Wilayah AWS selain OpenSearch domain Anda, tambahkan parameter `"endpoint": "s3.amazonaws.com"` ke permintaan.

------
#### [ Encrypted snapshots ]

Saat ini Anda tidak dapat menggunakan kunci AWS Key Management Service (KMS) untuk mengenkripsi snapshot manual, tetapi Anda dapat melindunginya menggunakan enkripsi sisi server (SSE).

Untuk mengaktifkan SSE dengan kunci terkelola S3 untuk bucket yang Anda gunakan sebagai repositori snapshot, tambahkan `"server_side_encryption": true` ke blok permintaan PUT. `"settings"` *Untuk informasi selengkapnya, lihat [Menggunakan enkripsi sisi server dengan kunci terkelola Amazon S3 (SSE-S3)](https://docs.aws.amazon.com/AmazonS3/latest/userguide/UsingServerSideEncryption.html) di Panduan Pengguna Layanan Penyimpanan Sederhana Amazon.*

Atau, Anda dapat menggunakan AWS KMS kunci untuk enkripsi sisi server pada bucket S3 yang Anda gunakan sebagai repositori snapshot. Jika Anda menggunakan pendekatan ini, pastikan untuk memberikan `TheSnapshotRole` izin ke AWS KMS kunci yang digunakan untuk mengenkripsi bucket S3. Untuk informasi selengkapnya, lihat [Kebijakan utama di AWS KMS](https://docs.aws.amazon.com/kms/latest/developerguide/key-policies.html).

------
#### [ Domain migration ]

Mendaftarkan repositori snapshot adalah operasi satu kali. Namun, untuk bermigrasi dari satu domain ke domain lain, Anda harus mendaftarkan repositori snapshot yang sama pada domain lama dan domain baru. Nama repositori adalah semaunya.

Pertimbangkan panduan berikut saat bermigrasi ke domain baru atau mendaftarkan repositori yang sama dengan beberapa domain:
+ Saat mendaftarkan repositori pada domain baru, tambahkan `"readonly": true` ke blok `"settings"` dari permintaan PUT. Pengaturan ini mencegah Anda dari secara tidak sengaja menimpa data dari domain lama. Hanya satu domain yang harus memiliki akses tulis ke repositori.
+ Jika Anda memigrasikan data ke domain yang berbeda Wilayah AWS, (misalnya, dari domain lama dan bucket yang terletak di us-east-2 ke domain baru di us-west-2), ganti dengan di pernyataan PUT dan coba lagi permintaan tersebut. `"region": "region"` `"endpoint": "s3.amazonaws.com"`

------

### Menggunakan sampel klien Python
<a name="managedomains-snapshot-client-python"></a>

Klien Python lebih mudah untuk diotomatisasi daripada permintaan HTTP sederhana dan memiliki kemampuan penggunaan kembali yang lebih baik. Jika anda memilih untuk menggunakan metode ini untuk mendaftarkan repositori snapshot, simpan sampel kode Python berikut sebagai file Python, seperti `register-repo.py`. Klien memerlukan paket [AWS SDK untuk Python (Boto3)](https://aws.amazon.com/sdk-for-python/), [request](http://docs.python-requests.org/) dan [requests-aws4auth](https://pypi.python.org/pypi/requests-aws4auth). Klien berisi contoh-contoh yang dikomentari untuk operasi snapshot lainnya.

Memperbarui variabel berikut dalam kode sampel: `host`, `region`, `path`, dan `payload`.

```
import boto3
import requests
from requests_aws4auth import AWS4Auth

host = '' # domain endpoint
region = '' # e.g. us-west-1
service = 'es'
credentials = boto3.Session().get_credentials()
awsauth = AWS4Auth(credentials.access_key, credentials.secret_key, region, service, session_token=credentials.token)

# Register repository

path = '/_snapshot/my-snapshot-repo-name' # the OpenSearch API endpoint
url = host + path

payload = {
  "type": "s3",
  "settings": {
    "bucket": "amzn-s3-demo-bucket",
    "base_path": "my/snapshot/directory",
    "region": "us-west-1",
    "role_arn": "arn:aws:iam::123456789012:role/snapshot-role"
  }
}

headers = {"Content-Type": "application/json"}

r = requests.put(url, auth=awsauth, json=payload, headers=headers)

print(r.status_code)
print(r.text)

# # Take snapshot
#
# path = '/_snapshot/my-snapshot-repo-name/my-snapshot'
# url = host + path
#
# r = requests.put(url, auth=awsauth)
#
# print(r.text)
#
# # Delete index
#
# path = 'my-index'
# url = host + path
#
# r = requests.delete(url, auth=awsauth)
#
# print(r.text)
#
# # Restore snapshot (all indexes except Dashboards and fine-grained access control)
#
# path = '/_snapshot/my-snapshot-repo-name/my-snapshot/_restore'
# url = host + path
#
# payload = {
#   "indices": "-.kibana*,-.opendistro_security,-.opendistro-*",
#   "include_global_state": False
# }
#
# headers = {"Content-Type": "application/json"}
#
# r = requests.post(url, auth=awsauth, json=payload, headers=headers)
#
# print(r.text)
# 
# # Restore snapshot (one index)
#
# path = '/_snapshot/my-snapshot-repo-name/my-snapshot/_restore'
# url = host + path
#
# payload = {"indices": "my-index"}
#
# headers = {"Content-Type": "application/json"}
#
# r = requests.post(url, auth=awsauth, json=payload, headers=headers)
#
# print(r.text)
```

# Mengambil snapshot manual
<a name="managedomains-snapshot-create"></a>

Snapshot tidak seketika. Mereka membutuhkan waktu untuk menyelesaikan dan tidak mewakili point-in-time pandangan cluster yang sempurna. Sementara snapshot sedang berlangsung, Anda masih dapat mengindeks dokumen dan membuat permintaan lain ke klaster, tetapi dokumen baru dan pembaruan untuk dokumen yang ada umumnya tidak termasuk dalam snapshot. Snapshot menyertakan pecahan primer seperti yang ada saat OpenSearch memulai snapshot. Tergantung pada ukuran kolam utas snapshot Anda, serpihan yang berbeda mungkin disertakan dalam snapshot pada waktu yang sedikit berbeda. Untuk praktik terbaik snapshot, lihat[Tingkatkan kinerja snapshot](bp.md#bp-stability-snapshots).

**Awas**  
Snapshot manual tidak termasuk data yang disimpan dalam UltraWarm atau tingkatan penyimpanan dingin. Jika domain Anda menggunakan UltraWarm atau penyimpanan dingin, migrasi indeks tersebut ke penyimpanan panas sebelum mengambil snapshot manual jika Anda perlu menyimpan data tersebut.

## Penyimpanan dan performa snapshot
<a name="managedomains-snapshot-storage"></a>

OpenSearch snapshot bersifat inkremental, artinya mereka hanya menyimpan data yang berubah sejak snapshot terakhir yang berhasil. Sifat pertambahan ini berarti perbedaan dalam penggunaan disk antara snapshot yang sering dan jarang sering kali minimal. Dengan kata lain, mengambil snapshot per jam selama seminggu (untuk total 168 snapshot) mungkin tidak menggunakan lebih banyak ruang disk daripada mengambil satu snapshot pada akhir minggu. Selain itu, semakin sering Anda mengambil snapshot, semakin sedikit waktu yang diperlukan untuk menyelesaikannya. Misalnya, snapshot harian dapat memakan waktu 20-30 menit untuk diselesaikan, sedangkan snapshot per jam mungkin selesai dalam beberapa menit. Beberapa OpenSearch pengguna mengambil foto sesering setiap setengah jam.

## Ambil snapshot
<a name="managedomains-snapshot-take"></a>

Anda menentukan informasi berikut saat Anda membuat snapshot:
+ Nama dari repositori snapshot Anda
+ Sebuah nama untuk snapshot

Contoh dalam bab ini menggunakan [curl](https://curl.haxx.se/), klien HTTP umum, untuk kenyamanan dan singkatnya. Untuk meneruskan nama pengguna dan kata sandi ke permintaan curl Anda, lihat [tutorial Memulai](https://docs.aws.amazon.com/opensearch-service/latest/developerguide/gsg.html).

Jika kebijakan akses menentukan pengguna atau peran, Anda harus menandatangani permintaan snapshot. Untuk curl, Anda dapat menggunakan [`--aws-sigv4`opsi](https://curl.se/docs/manpage.html#--aws-sigv4) dengan versi 7.75.0 atau yang lebih baru. Anda juga dapat menggunakan contoh yang dikomentari dalam contoh [klien Python](managedomains-snapshot-registerdirectory.md#managedomains-snapshot-client-python) untuk membuat permintaan HTTP yang ditandatangani ke titik akhir yang sama dengan yang digunakan perintah curl.

Untuk mengambil snapshot manual, lakukan langkah-langkah berikut:

1. Anda tidak dapat mengambil snapshot jika salah satu sedang berlangsung. Untuk memeriksa, jalankan perintah berikut:

   ```
   curl -XGET 'domain-endpoint/_snapshot/_status'
   ```

1. Jalankan perintah berikut untuk mengambil snapshot manual:

   ```
   curl -XPUT 'domain-endpoint/_snapshot/repository-name/snapshot-name'
   ```

   Untuk menyertakan atau mengecualikan indeks tertentu dan menentukan pengaturan lain, tambahkan isi permintaan. Untuk struktur permintaan, lihat [Mengambil snapshot](https://opensearch.org/docs/1.1/opensearch/snapshot-restore/#take-snapshots) dalam OpenSearch dokumentasi.

**catatan**  
Waktu yang diperlukan untuk mengambil snapshot meningkat dengan ukuran domain OpenSearch Layanan. Operasi snapshot yang berjalan lama terkadang mengalami kesalahan berikut: `504 GATEWAY_TIMEOUT`. Anda biasanya dapat mengabaikan kesalahan ini dan menunggu operasi selesai dengan sukses. Jalankan perintah berikut untuk memverifikasi status dari semua snapshot domain Anda:  

```
curl -XGET 'domain-endpoint/_snapshot/repository-name/_all?pretty'
```

# Memulihkan snapshot
<a name="managedomains-snapshot-restore"></a>

Sebelum mengembalikan snapshot, pastikan domain tujuan tidak menggunakan [Multi-AZ dengan](managedomains-multiaz.md#managedomains-za-standby) Standby. Mengaktifkan siaga menyebabkan operasi pemulihan gagal.

**Awas**  
Jika Anda menggunakan alias indeks, Anda harus menghentikan permintaan tulis ke alias atau mengalihkan alias ke indeks lain sebelum menghapus indeksnya. Menghentikan permintaan penulisan membantu menghindari skenario berikut:  
Anda menghapus indeks, yang juga menghapus aliasnya.
Permintaan penulisan yang salah ke alias yang sekarang dihapus membuat indeks baru dengan nama yang sama dengan alias.
Anda tidak dapat lagi menggunakan alias karena konflik penamaan dengan indeks baru. Jika Anda telah mengalihkan alias ke indeks lain, tentukan `"include_aliases": false` saat Anda memulihkan dari snapshot.

Untuk mengembalikan snapshot

1. Identifikasi snapshot yang ingin Anda pulihkan. Pastikan bahwa semua pengaturan untuk indeks ini, seperti paket penganalisis khusus atau pengaturan persyaratan alokasi, kompatibel dengan domain. Untuk melihat semua repositori snapshot, jalankan perintah berikut:

   ```
   curl -XGET 'domain-endpoint/_snapshot?pretty'
   ```

   Setelah Anda mengidentifikasi repositori, jalankan perintah berikut untuk melihat semua snapshot:

   ```
   curl -XGET 'domain-endpoint/_snapshot/repository-name/_all?pretty'
   ```
**catatan**  
Sebagian besar snapshot otomatis disimpan dalam repositori `cs-automated`. Jika domain Anda mengenkripsi data saat tidak aktif, maka data tersebut akan disimpan di repositori `cs-automated-enc`. Jika Anda tidak melihat repositori snapshot manual yang Anda cari, pastikan Anda [mendaftarkannya](managedomains-snapshot-registerdirectory.md) ke domain.

1. (Opsional) Hapus atau ganti nama satu atau beberapa indeks di domain OpenSearch Layanan jika Anda memiliki konflik penamaan antara indeks di cluster dan indeks dalam snapshot. Anda tidak dapat mengembalikan snapshot indeks Anda ke OpenSearch cluster yang sudah berisi indeks dengan nama yang sama.

   Anda memiliki opsi berikut jika Anda memiliki konflik penamaan indeks:
   + Hapus indeks pada domain OpenSearch Layanan yang ada dan kemudian pulihkan snapshot.
   + Ganti nama indeks saat Anda memulihkannya dari snapshot dan indeks ulang nanti. Untuk mempelajari cara mengganti nama indeks, lihat [contoh permintaan ini](https://opensearch.org/docs/latest/api-reference/snapshots/restore-snapshot/#example-request) dalam dokumentasi. OpenSearch 
   + Kembalikan snapshot ke domain OpenSearch Layanan yang berbeda (hanya mungkin dengan snapshot manual).

   Perintah berikut menghapus semua indeks yang ada di domain:

   ```
   curl -XDELETE 'domain-endpoint/_all'
   ```

   Namun, jika Anda tidak berencana untuk memulihkan semua indeks, Anda cukup menghapus satu:

   ```
   curl -XDELETE 'domain-endpoint/index-name'
   ```

1. Untuk memulihkan snapshot, jalankan perintah berikut:

   ```
   curl -XPOST 'domain-endpoint/_snapshot/repository-name/snapshot-name/_restore'
   ```

   Karena izin khusus pada OpenSearch Dasbor dan indeks kontrol akses berbutir halus, upaya untuk memulihkan semua indeks mungkin gagal, terutama jika Anda mencoba memulihkan dari snapshot otomatis. Contoh berikut memulihkan hanya satu indeks, `my-index`, dari `2020-snapshot` di repositori snapshot `cs-automated`:

   ```
   curl -XPOST 'domain-endpoint/_snapshot/cs-automated/2020-snapshot/_restore' \
   -d '{"indices": "my-index"}' \
   -H 'Content-Type: application/json'
   ```

   Sebagai alternatif, Anda mungkin ingin memulihkan semua indeks *kecuali Dasbor dan indeks kontrol* akses berbutir halus:

   ```
   curl -XPOST 'domain-endpoint/_snapshot/cs-automated/2020-snapshot/_restore' \
   -d '{"indices": "-.kibana*,-.opendistro*"}' \
   -H 'Content-Type: application/json'
   ```
**catatan**  
Tergantung pada OpenSearch versi Anda, indeks sistem tambahan mungkin juga perlu dikecualikan, seperti `-.opensearch-observability*` dan`-.plugins-ml-config*`. Operasi pemulihan mungkin gagal jika indeks ini sudah ada di domain target. Untuk mengecualikannya, tambahkan ke daftar `indices` pengecualian. Sebagai contoh: `"indices": "-.kibana*,-.opendistro*,-.opensearch-observability*,-.plugins-ml-config*"`.

   Anda dapat memulihkan snapshot tanpa menghapus datanya dengan menggunakan parameter `rename_pattern` dan`rename_replacement`. Untuk informasi selengkapnya tentang parameter ini, lihat [bidang permintaan](https://opensearch.org/docs/latest/api-reference/snapshots/restore-snapshot/#request-fields) Restore Snapshot API dan [contoh permintaan](https://opensearch.org/docs/latest/api-reference/snapshots/restore-snapshot/#example-request) dalam OpenSearch dokumentasi.

**catatan**  
Jika tidak semua pecahan utama tersedia untuk indeks yang terlibat, snapshot mungkin memiliki file. `state` `PARTIAL` Nilai ini menunjukkan bahwa data dari setidaknya satu serpihan tidak berhasil disimpan. Anda masih dapat memulihkan dari sebagian snapshot, tetapi Anda mungkin perlu menggunakan snapshot lama untuk memulihkan indeks yang hilang.

## Menghapus snapshot manual
<a name="managedomains-snapshot-delete"></a>

Untuk menghapus snapshot manual, jalankan perintah berikut:

```
DELETE _snapshot/repository-name/snapshot-name
```

# Mengotomatiskan snapshot dengan Manajemen Snapshot
<a name="managedomains-snapshot-mgmt"></a>

Anda dapat menyiapkan kebijakan Manajemen Snapshot (SM) di OpenSearch Dasbor untuk mengotomatiskan pembuatan dan penghapusan snapshot secara berkala. SM dapat mengambil snapshot dari sekelompok indeks, sedangkan [Index State Management](managedomains-snapshots.md#managedomains-snapshot-ism) hanya dapat mengambil satu snapshot per indeks. Untuk menggunakan SM in OpenSearch Service, Anda harus mendaftarkan repositori Amazon S3 Anda sendiri. Untuk petunjuk untuk mendaftarkan repositori Anda, lihat [Mendaftarkan repositori snapshot manual](https://docs.aws.amazon.com/opensearch-service/latest/developerguide/managedomains-snapshots.html#managedomains-snapshot-registerdirectory).

**catatan**  
Manajemen Snapshot didukung dimulai dengan OpenSearch versi 2.5. Domain yang menjalankan versi sebelumnya tidak mendukung fitur ini.

Sebelum SM, OpenSearch Layanan menawarkan fitur snapshot otomatis gratis yang masih diaktifkan secara default. Fitur ini mengirimkan snapshot ke repositori yang dikelola layanan`cs-*`. Untuk menonaktifkan fitur, hubungi. Dukungan

Untuk informasi selengkapnya tentang fitur SM, lihat [Manajemen snapshot](https://opensearch.org/docs/latest/dashboards/sm-dashboards/) dalam OpenSearch dokumentasi.

SM saat ini tidak mendukung pembuatan snapshot pada beberapa jenis indeks. Misalnya, jika Anda mencoba membuat snapshot pada beberapa indeks dengan `*` dan beberapa indeks berada di [tingkat hangat](https://docs.aws.amazon.com/opensearch-service/latest/developerguide/ultrawarm.html#ultrawarm-manual-snapshot), pembuatan snapshot akan gagal. Jika Anda memerlukan snapshot berisi beberapa jenis indeks, gunakan [tindakan snapshot ISM](https://opensearch.org/docs/latest/im-plugin/ism/policies/#snapshot) hingga SM mendukung opsi ini.

# Mengatur Konfigurasi Izin
<a name="sm-security"></a>

Jika Anda memutakhirkan ke 2.5 dari versi domain OpenSearch Layanan sebelumnya, izin keamanan manajemen snapshot mungkin tidak ditentukan pada domain. Pengguna non-admin harus dipetakan ke peran ini untuk menggunakan manajemen snapshot pada domain menggunakan kontrol akses berbutir halus. Untuk membuat peran manajemen snapshot secara manual, lakukan langkah-langkah berikut:

1. Di OpenSearch Dasbor, buka **Keamanan** dan pilih **Izin**.

1. Pilih **Buat grup tindakan** dan konfigurasi grup-grup berikut:     
[\[See the AWS documentation website for more details\]](http://docs.aws.amazon.com/id_id/opensearch-service/latest/developerguide/sm-security.html)

1. Pilih **Peran** dan **Buat peran**.

1. Beri nama peran **snapshot\$1management\$1role**.

1. Untuk **izin Cluster**, pilih `snapshot_management_full_access` atau`snapshot_management_read_access`.

1. Pilih **Buat**.

1. Setelah Anda membuat peran, [petakan](fgac.md#fgac-mapping) ke setiap pengguna atau peran backend yang akan mengelola snapshot.

## Pertimbangan-pertimbangan
<a name="sm-considerations"></a>

Pertimbangkan hal berikut saat Anda mengonfigurasi manajemen snapshot:
+ Satu kebijakan diperbolehkan per repositori.
+ Hingga 400 snapshot diizinkan untuk satu kebijakan.
+ Fitur ini tidak akan berjalan jika domain Anda memiliki status merah, berada di bawah tekanan JVM tinggi (85% atau lebih tinggi), atau memiliki fungsi snapshot macet. Ketika kinerja pengindeksan dan pencarian keseluruhan klaster Anda terpengaruh, SM juga dapat terpengaruh.
+ Operasi snapshot hanya dimulai setelah operasi sebelumnya selesai, sehingga tidak ada operasi snapshot bersamaan yang diaktifkan oleh satu kebijakan.
+ Beberapa kebijakan dengan jadwal yang sama dapat menyebabkan lonjakan sumber daya. Jika indeks snapshot kebijakan tumpang tindih, operasi snapshot level shard hanya dapat berjalan secara berurutan, yang dapat menyebabkan masalah kinerja berjenjang. Jika kebijakan berbagi repositori, akan ada lonjakan operasi penulisan ke repositori tersebut.
+ Kami menyarankan Anda menjadwalkan otomatisasi operasi snapshot Anda tidak lebih dari sekali per jam, kecuali jika Anda memiliki kasus penggunaan khusus.

## Mengotomatisasi snapshot dengan Manajemen State Indeks
<a name="managedomains-snapshot-ism"></a>

Anda dapat menggunakan operasi [snapshot](https://opendistro.github.io/for-elasticsearch-docs/docs/im/ism/policies/#snapshot) Index State Management (ISM) untuk secara otomatis memicu snapshot indeks berdasarkan perubahan usia, ukuran, atau jumlah dokumen. ISM adalah yang terbaik ketika Anda membutuhkan satu snapshot per indeks. Jika Anda perlu memotret sekelompok indeks, lihat. [Mengotomatiskan snapshot dengan Manajemen Snapshot](managedomains-snapshot-mgmt.md)

Untuk menggunakan SM in OpenSearch Service, Anda harus mendaftarkan repositori Amazon S3 Anda sendiri. Untuk contoh kebijakan ISM yang menggunakan operasi `snapshot`, lihat [Sampel Kebijakan](ism.md#ism-example).

## Menggunakan Curator untuk snapshot
<a name="managedomains-snapshot-curator"></a>

Jika ISM tidak berfungsi untuk manajemen indeks dan snapshot, Anda dapat menggunakan Kurator sebagai gantinya. Ini menawarkan fungsionalitas penyaringan lanjutan yang dapat membantu menyederhanakan tugas manajemen pada cluster yang kompleks. Gunakan [pip](https://pip.pypa.io/en/stable/installing/) untuk menginstal Curator:

```
pip install elasticsearch-curator
```

Anda dapat menggunakan Curator sebagai antarmuka baris perintah (CLI) atau API Python. [Jika Anda menggunakan Python API, Anda harus menggunakan versi 7.13.4 atau sebelumnya dari klien elasticsearch-py lama.](https://elasticsearch-py.readthedocs.io/) Itu tidak mendukung klien opensearch-py. 

Jika Anda menggunakan CLI, ekspor kredensial Anda pada baris perintah dan konfigurasikan `curator.yml` sebagai berikut:

```
client:
  hosts: search-my-domain.us-west-1.es.amazonaws.com
  port: 443
  use_ssl: True
  aws_region: us-west-1
  aws_sign_request: True
  ssl_no_validate: False
  timeout: 60

logging:
  loglevel: INFO
```