Tahun 1986, lembaga ilmu pengetahuan nasional Amerika Serikat (NSF) mendanai pembuatan jaringan TCP/IP yang dinamai NSFNET. Jaringan ini digunakan untuk menghubungkan lima pusat komputer super dan memungkinkan terhubungnya universitas – universitas di Amerika Serikat dengan kecepatan 56Kbps. Jaringan inilah yang kemudian menjadi embrio yang kita kenal sekarang ini.
Internet Protocol dikembangkan pertama kali oleh Defense Advanced Research Projects Agency ( DARPA) pada tahun 1970 sebagai awal dari usaha untuk mengembangkan protokol yang dapat melakukan interkoneksi berbagai jaringan komputer yang terpisah, yang masing-masing jaringan tersebut menggunakan teknologi yang berbeda. Protokol utama yang dihasilkan proyek ini adalah Internet Protocol (IP). Riset yang sama dikembangkan pula yaitu beberapa protokol level tinggi yang didesain dapat bekerja dengan IP. Yang paling penting dari proyek tersebut adalah Transmission Control Protocol (TCP), dan semua grup protokol diganti dengan TCP/IP suite. Pertama kali TCP/IP diterapkan di ARPANET, dan mulai berkembang setelah Universitas California di Berkeley mulai menggunakan TCP/IP dengan sistem operasi UNIX. Selain Defense Advanced Research Projects Agency (DARPA) ini yang mengembangkan Internet Protocol, yang juga mengembangkan TCP/IP adalah Department of defense (DOD).
Saat ini TCP/IP digunakan sebagai sebuah protokol standar untuk menghubungkan komputer-komputer dan jaringan untuk membentuk sebuah jaringan yang luas (WAN). TCP/IP merupakan sebuah standar jaringan terbuka yang bersifat independen terhadap mekanisme transport jaringan fisik yang digunakan, sehingga dapat digunakan di mana saja. Protokol ini menggunakan skema pengalamatan yang sederhana yang disebut sebagai alamat IP (IP Address) yang mengizinkan hingga beberapa ratus juta komputer untuk dapat saling berhubungan satu sama lainnya di Internet. Protokol ini juga bersifat routable yang berarti protokol ini cocok untuk menghubungkan sistem-sistem berbeda (seperti Microsoft Windows dan keluarga UNIX ) untuk membentuk jaringan yang heterogen.
Sekumpulan protocol TCP/IP dimodelkan dengan empat layer yaitu : Network Interface Layer (Ethernet, X.25, SLIP,PPP), Internet Layer (IP, ICMP, ARP), Transport Layer (TCP, UDP), dan Application Layer (SMTP, FTP,HTTP, dll).
2.PENGERTIAN
Internet protokol adalah protokol yang memindahkan paket dari mesin sumber ke mesin destinasi, dalam intervening network melalui router. Itulah mengapa IP layer pada stack disebut internet layer atau network layer. Protokol TCP adalah protokol layer yang digunakan oleh World Wide Web, e-mail, FTP, dan aplikasi lain yang mengandalkan trafic dalam internet.
Struktur Protokol TCP/IP
• Protokol lapisan antarmuka jaringan ( network access ): bertanggung jawab untuk meletakkan frame-frame jaringan di atas media jaringan yang digunakan. TCP/IP dapat bekerja dengan banyak teknologi transport, mulai dari teknologi transport dalam LAN (seperti halnya Ethernet dan Token Ring), MAN dan WAN (seperti halnya dial-up modem yang berjalan di atas Public Switched Telephone Network (PSTN), Integrated Services Digital Network (ISDN), serta Asynchronous Transfer Mode (ATM)).
• Protokol lapisan internet: bertanggung jawab untuk melakukan pemetaan (routing) dan enkapsulasi paket-paket data jaringan menjadi paket-paket IP. Protokol yang bekerja dalam lapisan ini adalah Internet Protocol (IP), Address Resolution Protocol (ARP), Internet Control Message Protocol (ICMP), dan Internet Group Management Protocol (IGMP).
• Protokol lapisan transport: berguna untuk membuat komunikasi menggunakan sesi koneksi yang bersifat connection-oriented atau broadcast yang bersifat connectionless. Protokol dalam lapisan ini adalah Transmission Control Protocol (TCP) dan User Datagram Protocol (UDP).
• Protokol lapisan aplikasi: bertanggung jawab untuk menyediakan akses kepada aplikasi terhadap layanan jaringan TCP/IP. Protokol ini mencakup protokol Dynamic Host Configuration Protocol (DHCP), Domain Name System (DNS), Hypertext Transfer Protocol (HTTP), File Transfer Protocol (FTP), Telnet, Simple Mail Transfer Protocol (SMTP), Simple Network Management Protocol (SNMP), dan masih banyak protokol lainnya. Dalam beberapa implementasi stack protokol, seperti halnya Microsoft TCP/IP, protokol-protokol lapisan aplikasi berinteraksi dengan menggunakan antarmuka Windows Sockets (Winsock) atau NetBIOS over TCP/IP (NetBT).
Keuntungan Protokol TCP/IP
• IP adalah protokol yang tidak handal atau best effort. Protokol ini sangat baik untuk mengirimkan data tetapi paket tersebut dapat hilang dan tidak menimbulkan pesan kesalahan dimanapun, misalnya jika ada kegagalan router atau disconnect. TCP adalah protokol jaringan yang handal. Protokol ini bekerja berkelanjutan untuk menjamin pengiriman semua data dan sesuai dengan urutan pengiriman sehingga dapat diketahui data yang dikirim sampai ke destinasi.
• IP layer me-route paket hanya pada tingkat mesin. IP tidak memiliki mekanisme untuk membedakan paket dari aplikasi dalam mesin atau membedakan antara banyak koneksi dalam aplikasi aplikasi tunggal. Fungsi ini disediakan oleh protokol transport layer, TCP dan UDP. IP layer me-route ke mesin sedangkan layer transport mengirim ke koneksi individu dalam suatu aplikasi, yang diidentifikasi oleh TCP dengan menetapkan “port number” yang unik pada masing-masing koneksi.
• IP adalah tanpa koneksi – paket ditransmisikan secara individu, benar – benar saling bebas. Untuk banyak aplikasi hal ini tidak cocok. Mereka menampilkan komunikasi sebagai suatu sesi secara keseluruhan; pertukaran adalah bagian dari transaksi keseluruhan sehingga aplikasi harus menyimpan informasi tentang keadaan percakapan yang sedang berlangsung. Misalnya, saat menggunakan POP mail server, perintah “retrieve message” hanya dimungkinkan jika user telah memasukkan username dan password yang valid. Atau pada ftp, saat me-request file, misalnya “get readme.txt” file tertentu yang dikirim sangat tergantung pada direktori tempat saat mengeluarkan command tersebut. TCP menjawab kebutuhan ini; TCP adalah protokol connection-oriented yang memungkin mendapatkan sesi berkelanjutan. Sebelum komunikasi menggunakan TCP, aplikasi pada kedua ujung membangun ( membuka ) koneksi antar mereka. Kemudian mereka mempertukarkan data melalui koneksi ini, dan saat mereka selesai, mereka menterminasi koneksi.
Layanan TCP/IP
TCP menggunakan paket – paket yang dilapiskan di atas IP, ARP, ICMP, dan semua mekanisme routing untuk mengirimkan data. Tetapi saat menggunakan mekanisme tersebut, mereka adalah layer terpisah dan TCP tidak menduplikasi fungsionalitas mereka. TCP tidak terlibat di dalamnya atau mengetahui sesuatu tentang routing tersebut: ditangani secara eksklusif oleh IP layer yang ada di bawahnya, sebagaimana ditunjukkan oleh gambar 2 di atas. Bagi TCP layer di mesin sumber tampak bahwa dia berbicara secara langsung ke TCP layer di destinasi. Itulah mengapa layer transport disebut juga layer host to host, TCP dan UDP disebut protokol end to end.
Bentuk layanan default yang dapat berjalan di atas TCP/IP, sebagai berikut
Pengiriman berkas (file transfer). File Transfer Protocol (FTP) memungkinkan pengguna komputer yang satu untuk dapat mengirim ataupun menerima berkas ke sebuah host di dalam jaringan. Metode otentikasi yang digunakannya adalah penggunaan nama pengguna (user name) dan [[password]], meskipun banyak juga FTP yang dapat diakses secara anonim (anonymous), alias tidak berpassword.
• Computer mail. Digunakan untuk menerapkan sistem surat elektronik.
• Remote login. Network terminal Protocol (telnet) memungkinkan pengguna komputer dapat melakukan log in ke dalam suatu komputer di dalam suatu jaringan secara jarak jauh. Jadi hal ini berarti bahwa pengguna menggunakan komputernya sebagai perpanjangan tangan dari komputer jaringan tersebut.
• Network File System (NFS). Pelayanan akses berkas-berkas yang dapat diakses dari jarak jauh yang memungkinkan klien-klien untuk mengakses berkas pada komputer jaringan, seolah-olah berkas tersebut disimpan secara lokal.
• Remote execution. Memungkinkan pengguna komputer untuk menjalankan suatu program tertentu di dalam komputer yang berbeda. Biasanya berguna jika pengguna menggunakan komputer yang terbatas, sedangkan ia memerlukan sumber yg banyak dalam suatu sistem komputer. Ada beberapa jenis remote execution, ada yang berupa perintah-perintah dasar saja, yaitu yang dapat dijalankan dalam system komputer yang sama dan ada pula yg menggunakan sistem Remote Procedure Call (RPC), yang memungkinkan program untuk memanggil subrutin yang akan dijalankan di sistem komputer yg berbeda. Misalnya, software Real VNC yang menggunakan IP dalam jaringan untuk me-remote komputer.
• Name server yang berguna sebagai penyimpanan basis data nama host yang digunakan pada internet.
Koneksi dan Port TCP
Aplikasi client menggunakan nomor port untuk memberitahu mesin destinasi, service TCP mana yang diinginkannya. Server untuk aplikasi tertentu mendengarkan well-known port untuk mengetahui koneksi dari client yang meminta service-nya. TCP digunakan untuk berkomunikasi data application to application ( dengan IP layer di bawahnya menangani donkey network untuk mendapatkan paket dari satu mesin ke mesin lainnya melewati jaringan.) Banyal aplikasi yang berbeda – Web, e-mail, FTP, sistem basis data, sistem windows, dan lain – lain menggunakan TCP.
Port adalah alamat yang membedakan koneksi TCP yang berbeda – beda pada mesin yang sama, sedangkan IP address adalah nomor yang mengidentifikasikan mesin mana yang menjadi tujuan suatu paket, port TCP adalah nomor yang mengidentifikasikan koneksi mana dalam mesin spesifik yang dihubungkan dengan paket tersebut.
Telnet >> Port 23
Email >> Port 25
HTTP >> Port 80
Email (POP-3) >> Port 110
Inilah yang disebut sebagai well-known port. Server untuk service tertentu mendengarkan pada well-known port yang sesuai dan memperlakukan permintaan apapun yang datang untuk diproses sesuai dengan permintaan tersebut.
Masalah Pengalamatan
Dalam sebuah jaringan SNA , setiap mesin mempunyai Logical Units dengan alamat jaringan masing-masing. DECNET, Appletalk, dan Novell IPX mempunyai rancangan untuk membuat nomor untuk setiap jaringan lokal dan untuk setiap workstation yang terhubung ke jaringan.
Pada bagian utama pengalamatan lokal network, TCP/IP membuat nomor unik untuk setiap workstation di seluruh dunia. Nomor IP adalah nilai 4 byte (IPv4) dengan konvensi merubah setiap byte ke dalam nomor desimal (0 sampai 255 untuk IP yang digunakan sekarang) dan memisahkan setiap bytes dengan periode. Sebagai contoh misalnya 130.132.59.234.
Sebuah organisasi dimulai dengan mengirimkan electronic mail ke Hostmaster@INTERNIC.NET meminta untuk pembuatan nomor jaringan. Hal ini dimungkinkan bagi hampir setiap orang untuk memperoleh nomor untuk jaringan “small class C” dengan 3 bytes pertama meyatakan jaringan dan byte terakhir menyatakan individual komputer. Organisasi yang lebih besar dapat memperoleh jaringan “Class B” dengan 2 bytes pertama menyatakan jaringan dan 2 bytes terakhir menyatakan menyatakan masing-masing workstation sampai mencapai 64.000 individual workstation. Contoh Jaringan Class B Yale adalah 130.132, jadi semua komputer dengan IP address 130.132.*.* adalah dihubungkan melalui Yale.
Kemudian organisasi berhubungan dengan intenet melalui satu dari beberapa jaringan regional atau jaringan khusus. vendor jaringan diberi nomor pelanggan networks dan ditambahkan ke dalam konfigurasi routing dalam masing-masing mesin.
Tidak ada rumus matematika yang mengubah nomor 192.35.91 atau 130.132 menjadi “Yale University” atau “New Haven”. Mesin-mesin yang mengatur jaringan regional yang besar atau routers Internet pusat dapat menentukan lokasi jaringan-jaringan tersebut dengan mencari setiap nomor jaringan tersebut dalam tabel. Diperkirakan ada ribuan jaringan class B dan jutaan jaringan class C. Pelanggan yang terhubung dengan Internet, bahkan perusahaan besar seperti IBM tidak perlu untuk memelihara informasi pada jaringan-jatingan yang lain. Mereka mengirim semua eksternal data ke regional carrier yang mereka langgan, dan regional carrier mengamati dan memelihara tabel dan melakukan routing yang tepat.
3. Subnets
Meskipun pelanggan individual tidak membutuhkan nomor tabel jaringan atau menyediakan eksplisit routing, tapi untuk kebanyakan jaringan class B dapat diatur secara internal sehingga lebih kecil dan versi organisasi jaringan yang lebih sederhana. Biasanya membagi dua byte internal assignment menjadi satu byte nomor departmen dan satu byte Workstation ID.
Enterprise network dibangun dengan menggunakan TCP/IP router box secara komersial. setiap router mempunyai tabel dengan 255 masukan untuk mengubah satu byte nomor departmen menjadi pilihan tujuan ethernet yang terhubung ke salah satu router. Misalnya, pesan ke 130.132.59.234 melalui jaringan regional National dan New England berdasarkan bagian nomor 130.132. Tiba di Yale, 59 department ID memilih ethernet connector . 234 memilih workstation tertentu pada LAN. Jaringan Yale harus diupdate sebagai ethernet baru dan departemen ditambahkan, tapi tidak dipengaruhi oleh perubahan dari luar atau perpindahan mesin dalam departemen.
4. Jalur-jalur tak tentu
Setiap kali sebuah pesan tiba pada sebuah IP router, maka router akan membuat keputusan ke mana berikutnya pesan tersebut akan dikirimkan. Ada konsep satu waktu tertentu dengan preselected path untuk semua traffic. Misalkan sebuah perusahaan dengan fasilitas di New York, Los Angles, Chicago dan Atlanta. Dapat dibuat jaringan dari empat jalur telepon membentuk sebuah loop (NY ke Chicago ke LA ke Atlanta ke NY). Sebuah pesan tiba di router NY dapat pergi ke LA melalui Chicago atau melalui Atlanta. jawaban dapat kembali ke jalan lain.
Bagaimana sebuah router dapat membuat keputusan antara router dengan router? tidak ada jawaban yang benar. Traffic dapat dipetakan dengan algoritma “clockwise” (pergi ke NY ke Atlanta, LA ke chicago). Router dapat menentukan, mengirimkan pesan ke Atlanta kemudian selanjutnya ke ke Chicago. Routing yang lebih baik adalah dengan mengukur pola traffic dan mengirimkan data melalui link yang paling tidak sibuk.
Jika satu saluran telepon dalam satu jaringan rusak, pesan dapat tetap mencapai tujuannya melalui jalur yang lain. Setelah kehilangan jalur dari NY ke Chicago, data dapat dikirim dari NY ke Atlanta ke LA ke Chicago. Dengan begitu maka jalur akan berlanjut meskipun dengan kerugian performance menurun.
Masalah yang Tidak Diperiksa (Undiagnosed Problem)
Jika ada error terjadi, maka dilaporkan ke network authorities. Error tersebut harus dibenarkan atau diperbaiki. IP, didesain untuk dapat tahan dan kuat. Kehilangan node atau jalur adalah hal biasa, tetapi jaringan harus tetap jalan. Jadi IP secara otomatis menkonfigurasi ulang dirinya sendiri bila terjadi sesuatu yang salah. Jika banyak redundancy yang dibangun ke dalam sistem maka komuniksi tetap berlangsung dan terjaga. TCP dirancang untuk memulihkan node atau saluran yang gagal dimana propagasi routing table berubah untuk semua node router. Karena proses updating memerlukan waktu yang lama , TCP agak lambat untuk menginisiasi pemulihan.
Koneksi TCP Diidentifikasi Oleh Port
Port destinasi sendiri tidak cukup untuk meng-enable TCP untuk mengirimkan paket ke koneksi yang tepat pada saat mesin dan untuk mencegah bercampurnya paket dari koneksi yang berbeda. TCP memecahkan masalah ini dengan menggunakan port sumber dan IP address sumber dan destinasi, yaitu kombinasi dari :
1. Nomor IP sumber ( N1 )
2. Nomor port sumber ( P1 )
3. Nomor IP sumber ( N2 )
4. Nomor port sumber ( P2 )
untuk menetapkan suatu koneksi secar unik sehingga semua paket untuk koneksi ini dapat dikirimkan tanpa bercampur dengan yang lain.
Mengenai Nomor IP
Setiap perusahaan besar atau perguruan tinggi yang terhubung ke internet harus mempunyai level intermediet network. beberapa router mungkin dikonfigurasi untuk berhubungan dengan bebarapa department LAN. Semua traffic di luar organisasi dihubungkan dengan koneksi tunggal ke jaringan provider regional.
Jadi, pemakai akhir dapat menginstall TCP/IP pada PC tanpa harus tahu jaringan regional . Tiga bagian informasi dibutuhkan :
• IP address dibuat pada PC
• Bagian dari IP address (subnet mask) yang membedakan mesin lain dalam LAN yang sama (pesan dapat dikirim secara langsung ) dengan mesin-mesin di departemen lain atao dimanapun di seluruh dunia ( yang dikirimkan ke router mesin)
• IP address dari router mesin yang menghubungkan LAN tersebut dengan dunia luar.
7. Susunan TCP/IP protocol
Internet pada mulanya didesain dengan dua kriteria utama. Dua kriteria ini mempengaruhi dan membentuk hardware dan software yang digunakan sekarang. Kriteria tersebut : Jaringan harus melakukan komunikasi antara para peneliti di belahan dunia yang berbeda, memungkinkan meraka dapat berbagi dan berkomunikasi mengenai penelitian mereka satu sama lain. Sayangnya, riset memerlukan berbagai komputer dari beragam platform dan arsitektur jaringan yang berbeda untuk keperluan keilmuan. Maka untuk itu diperlukan protocol suite untuk dapat berhubungan dengan berbagai platforms hardware yang berbeda dan bahkan sistem jaringan yang berbeda. Lebih jauh lagi, network harus merupakan jaringan komunikasi yang kuat yang mempunyai kemampuan dapat bertahan dari serangan nuklir. Rancangan ini memebawa ke arah desentralisasi jaringan yang terdiri dari jaringan yang terpisah, lebih kecil, jaringan yang diisolasi yang mempunyai kemampuan otomatis bila diperlukan.