{"id":5100,"date":"2025-01-04T02:11:05","date_gmt":"2025-01-03T19:11:05","guid":{"rendered":"https:\/\/www.linuxid.net\/istilah\/?p=5100"},"modified":"2025-01-26T17:47:40","modified_gmt":"2025-01-26T10:47:40","slug":"grpc","status":"publish","type":"post","link":"https:\/\/www.linuxid.net\/istilah\/grpc\/","title":{"rendered":"gRPC"},"content":{"rendered":"<h2>Apa itu gRPC?<\/h2>\n<p>gRPC adalah framework remote procedure call (RPC) dengan performa tinggi yang dirilis oleh Google pada Agustus 2016. Sejak saat itu, gRPC telah mendapatkan perhatian baik di kalangan komunitas open source maupun perusahaan sebagai cara untuk mengakomodasi interaksi klien-server yang dibutuhkan untuk pengembangan lintas platform dan desain arsitektur mikroservis.<\/p>\n<p>gRPC dapat menyederhanakan proses bagi pengembang untuk membangun sistem terhubung dengan menghubungkan layanan di dalam dan antar pusat data. Ini juga menyediakan dukungan yang dapat dipasang untuk pelacakan, pengecekan kesehatan, penyeimbangan beban, dan otentikasi.<\/p>\n<p>Pengembang sering menggunakan gRPC untuk interaksi klien mobile dan web karena dapat menghasilkan pustaka untuk Android dan iOS. Selain itu, gRPC menggunakan <a href=\"https:\/\/www.linuxid.net\/istilah\/HTTP-Hypertext-Transfer-Protocol\/\">protokol transport HTTP<\/a> berbasis standar sehingga dapat melewati <a href=\"https:\/\/www.linuxid.net\/istilah\/firewall\/\">firewall<\/a> keamanan dan mengakses <a href=\"https:\/\/www.linuxid.net\/istilah\/proxy-server\/\">proxy<\/a> perantara.<\/p>\n<h2>Bahasa Pemrograman yang Didukung<\/h2>\n<p>Klien dan server gRPC dapat dijalankan dan berkomunikasi satu sama lain di berbagai lingkungan, termasuk desktop pengguna atau server di dalam jaringan Google. Selain itu, klien gRPC dapat ditulis dalam berbagai bahasa pemrograman populer, termasuk (tetapi tidak terbatas pada):<\/p>\n<ul class=\"default-list\/\">\n<li>Java<\/li>\n<li>C# dan C++<\/li>\n<li>Objective-C<\/li>\n<li>Ruby<\/li>\n<li>Python<\/li>\n<li>Go<\/li>\n<\/ul>\n<p>Di atas itu, pengembang dapat membuat server gRPC di Java dengan klien di Python, Ruby, atau Go. Selain itu, karena API Google terbaru memiliki versi gRPC dari antarmuka mereka, pengembang dapat membangun fungsionalitas Google ke dalam aplikasi mereka.<\/p>\n<h2>Manfaat Menggunakan gRPC<\/h2>\n<p>gRPC, seperti sistem RPC lainnya, berputar di sekitar ide mendefinisikan layanan, seperti mengidentifikasi metode yang dapat dipanggil secara jarak jauh beserta parameter dan tipe pengembalian mereka. Namun, gRPC menyediakan teknologi canggih yang efisien dan <a href=\"https:\/\/www.linuxid.net\/istilah\/scalability\/\">scalable<\/a>, seperti HTTP\/2 dan stream. Karena bersifat agnostik terhadap teknologi, gRPC dapat digunakan dan berinteraksi dengan server dan klien dari beberapa bahasa pemrograman yang berbeda.<\/p>\n<p>gRPC juga dibangun di atas <a href=\"https:\/\/developers.google.com\/protocol-buffers\" target=\"_blank\" rel=\"noopener\/\">protocol buffers<\/a>, yang juga dikenal sebagai protobuf. Protocol buffers adalah alat Google untuk <a href=\"https:\/\/www.techtarget.com\/searchapparchitecture\/tip\/Understanding-protocol-buffers-vs-JSON\/\">mengurutkan data terstruktur<\/a>, yang memungkinkan komunikasi dan penyimpanan data yang dapat diprediksi dan dianalisis.<\/p>\n<h2>Jenis-jenis gRPC<\/h2>\n<p>Saat ini, gRPC memungkinkan pengembang untuk mendefinisikan empat jenis metode layanan, yang mirip dengan metode panggilan RPC tradisional lainnya:<\/p>\n<h3>Unary RPC<\/h3>\n<p>Panggilan fungsi dasar: Klien mengirim satu permintaan ke server, kemudian menerima satu respons kembali.<\/p>\n<h3>Server streaming<\/h3>\n<p>Klien mengirimkan permintaan ke server dan menerima stream pesan sebagai balasan. Klien membaca dari stream yang dikembalikan sampai tidak ada pesan yang tersisa. Di sini, gRPC menjaga urutan pesan dalam setiap panggilan RPC.<\/p>\n<h3>Client streaming<\/h3>\n<p>Sebaliknya dari server streaming, klien menulis serangkaian pesan dan mengirimkannya ke server, menggunakan stream yang disediakan. Setelah klien selesai menulis pesan, ia menunggu server untuk membacanya dan mengembalikan respons. Sekali lagi, gRPC menjaga urutan pesan dalam setiap panggilan RPC.<\/p>\n<h3>Bidirectional streaming<\/h3>\n<p>Baik klien maupun server mengirimkan serangkaian pesan melalui stream baca\/tulis. Kedua stream bekerja secara independen satu sama lain dan, dengan demikian, klien dan server dapat membaca dan menulis dalam urutan apa pun. Misalnya, server membaca sebuah pesan lalu menulis respons. Atau server menunggu untuk menerima semua pesan klien sebelum menulis responsnya. Untuk menjaga urutan, gRPC memelihara urutan pesan dalam setiap stream.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Apa itu gRPC? gRPC adalah framework remote procedure call (RPC) dengan performa tinggi yang dirilis oleh Google pada Agustus 2016. Sejak saat itu, gRPC telah mendapatkan perhatian baik di kalangan komunitas open source maupun perusahaan sebagai cara untuk mengakomodasi interaksi klien-server yang dibutuhkan untuk pengembangan lintas platform dan desain arsitektur mikroservis. gRPC dapat menyederhanakan proses [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[271],"tags":[99],"class_list":["post-5100","post","type-post","status-publish","format-standard","hentry","category-software-development","tag-application-development-and-design"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v24.9 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Apa itu gRPC? - Istilah Komputer<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.linuxid.net\/istilah\/grpc\/\" \/>\n<meta property=\"og:locale\" content=\"id_ID\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Apa itu gRPC? - Istilah Komputer\" \/>\n<meta property=\"og:description\" content=\"Apa itu gRPC? gRPC adalah framework remote procedure call (RPC) dengan performa tinggi yang dirilis oleh Google pada Agustus 2016. Sejak saat itu, gRPC telah mendapatkan perhatian baik di kalangan komunitas open source maupun perusahaan sebagai cara untuk mengakomodasi interaksi klien-server yang dibutuhkan untuk pengembangan lintas platform dan desain arsitektur mikroservis. gRPC dapat menyederhanakan proses [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.linuxid.net\/istilah\/grpc\/\" \/>\n<meta property=\"og:site_name\" content=\"Istilah Komputer\" \/>\n<meta property=\"article:published_time\" content=\"2025-01-03T19:11:05+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-01-26T10:47:40+00:00\" \/>\n<meta name=\"author\" content=\"adhit\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Ditulis oleh\" \/>\n\t<meta name=\"twitter:data1\" content=\"adhit\" \/>\n\t<meta name=\"twitter:label2\" content=\"Estimasi waktu membaca\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 menit\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.linuxid.net\/istilah\/grpc\/\",\"url\":\"https:\/\/www.linuxid.net\/istilah\/grpc\/\",\"name\":\"Apa itu gRPC? - Istilah Komputer\",\"isPartOf\":{\"@id\":\"https:\/\/linuxid.net\/istilah\/#website\"},\"datePublished\":\"2025-01-03T19:11:05+00:00\",\"dateModified\":\"2025-01-26T10:47:40+00:00\",\"author\":{\"@id\":\"https:\/\/linuxid.net\/istilah\/#\/schema\/person\/ec7c6c711087fb70886ff5a4fe68e83d\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.linuxid.net\/istilah\/grpc\/#breadcrumb\"},\"inLanguage\":\"id\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.linuxid.net\/istilah\/grpc\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.linuxid.net\/istilah\/grpc\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/linuxid.net\/istilah\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"gRPC\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/linuxid.net\/istilah\/#website\",\"url\":\"https:\/\/linuxid.net\/istilah\/\",\"name\":\"Istilah Komputer\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/linuxid.net\/istilah\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"id\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/linuxid.net\/istilah\/#\/schema\/person\/ec7c6c711087fb70886ff5a4fe68e83d\",\"name\":\"adhit\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"id\",\"@id\":\"https:\/\/linuxid.net\/istilah\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/www.linuxid.net\/istilah\/wp-content\/litespeed\/avatar\/808829c8eb1b70c161b392916104c2ba.jpg?ver=1777193465\",\"contentUrl\":\"https:\/\/www.linuxid.net\/istilah\/wp-content\/litespeed\/avatar\/808829c8eb1b70c161b392916104c2ba.jpg?ver=1777193465\",\"caption\":\"adhit\"},\"sameAs\":[\"https:\/\/linuxid.net\/istilah\"],\"url\":\"https:\/\/www.linuxid.net\/istilah\/author\/xsandradietsax\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Apa itu gRPC? - Istilah Komputer","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.linuxid.net\/istilah\/grpc\/","og_locale":"id_ID","og_type":"article","og_title":"Apa itu gRPC? - Istilah Komputer","og_description":"Apa itu gRPC? gRPC adalah framework remote procedure call (RPC) dengan performa tinggi yang dirilis oleh Google pada Agustus 2016. Sejak saat itu, gRPC telah mendapatkan perhatian baik di kalangan komunitas open source maupun perusahaan sebagai cara untuk mengakomodasi interaksi klien-server yang dibutuhkan untuk pengembangan lintas platform dan desain arsitektur mikroservis. gRPC dapat menyederhanakan proses [&hellip;]","og_url":"https:\/\/www.linuxid.net\/istilah\/grpc\/","og_site_name":"Istilah Komputer","article_published_time":"2025-01-03T19:11:05+00:00","article_modified_time":"2025-01-26T10:47:40+00:00","author":"adhit","twitter_card":"summary_large_image","twitter_misc":{"Ditulis oleh":"adhit","Estimasi waktu membaca":"2 menit"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.linuxid.net\/istilah\/grpc\/","url":"https:\/\/www.linuxid.net\/istilah\/grpc\/","name":"Apa itu gRPC? - Istilah Komputer","isPartOf":{"@id":"https:\/\/linuxid.net\/istilah\/#website"},"datePublished":"2025-01-03T19:11:05+00:00","dateModified":"2025-01-26T10:47:40+00:00","author":{"@id":"https:\/\/linuxid.net\/istilah\/#\/schema\/person\/ec7c6c711087fb70886ff5a4fe68e83d"},"breadcrumb":{"@id":"https:\/\/www.linuxid.net\/istilah\/grpc\/#breadcrumb"},"inLanguage":"id","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.linuxid.net\/istilah\/grpc\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.linuxid.net\/istilah\/grpc\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/linuxid.net\/istilah\/"},{"@type":"ListItem","position":2,"name":"gRPC"}]},{"@type":"WebSite","@id":"https:\/\/linuxid.net\/istilah\/#website","url":"https:\/\/linuxid.net\/istilah\/","name":"Istilah Komputer","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/linuxid.net\/istilah\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"id"},{"@type":"Person","@id":"https:\/\/linuxid.net\/istilah\/#\/schema\/person\/ec7c6c711087fb70886ff5a4fe68e83d","name":"adhit","image":{"@type":"ImageObject","inLanguage":"id","@id":"https:\/\/linuxid.net\/istilah\/#\/schema\/person\/image\/","url":"https:\/\/www.linuxid.net\/istilah\/wp-content\/litespeed\/avatar\/808829c8eb1b70c161b392916104c2ba.jpg?ver=1777193465","contentUrl":"https:\/\/www.linuxid.net\/istilah\/wp-content\/litespeed\/avatar\/808829c8eb1b70c161b392916104c2ba.jpg?ver=1777193465","caption":"adhit"},"sameAs":["https:\/\/linuxid.net\/istilah"],"url":"https:\/\/www.linuxid.net\/istilah\/author\/xsandradietsax\/"}]}},"_links":{"self":[{"href":"https:\/\/www.linuxid.net\/istilah\/wp-json\/wp\/v2\/posts\/5100","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.linuxid.net\/istilah\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.linuxid.net\/istilah\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.linuxid.net\/istilah\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.linuxid.net\/istilah\/wp-json\/wp\/v2\/comments?post=5100"}],"version-history":[{"count":0,"href":"https:\/\/www.linuxid.net\/istilah\/wp-json\/wp\/v2\/posts\/5100\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.linuxid.net\/istilah\/wp-json\/wp\/v2\/media?parent=5100"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.linuxid.net\/istilah\/wp-json\/wp\/v2\/categories?post=5100"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.linuxid.net\/istilah\/wp-json\/wp\/v2\/tags?post=5100"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}