Skip to content

emka.web.id

menulis pengetahuan – merekam peradaban

Menu
  • Home
  • Tutorial
  • Search
Menu

Tutorial Golang: Cara Membuat Aplikasi Client-Server 100 Koneksi

Posted on May 18, 2024

Ingin membangun program server dan klien TCP yang dapat menangani puluhan permintaan secara bersamaan (concurrent)? Artikel ini akan memandu Anda, mulai dari memahami konsep socket hingga membuat program GoLang yang handal.

Apa itu Socket?

Secara sederhana, socket adalah mekanisme yang memungkinkan dua komputer terhubung satu sama lain. Bayangkan seperti saluran telepon kabel, di mana kedua orang dapat berbicara dan pesan ditransfer melalui kabel. Namun, untuk komputer dan jaringan, konsepnya lebih kompleks, tetapi idenya tetap sama.

Membangun Server di GoLang:

  1. Inisiasi Projek:

Pertama, buat project baru di direktori pilihan Anda. Gunakan go mod init untuk inisiasi dan beri nama project sesuai keinginan (idealnya sama dengan nama repository GitHub Anda). Sebagai contoh, kita akan menggunakan github.com/milbmr/golang-server.

Bash

go mod init github.com/milbmr/golang-server

Use code with caution.content_copy

  1. Buat File main.go:

Buat file main.go menggunakan editor teks favorit Anda. Pastikan untuk memberi nama package menjadi package main dan import package yang dibutuhkan: net dan fmt dari standard library. Terakhir, buat fungsi main.

Go

package main

import (
  "fmt"
  "net"
)

func main() {
  // ... isi kode server disini
}

Use code with caution.content_copy

  1. Membuat Listener:

Listener adalah socket yang menunggu koneksi pada alamat IP dan port tertentu. Tambahkan kode berikut ke fungsi main dan kita akan membahasnya baris per baris:

Go

listener, err := net.Listen("tcp", "127.0.0.1:8000")
if err != nil {
  fmt.Println("Error mendengarkan koneksi:", err)
  return
}

Use code with caution.content_copy

  • Argumen pertama untuk fungsi listen adalah protokol jaringan yang akan kita gunakan. Dalam kasus ini, kita menggunakan protokol TCP untuk membuat koneksi jaringan yang persisten dan handal.
  • Argumen kedua adalah alamat IP dan nomor port (8000) tempat socket akan terikat untuk mendengarkan koneksi masuk.
  • Kita menggunakan alamat loopback “127.0.0.1” karena kita ingin socket ini diakses secara lokal pada mesin kita, bukan terekspos ke jaringan untuk lalu lintas jarak jauh.

Fungsi listen akan mengembalikan interface net.Listener dan error. Kita periksa error menggunakan pernyataan if untuk memastikan semuanya berjalan dengan baik.

  1. Menangani Koneksi:

Tambahkan kode berikut di bawah pembuatan listener:

Go

go func() {
  for {
    conn, err := listener.Accept()
    if err != nil {
      return
    }

    go func(c net.Conn) {
      defer c.Close()
      _, err := c.Write([]byte("connected\n"))
      if err != nil {
        fmt.Println("Error menulis:", err)
        return
      }
    }(conn)
  }
}()

Use code with caution.content_copy

  • Kita membuat fungsi anonim dan menjalankannya di goroutine terpisah untuk menangani permintaan secara asynchronous (tidak bergantung).
  • Looping infinite (for) diperlukan kecuali kita hanya ingin menangani satu permintaan.
  • Di dalam loop, kita menggunakan method Accept dari interface net.Listener yang dikembalikan oleh net.Listen. Method ini akan menunggu hingga ada koneksi baru kemudian mengembalikan interface net.Conn. Interface ini memiliki method Read dan Write untuk memungkinkan kita membaca dan menulis ke aliran koneksi TCP.
  • Selanjutnya, kita membuat goroutine baru untuk menangani permintaan yang diterima oleh method Accept. Interface conn dilewatkan sebagai argumen ke goroutine untuk memastikan setiap permintaan dienkapsulasi dalam goroutine terpisah.
  • Pernyataan defer digunakan untuk memastikan koneksi ditutup sebelum goroutine keluar.
  • Kita gunakan method Write untuk mengirim data kembali ke klien. Method ini membutuhkan byte slice sebagai argumen, jadi kita perlu mengonversi string menjadi byte slice sebelum ditulis.
  • Terakhir, kita tangani error dan kembali ke loop Accept untuk siap menerima koneksi baru.
  1. Menunggu Goroutine dan Menutup Koneksi:

Server kita hampir selesai. Kita perlu menunggu goroutine untuk menyelesaikan tugasnya dan memastikan server berjalan dengan efisien. Selain itu, kita perlu menutup listener agar koneksi dapat diakhiri dengan baik setelah program selesai.

  • Gunakan WaitGroup dari package sync untuk menunggu goroutine dan gunakan channel untuk menunggu fungsi Accept selesai.
  • Tambahkan import untuk package sync di awal kode:
  • Tambahkan import untuk package sync di awal kode:

Go

import (
  "net"
  "sync"
)

Use code with caution.content_copy

  • Buat WaitGroup dan channel di fungsi main:

Go

var w sync.WaitGroup
done := make(chan struct{})

Use code with caution.content_copy

  • Ubah fungsi goroutine untuk melacak goroutine yang berjalan dan menyelesaikannya:

Go

var numberOfConnections int
go func() {
  defer func() {
    done <- struct{}{} // tulis ke channel
  }()

  for {
    conn, err := listener.Accept()
    if err != nil {
      return
    }

    w.Add(1) // increment
    go func(c net.Conn, connNum int) {
      defer func() {
        c.Close()
        w.Done() // decrement
      }()

      _, err := c.Write([]byte(fmt.Sprintf("writing to connection number %d\n", connNum)))
      if err != nil {
        fmt.Println("Error menulis:", err)
        return
      }
    }(conn, numberOfConnections)

    numberOfConnections++
  }
}()

Use code with caution.content_copy

  • Gunakan w.Add(1) untuk menambah satu dengan setiap goroutine baru dan w.Done() untuk mengurangi saat selesai.
  • Tulis ke channel done untuk menunjukkan bahwa fungsi Accept telah selesai dan loop for telah keluar.
  • listener.Close() memungkinkan koneksi ditutup dengan baik.
  • w.Wait() digunakan untuk menunggu goroutine selesai.

6. Membangun Klien:

  • Buat fungsi dial untuk membuat permintaan ke server:

Go

func dial(wait *sync.WaitGroup) {
  conn, err := net.Dial("tcp", "127.0.0.1:8000")
  if err != nil {
    fmt.Println("Error koneksi:", err)
    return
  }

  defer func() {
    conn.Close()
    wait.Done()
  }()

  scanner := bufio.NewScanner(conn)
  scanner.Scan()
  err = scanner.Err()
  if err != nil {
    fmt.Println("Error scanning:", err)
  }
  fmt.Println(scanner.Text())
}

Use code with caution.content_copy

  • Gunakan net.Dial untuk terhubung ke server, mirip dengan fungsi net.Listen di server.
  • Gunakan bufio.NewScanner untuk membaca baris dari socket.
  • Cetak data yang diterima dari server.

7. Menjalankan Server dan Klien:

  • Lakukan 100 permintaan serentak ke server:

Go

for i := 0; i < 100; i++ {
  w.Add(1)
  go dial(&w)
}

Use code with caution.content_copy

  • Jalankan program menggunakan go run main.go.

Hasil:

Anda akan melihat output di terminal menunjukkan 100 koneksi simultan ke server.

Tips:

  • Gunakan tools seperti netstat atau tcpdump untuk memantau koneksi jaringan.
  • Uji server dengan beban yang lebih tinggi untuk mengukur performanya.
  • Gunakan teknik konkurensi lanjutan seperti channels dan context untuk mengelola goroutine dan aliran data dengan lebih baik.

Kesimpulan:

Anda telah membangun server dan klien TCP GoLang yang dapat menangani puluhan koneksi secara simultan. Dengan memahami konsep socket, goroutine, dan WaitGroup, Anda dapat membangun aplikasi jaringan yang skalabel dan handal.

Ingat:

  • Selalu pertimbangkan keamanan saat membangun aplikasi jaringan.
  • Pantau performa server dan optimalkan kode Anda untuk menangani beban yang tinggi.
  • Gunakan teknik konkurensi dengan hati-hati untuk menghindari deadlock dan race condition.

Terbaru

  • Kode 0425 Daerah Mana? Ini Pengertian dan Fakta Sebenarnya
  • Apa Itu SSS CapCut? Pengertian Downloader Video Tanpa Watermark yang Wajib Kalian Tahu
  • Apa Itu Paket GamesMAX Telkomsel? Ini Pengertian dan Fungsinya Bagi Gamers
  • Apa Itu Menu Plus di Google Search? Ini Pengertian dan Fungsinya
  • Apa Itu Lepas Kolpri? Ini Pengertian dan Fenomenanya di Dunia Gaming
  • Pixel Buds Pro Dapat Update Software dengan Dukungan ANC Adaptif dan Peningkatan Audio
  • Mous Pixel Watch 4 Akan Hadir dengan Charger Baru dan Fitur-Fitur Terbaru
  • Hati-hati, Video Asli Botol Golda Viral Season 4 Full 6.30 Menit, Cek Link dan Faktanya disini!
  • Google Docs Dapat Update Material 3 dan Desain Ekspresif Baru, Fokus pada Kreativitas dan Kolaborasi
  • Belum Tahu? Ini Trik Hitung Cost Per Gigabyte Supaya Gak Boncos Saat Beli Paket Internet
  • Apple TV dan Google Cast Akan Terintegrasi Lebih Dalam, Tawarkan Pengalaman Streaming yang Lebih Baik
  • Lagi Rame Botol Golda Viral 19 Detik? APA ITU? Jangan Asal Klik Link Sembarangan, Ini Bahayanya!
  • Apa itu Regedit FF Auto Headshot 100 No Password 2024? Simak Definisi dan Cara Kerjanya
  • Apa Itu KPH dan MPH? Pengertian dan Perbedaannya di Game Balap
  • Belum Tahu? Inilah Cara Aman Quotex Login dan Solusi Kalau Error!
  • Apa Itu Fitur Gestur Baru di Pixel Watch 4? Ini Pengertian dan Perbedaannya
  • Belum Tahu? Inilah Cara Aman Login Binomo dan Trik Trading Buat Pemula Biar Nggak Boncos
  • Cara Mengatasi Error ‘Versi Diagnostik Belum Terbarui’ (Your current version of diagnostics is not up to date)
  • Cara Membuat Newsletter di Outlook 365
  • Sering Telepon di Tempat Berisik? Fitur Baru Expressive Call dari Google Bakal Jadi Penyelamat Kalian!
  • Google Pixel 10 Pro Akan Punya Integrasi Play Points Lebih Dalam
  • Stop Cara Kuno! Ini Trik Supaya Manajemen Karyawan Jadi Lebih Cepat dan Anti Ribet
  • Bug di Aplikasi Cuaca Wear OS Google: Update Tidak Ngaruh!
  • Samsung Kembangkan Sensor Kamera Baru Pakai Teknologi Global Shutter dan Efek Blur Bergerak
  • Cara Membuat Anggaran Otomatis di Excel
  • Baseus X1 Pro Kamera: Kamera Ringkas dengan Fitur Canggih dan Harga yang Menarik
  • Profil Sosmed Kalian Sepi? Gini Caranya Makeover Bio Biar Makin Dilirik Sama Netizen!
  • Cara Mengatasi Error ‘Disk is Full or Read-Only’
  • Belum Tahu? Inilah Trik Ampuh Atasi Error ‘We Were Unable To Create Your Notebook’ di OneNote
  • Trik Instagram Stories 2025: Ubah Viewer Jadi Loyal Follower dengan Fitur Sederhana Ini
  • Ini Dia ESP32 P4: IoT RISC-V dengan Layar AMOLED dan LoRa, Perangkat Handheld Inovatif
  • Apa Itu HealthyPi-6? Solusi Open Source untuk Akuisisi Biosignal
  • Jetson THOR Industrial PC: 25Gbe Networking dan Bisa Pakai Kamera GMSL2
  • Azul Systems Akuisisi Payara Java Server
  • PC Kentang Jadi Ngebut? Coba GRML 2025, Distro Debian Ringan dengan Kernel 6.17!
  • Apa Itu US National Framework for AI? Kepres Donald Trump Bikin Heboh Dunia AI
  • Kenapa Bisnis Properti & Real Estate Harus Pakai AI, Ini Alasannya!
  • BARU! Brave Browser Bakal Bisa Ngerjain Tugas Kalian Secara Otomatis Lewat Agentic AI!
  • Belum Tahu? Google Maps Bakal Makin Canggih Berkat Integrasi Gemini Visual Ini!
  • Siap-Siap! Tahun 2026 Gemini Bakal “Menjajah” Chrome, iPhone, sampai Smartwatch Kalian
  • Apa Itu Video PT Pabrik Brebes Viral? Ini Pengertian dan Fakta Sebenarnya
  • Apa itu Data Breach Coupang? Pengertian dan Kronologi Kebocoran Data Terbesar di Korea Selatan
  • Apa Itu CVE-2018-4063? Pengertian Celah Keamanan Sierra Wireless AirLink yang Masuk Katalog CISA
  • Apa Itu Ashen Lepus? Kelompok Peretas yang Mengincar Instansi Pemerintah Timur Tengah
  • Pengertian Vulnerability WebKit Apple Terbaru: Apa Itu CVE-2025-43529 dan CVE-2025-14174?

©2025 emka.web.id | Design: Newspaperly WordPress Theme