Notice
Recent Posts
Recent Comments
Link
«   2024/12   »
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31
Archives
Today
Total
관리 메뉴

밤빵's 개발일지

[TIL]20240819 기본 포트는 왜 8080일까? 본문

개발Article

[TIL]20240819 기본 포트는 왜 8080일까?

최밤빵 2024. 8. 19. 22:17

Redis에 관한 개발일지를 작성하면서 재밌던건 6379가 "NERD"란 단어를 숫자로 변환했다는 점이였다. 왜 6379인지 궁금해서 알아보다가 8080은 왜 8080인지 궁금해졌다.  

🤓기본 포트 8080이 선택된 이유

웹 애플리케이션을 개발하고 배포하면서 가끔 궁금했던건 "왜 기본 포트 번호가 8080일까?"였다. 많은 웹 프레임워크와 애플리케이션 서버(예: Tomcat, Spring Boot 등)는 기본적으로 8080 포트를 사용한다. 그래서 오늘은 포트 8080이 기본 포트로 정해진 이유와, 다른 디폴트 포트들의 예시를 정리해봤다! 

 

▶ 포트와 네트워크 통신의 기본 이해

포트는 네트워크 통신에서 특정 프로세스를 식별하는 데 사용되는 숫자이다. 서버와 클라이언트는 포트를 통해 데이터를 주고받는다. 예를 들어, HTTP 프로토콜은 기본적으로 포트 80을 사용하고, HTTPS 프로토콜은 443을 사용한다. 하지만, 이러한 기본 포트는 루트 권한이 필요한 특권 포트이기 때문에, 개발 환경에서는 주로 사용되지 않는다.

 

▶기본 포트 번호가 8080인 이유 

 

→ 전통적인 HTTP 포트의 대체:

전통적인 HTTP 포트는 80이다. 하지만, 80 포트는 일반적으로 운영 환경에서 웹 서버(Apache, Nginx 등)가 사용하고, 이를 개발 환경에서 사용하기 위해서는 루트 권한이 필요하다.그래서 HTTP 통신을 위한 대체 포트로 8080이 선택되었다. 8080은 80의 두 배로, 숫자 자체가 직관적이고 기억하기 쉽다. 이 숫자 선택은 우연이 아니라, "기본 포트의 의미를 유지하면서도 개발자가 쉽게 사용할 수 있는 포트"라는 철학에서 비롯된 것이다.

 

→ 비특권 포트:

8080은 1024 이상의 비특권 포트이다. 1024 이하의 포트는 일반적으로 운영체제에서 특권 포트로 간주되며, 이를 사용하려면 관리자 권한이 필요하다. 그러나, 8080은 비특권 포트로 설정되어 있어서, 모든 사용자 계정에서 쉽게 사용할 수 있다. 이는 특히 개발 환경에서 여러 개발자나 애플리케이션이 동시에 동작할 때 매우 유용하다.

 

→ 충돌 방지 및 일관성 유지:

8080은 다양한 애플리케이션 서버에서 기본 포트로 사용되어 왔다. 결과적으로 개발자들 사이에서 관례처럼 자리잡았고, 이를 사용하는 많은 애플리케이션과 튜토리얼이 존재한다. 새로운 개발자가 8080 포트를 기본 설정으로 사용하면, 기존 문서 및 자료와의 일관성을 유지할 수 있다. 이는 코드 공유와 협업 시에도 유리하다.

 

→ 테스트와 개발 환경의 유연성:

8080은 테스트와 개발 환경에서 다중 서버와 인스턴스를 운영할 때 유연성을 제공한다. 기본적으로 많은 애플리케이션이 8080을 사용하지만, 필요에 따라 다른 포트로 쉽게 변경할 수 있다. 이 포트는 충돌이 적고, 로컬 개발 환경에서 설정이 쉬워 자주 사용된다.

 

→ 다중 애플리케이션 테스트의 편리함:

개발자들이 여러 애플리케이션을 동시에 테스트하거나, 다양한 서비스와의 상호작용을 시뮬레이션해야 할 때가 많다. 이러한 경우 각 애플리케이션이 고유한 포트를 사용해야 하고, 8080을 기준으로 순차적으로 8081, 8082 등의 포트를 사용하여 테스트 환경을 구성할 수 있다. 이는 개발 및 디버깅 과정에서 큰 편의를 제공한다.

 

▶ 다른 디폴트 포트의 예시

기본 포트 8080 외에도 다양한 서비스와 애플리케이션이 각기 다른 디폴트 포트를 사용한다. 몇 가지 대표적인 예시는 다음과 같다:

 

  • 80: HTTP의 기본 포트이다. 대부분의 웹 서버가 기본적으로 사용하는 포트이며, 사용자가 특정 포트를 지정하지 않으면 자동으로 사용된다.
  • 443: HTTPS의 기본 포트이다. 암호화된 HTTP 트래픽을 처리하기 위해 사용된다.
  • 3306: MySQL 데이터베이스의 기본 포트이다.
  • 5432: PostgreSQL 데이터베이스의 기본 포트이다.
  • 6379: Redis 서버의 기본 포트이다. ("NERD") 
  • 27017: MongoDB의 기본 포트이다.
  • 25: SMTP(Simple Mail Transfer Protocol)의 기본 포트로, 메일 서버가 주로 사용한다.
  • 22: SSH(Secure Shell)의 기본 포트로, 원격 서버 접근 시 주로 사용된다.

→ 이처럼 각기 다른 서비스가 각기 다른 디폴트 포트를 사용하는 이유는, 네트워크 환경에서 충돌을 피하고 일관성을 유지하기 위해서다. 포트 번호는 프로토콜과 서비스에 따라 정의되며, 개발자는 이 정보를 토대로 적절한 포트를 사용해야 한다.

 

▶ 포트 번호 선택의 철학

포트 번호의 선택은 단순히 "빈 공간"을 찾는 것이 아니라, 명확한 의미와 편리함을 동시에 고려한 결정이다. 8080처럼 직관적인 포트는 전달성과 이해도를 높이고, 특히 새로운 개발자들이나 교육 자료를 제작할 때 학습곡선을 낮추는 데 도움을 준다. 이는 전통적인 포트 번호(예: 80, 443 등)가 보안상의 이유로 개발 환경에서 피해야 할 때 더욱 중요해진다.

 

▶ 결론

기본 포트 번호 8080이 선택된 이유와 다양한 서비스가 사용하는 디폴트 포트에 대해 알아보았다. 8080 포트는 비특권 포트로, 개발자들이 루트 권한 없이 쉽게 사용할 수 있다는 장점이 있다. 또한, 직관적인 숫자와 기존의 전통적 사용 관례로 인해 널리 사용되고 있다. 다른 디폴트 포트 번호들도 특정 서비스나 프로토콜의 특성에 맞게 지정되어 있으며, 네트워크 환경에서의 안정적이고 일관된 통신을 보장한다.

결론적으로, 8080이 기본 포트로 사용되는 이유는 단순한 역사적 결정이 아니라, 기술적 편리함, 안전성, 그리고 일관성을 모두 고려한 현명한 선택이라 할 수 있다.