Friday 29 July 2016

Simulasi Routing BGP Pada Router Cisco di GNS3

Leave a Comment
Assalamulaikum Wr. Wb.
     Hai teman-teman, kali ini saya akan berbagi tentang bagaimana caranya untuk melakukan routing BGP pada perangkat router cisco di GNS3. Sebelum kita melakukan routingnya, lebih baik teman-teman membaca pengertian dari routing BGP di bawah ini.

A. Pengertian

     Border Gateway Protocol disingkat BGP adalah inti dari protokol routing Internet. Protocol ini yang menjadi backbone dari jaringan Internet dunia. BGP adalah protokol routing inti dari Internet yg digunakan untuk melakukan pertukaran informasi routing antar jaringan. BGP dijelaskan dalam RFC 4271. RFC 4276 menjelaskan implementasi report pada BGP-4, RFC 4277 menjelaskan hasil ujicoba penggunaan BGP-4. Ia bekerja dengan cara memetakan sebuah tabel IP network yang menunjuk ke jaringan yg dapat dicapai antar Autonomous System (AS). Hal ini digambarkan sebagai sebuah protokol path vector. BGP tidak menggunakan metrik IGP (Interior Gateway Protocol) tradisional, tapi membuat routing decision berdasarkan path, network policies, dan atau ruleset. BGP versi 4 masih digunakan hingga saat ini . BGP mendukung Class Inter-Domain Routing dan menggunakan route aggregation untuk mengurangi ukuran tabel routing. sejak tahun 1994, BGP-4 telah digunakan di Internet. semua versi dibawahnya sudah tidak digunakan. BGP diciptakan untuk menggantikan protokol routing EGP yang mengizinkan routing secara tersebar sehingga tidak harus mengacu pada satu jaringan backbone saja.

Karakteristik BGP
  • Menggunakan algoritma routing distance vektor.Algoritma routing distance vector secara periodik menyalin table routing dari router ke router. Perubahan table routing di update antar router yang saling berhubungan pada saat terjadi perubahan topologi.
  • Digunakan antara ISP dengan ISP dan client-client.
  • Digunakan untuk merutekan trafik internet antar autonomous system.
  • BGP adalah Path Vector routing protocol.Dalam proses menentukan rute-rute terbaiknya selalu mengacu kepada path yang terbaik dan terpilih yang didapatnya dari router BGP yang lainnya.
  • Router BGP membangun dan menjaga koneksi antar-peer menggunakan port nomor 179.
  • Koneksi antar-peer dijaga dengan menggunakan sinyal keepalive secara periodik.
  • Metrik (atribut) untuk menentukan rute terbaik sangat kompleks dan dapat dimodifikasi dengan fleksibel.
  • BGP memiliki routing table sendiri yang biasanya memuat prefiks-prefiks routing yang diterimanya dari router BGP lain

Mengapa BGP?
      BGP memiliki kemampuan untuk mengontrol dan mengatur trafik-trafik dari sumber berbeda di dalam network multi-home (tersambung ke lebih dari 1 ISP/Internet Service Provider). Tujuan utama BGP adalah untuk memperkenalkan kepada publik di luar network (upsteram provider atau peer) tentang rute atau porsi spasi address yang dimiliki dengan “meminta izin” membawa data ke suatu spasi address tujuan (meng-advertise).
Salah satu kelemahan yang mungkin dihadapi oleh BGP routing adalah ia mempublikasikan rute yang tidak diketahui bagaimana cara mencapainya. Ini dinamakan black-holing, yaitu melakukan advertise, atau meminta izin untuk membawa data, tetapi beberapa bagian spasi address adalah milik orang lain, akibatnya proses advertise malah menyulitkan.

Internet tanpa BGP
     Kemungkinan yang harus ditempuh tanpa melibatkan BGP ke provider:
Harus membuat rute default ke upstream provider, dan semua paket non-lokal diantarkan melalui interface yang ditetapkan oleh rute tersebut.
Provider akan menerapkan rute-rute statis ke network kita, dan mendistribusi ulang rute tersebut melalui IGP mereka. Dari IGP, selanjutnya bisa juga diredistribusikan ke BGP.
     Dengan BGP, provider akan memberi kita semua rute yang mereka miliki, dan berusaha “mendengarkan” setiap announcement rute-rute yang kita miliki untuk kemudian meredistribusikannya ke peer-peer atau customer tujuan.

Hubungan BGP Neighbor

     Arisitektur Internet sebenarnya tersusun atas AS-AS yang saling terkoneksi. Router yang berkomunikasi langsung melalui BGP dikenal sebagai BGP speaker. Beberapa BGP speaker dapat ditempatkan pada AS yang sama atau AS yang berbeda. Dalam masing-masing AS ini, BGP speaker berkomunikasi satu sama lain untuk melakukan pertukaran informasi reachabilitas network berdasarkan set-set policy yang dibangun dalam AS-AS.

Beberapa versi BGP

BGP versi 1
  • Ukuran message 8 – 1024 byte.
  • Terdapat 8 bit field Direction yang menandkan arah yang diambil oleh informasi routing.
  • Lima kemungkinan field Direction: Up, Down, Horizontal, EGP-derived information, Incomplete

BGP versi 2
  • Ukuran message 19 – 4096 byte.
  • Menghilangkan konsep up, down, dan horizontal di antara AS-AS
  • Menambahkan konsep path-attribute.

BGP versi 3
  • Ukuran message 19 – 4096 byte
  • Mengklarifikasi prosedur pendistribusian rute-rute BGP di antara speaker-speaker dalam sebuah AS.
  • Meningkatkan restriksi terhadap penggunaan path attribute Next-hop

BGP versi 4
  • Ukuran message 19 – 4096 byte.
  • Path atribute AS telah dimodifikasi sehingga set AS-AS dapat digambarkan sebagaimana AS individual.
  • Inter-AS Metric path attribute telah didefinisikan ulang sebagai Multi-Exit Discriminator path attribute.
  • Local preference path attribute ditambahkan.
  • Aggregator path attribute ditambahkan.
  • Dukungan untuk CIDR (Classless Inter Domain Routing)


Ringkasan Operasi BGP
     Saat sebuah router BGP baru dibangun, peer-peer BGP dengan sendirinya melakukan pertukaran tabel routing yang mereka miliki, setelah itu peer-peer mengirim notifikasi atau pemberitauan berkaitan dengan perubahan yang terjadi pada tabel routing. Update message memberi informasi peer BGP hanya untuk satu path. Bila perubahan yang timbul mempengaruhi banyak path, maka multiupdate, message perlu dikirim.
     Setelah BGP menghimpun update-update routingnya dari beragam AS, protokol akan membuat keputusan untuk mengambil path spesifik untuk masing-masing rute tujuan. Biasanya hanya satu path yang dibutuhkan untuk mencapai satu tujuan. BGP menggunakan atribut path (path attribute) yang dilepas kepadanya melalui update message agar bisa menentukan satu path terbaik bagi setiap tujuan.

     Ada dua bentuk sistem koneksi transport protocol yang penting dimengerti. Mereka saling bertukar pesan (message) untuk membuka dan mengkonfirmasi parameter-parameter koneksi. Alur data awal yang dihasilkan tidak lain berupa keseluruhan tabel routing BGP, yang selanjutnya beberapa update penambahan dikirim sebagai perubahan pada tabel routing. BGP dalam hal ini tidak menuntut refresh secara periodik atas keseluruhan tabel routing. Oleh karena itu, BGP speaker harus memelihara versi terkini keseluruhan tabel routing BGP dari semua peer-nya selama durasi koneksi tertentu.

     Pesan KeepAlive dikirim secara periodik untuk memastikan kelancaran koneksi. Pesan Notification dikirim untuk merespon adanya error atau kondisi-kondisi khusus yang terjadi. Jika sebuah koneksi menemukan sebuah error, pesan Notification segera dikirim dan koneksi pun ditutup.

Perangkat Hardware & Software untuk Komunikasi BGP
     Perlengkapan yang dibutuhkan adalah router komersial seperti Cisco router dan Bay router atau klon-klon PC yang menjalankan Linux, BSD, atau varian Unix lainnya dibantu dengan program yang dinamakan gated untuk memanage BGP.

eBGP vs iBGP
BGP mensupport dua tipe pertukaran informasi routing:
  •     Pertukaran di antara AS-AS yang berbeda (external BGP atau eBGP)
  •     Pertukaran dalam satu AS tunggal (internal BGP atau iBGP)


      Sebuah sistem BGP berbagi informasi reachabilitas network dengan sistem-sitem BGP berdekatan lainnya yang dikenal dengan neighbor atau peer. Sistem BGP tersusun atas grup-grup (groups). Dalam sebuah grup BGP internal, semua peer anggota grup (internal peer) berada dalam AS yang sama. Grup internal menggunakan rute-rute dari IGP untuk memutuskan penyampaian atau forwarding address-adress. Mereka juga menyebarkan rute-rute eksternal di antara router-router internal lain yang menjalankan BGP internal, menghitung next hop dengan mengambil hop BGP yang diterima dengan rute, lalu memutuskannya menggunakan informasi yang diperoleh dari salah satu IGP.
eBGP dan iBGP saling berbagi protokol level dasar yang sama untuk bertukar rute dan juga berbagi algoritma. Namun eBGP digunakan untuk bertukar rute di antara AS yang berbeda, sedang iBGP digunakan untuk bertukar rute di antara AS yang sama. Dalam faktanya, iBGP termasuk salah satu “interior routing protocol” yang dapat digunakan untuk melakukan routing aktif dalam sebuah network.

     Perbedaan utama eBGP dan iBGP adalah bahwa eBGP tidak bosan-bosannya mencoba meng-advertise setiap rute BGP yang diketahui ke semua orang sehingga mungkin harus digunakan filter untuk menghentikannya. Sedang iBGP pada dasarnya cukup sulit bekerja karena iBGP tidak meredistribusi rute-rute. Speaker iBGP dalam lingkungan network harus melakukan peer dengan semua speaker iBGP lain untuk membuatnya dapat bekerja (routing mesh).

AS Number (ASN)
     ASN merupakan nomor unik yang mengidentifikasikan AS-AS. Nomor ini diatur oleh ARIN (Autonomous Number from The American Registry for Internet Numbers).
Kondisi yang harus dipenuhi untuk mendapatkan nomor AS:
Unique Routing Policy
Multi-homed Site

AS-Path
     Setiap kali sebuah rute disebarkan melalui BGP, ia akan diberi ‘perangko’ dengan sebuah nomor AS (AS number) dari router yang menyelenggarakannya. Rute ini bergerak dari satu AS ke AS lain sehingga membentuk sebuah alur atau path (AS-Path)
Kegunaan AS-Path:
  • Memberikan penelusuran diagnostik terhadap routing dalam sebuah network.
  • Merupakan salah satu nomor metric yang menetapkan bagimana rute-rute yang “didengar” melalui BGP dimasukkan ke dalam tabel routing IP.
  • Memungkinkan untuk melakukan routing policy, misalkan ketika kita ingin mengambil rute tertentu.

 BGP Message
  • Open: untuk membuat koneksi BGP di antara 2 sistem BGP
  • Update: untuk melakukan pertukaran informasi reachabilitas network.
  • KeepAlive: untuk menetapkan apakah sebuah link atau host fail atau tidak lagi eksis.
  • Notification: dikirim ketika kondisi error terdeteksi; menyebabkan sesi BGP dan koneksi TCP di antara sistem-sistem BGP akan ditutup.


B. Latar Belakang

     Dalam dunia bisnis, sebuah perusahaan seperti ISP akan memerlukan kerja sama dengan perusahaan dalam menjalankan bisnisnya, seperti meminta koneksi atau kerja sama-sama lainnya dalam membangun jaringan. Untuk menghubungkan kedua perusahaan tersebut pastinya memerlukan proses routing dari router ISP A ke ISP B bukan ?, nah bagaimana kalau kita menggunakan routing seperti OSPF untuk menghubungkan perusahaan tersebut?. Pastinya kalau kita menggunakan routing IGP seperti OSPF untuk menghubungkan kedua perusahaan tersebut, pasti perusahaan tersebut tidak akan mau. Ini dikarenakan, jika kita, menggunakan routing OSPF maka rahasia perusahaan bisa bocor ke perusahaan lain karena kita mengetahui ip dari perangkat-perangkat di perusahaan lain tersebut. Lalu bagaimana cara untuk mengatasinya ?, salah satu cara untuk mengatasinya adalah dengan menggunakan routing jenis EGP yaitu Border Gateway Protocol (BGP).
     Dengan protocol BGP ini kedua perusahaan tersebut bisa saling request koneksi, akan tetapi mereka tidak bisa melihat ip dari perangkat-perangkat yang terdapat di perusahaan lain. Dalam melakukan proses routing atau request koneksinya, kedua perusahaan tersebut cukup memberitahukan ip yang satu subnet atau satu jaringan dengan router pada perusahaan lain tersebut dan ASN (Autonomus System Number) dari routernya.

C. Persiapan Software dan Hardware
  •  Seperangkat komputer PC / Laptop
  • Aplikasi GNS3


D. Maksud dan Tujuan

     Keigatan ini bermaksudkan untuk memberi kita kita gambaran tentang cara kerja dan konfigurasi dari Border Gateway Protocol serta bertujuan untuk menghubungkan router atau jaringan yang sudah berbeda AS Number. 

E. Tahapan Pelaksanaan Kegiatan

1. Hidupkan komputer anda dan bukalah aplikasi GNS 3 anda.


2. Pada GNS3 masukkan 2 router yang nantinya akan kita gunakan untuk routing BGP dengan mengklik pada icon router --> pilih jenis routernya --> drag and drop router untuk menambahkannya.

3. Selanjutnya hubungkan kedua router dengan kabel yang tersedia di GNS3. Caranya klik pada icon kabel --> kemudian hubungkan antar interface router dengan kabel tersebut

4. Untuk memudahkan cara menghidupkan perangkat-perangkat anda, blok semua perangkat anda --> kemudian klik pada tombol "Start" untuk menghidupkannya.

5. Selanjutnya untuk melakukan pengaturannya, kita harus membukanya dengan consolenya. untuk membuka console, klik kanan pada perangkat anda --> kemudian pilih "Custome console".
 

6. Pada bagian "Choose a predefined command" saya atur dengan Mate Terminal, dikarenakan saya menggunakan Linux Mint 18 "Sarah" Mate. Kemudian klik "OK" untuk menerapkannya. 

7. Selanjutnya akan muncul jendela pengaturan dari perangkat-perangkat kita dengan bentuk terminal.

8. agar lebih mudah dalam konfigurasi kita nantinya, kita atur sekalian perencanaanpemberian ipnya dan keterangan-keterangan lain pada topologi kita seperti pada gambaar di bawah ini.

9. Untuk konfigurasinya, langkah pertama yang kita lakukan adalah melakukan konfigurasi IP pada setiap perangkat sesuai dengan topologi yang telah kita buat. Berikut adalah konfigurasinya untuk setiap perangkatnya

############Pengaturan Pada Router1##############
R1# conf t
R1(config)#int lo0   --> pindah ke pengaturan interface loopback
R1(config-if)#ip addr 1.1.1.1 255.255.255.255 --> mengatur ip interface loopback
R1(config-if)#no sh   --> menghidupkan interface
R1(config-if)#ex    --> keluar dari pengaturan interface
R1(config)#int fa0/0   --> pindah ke pengaturan interface fa0/0
R1(config-if)#ip addr 10.10.20.1 255.255.255.252 -->mengatur ip interface fa0/0
R1(config-if)#no sh --> menghidupkan interface
R1(config-if)#ex --> keluar dari pengaturan interface

R1(config)#

############Pengaturan Pada Router2##############

R2#conf t
R2(config)#int lo0
R2(config-if)#ip addr 2.2.2.2 255.255.255.255
R2(config-if)#no sh
R2(config-if)#ex
R2(config)#int fa0/0
R2(config-if)#ip addr 10.10.20.2 255.255.255.252
R2(config-if)#no sh
R2(config-if)#ex
R2(config)#

10. Setelah semua konfigurasi IP pada tiap perangkat telah selesai dan dirasa sudah benar, barulah selanjutnya kita melakukan routing BGP untuk menghubungkan jaringan-jaringan yang berbeda tersebut. Untuk routingnya, kita harus mengkonfigurasikannya pada tiap-tiap router. Berikut ini adalah konfigurasinya :

#############Routing Pada Router1###############
R1(config)#router bgp 65100
R1(config-router)#neighbor 10.10.20.2 remote 65200
R1(config-router)#network 1.1.1.1 mask 255.255.255.255
R1(config-router)#

#############Routing Pada Router2###############
R2(config)#
R2(config)#router bgp 65200
R2(config-router)#neighbor 10.10.20.1 remote 65100
R2(config-router)#network 2.2.2.2 mask 255.255.255.255
R2(config-router)#

11. untuk melihat rute dari routing kita, kita dapat melihatnya dengan mengetikkan perintah "show ip route" pada Privilege mode. Jika terdapat Huruf "B" didepan routingnya, itu berarti routing dari protocol BGP.
 

12. Untuk menguji koneksi antar jaringan berbeda sudah terkoneksi atau belum, kita coba lakukan ping dari loopback Router1 ke Loopback Router2 dan loopback Router2 ke Loopback Router1. Jika ping berhasil, maka konfigurasi routing BGP anda telah berhasil. 
Dari Router 1 ke loopback Router 2
Dari Router 2 ke loopback Router 1


F. Referensi

+https://id.wikipedia.org/wiki/Border_Gateway_Protocol
+http://santekno.blogspot.co.id/2013/01/bgp-border-gateway-protocol.html#popup
+Presentasi dari Om Danu Wiyoto.

G. Hasil dan Kesimpulan

     Dengan melakukan routing BGP ini, kita dapat menghubungkan router jaringan yang sudah berbeda AS Number.


     Sekian dari saya, mohon maaf sebesar-besarnya jika terdapat banyak kesalahan dalam postingan saya ^-^ 

Wassalamualikum Wr. Wb.
If You Enjoyed This, Take 5 Seconds To Share It

0 comments:

Post a Comment