운영 및 유지보수 리눅스 운영 및 유지 관리 Linux에서 포트 전달을 설정하는 방법

Linux에서 포트 전달을 설정하는 방법

Jul 05, 2023 pm 03:48 PM
리눅스 포트 포워딩

Linux에서 포트 전달을 설정하는 방법

포트 전달은 다양한 네트워크 응용 프로그램에서 매우 중요한 기능입니다. 이를 통해 외부 트래픽을 내부 네트워크의 특정 포트로 전달할 수 있습니다. Linux 시스템에서는 iptables 및 sysctl을 사용하여 포트 전달 기능을 구현합니다. 이 문서에서는 Linux에서 포트 전달을 설정하는 방법을 설명하고 해당 코드 예제를 제공합니다.

  1. 커널 매개변수 확인

포트 포워딩 설정을 시작하기 전에 먼저 커널 매개변수가 포워딩 기능을 허용하는지 확인해야 합니다. 다음 명령어를 실행하면 현재 시스템의 포워딩 설정을 확인할 수 있습니다.

sysctl net.ipv4.ip_forward
로그인 후 복사

출력 결과가 net.ipv4.ip_forward = 1이면 포워딩 기능이 활성화된 것입니다. 출력 결과가 net.ipv4.ip_forward = 0이면 포워딩 기능이 활성화되지 않았다는 의미입니다. 전달 기능이 켜져 있지 않은 경우 다음 명령을 실행하여 일시적으로 전달 기능을 켤 수 있습니다. net.ipv4.ip_forward = 1,说明转发功能已经开启。如果输出结果为net.ipv4.ip_forward = 0,则表示转发功能未开启。在转发功能未开启的情况下,可以通过运行以下命令来临时开启转发功能:

sysctl -w net.ipv4.ip_forward=1
로그인 후 복사

如果需要永久开启转发功能,可以编辑/etc/sysctl.conf文件,并添加或修改以下参数:

net.ipv4.ip_forward=1
로그인 후 복사

修改完毕后,保存文件并运行以下命令使其生效:

sysctl -p
로그인 후 복사
  1. 设置端口转发

实现端口转发的方式有很多种,下面我们将介绍两种常用的方式:使用iptables和使用socat工具。

A. 使用iptables

iptables是Linux系统上常用的防火墙工具,我们可以使用它来设置端口转发。以下是通过iptables设置端口转发的示例代码:

iptables -t nat -A PREROUTING -p tcp --dport <external_port> -j DNAT --to-destination <internal_ip>:<internal_port>
iptables -t nat -A POSTROUTING -j MASQUERADE
로그인 후 복사

其中<external_port>是外部端口,<internal_ip>是内部服务器的IP地址,<internal_port>是内部服务器的端口号。这两条命令将会将外部流量转发到内部服务器上。如果希望外部流量经过转发后仍然能够正确识别源IP地址,可以添加以下命令:

iptables -t nat -A POSTROUTING -o <external_interface> -j MASQUERADE
로그인 후 복사

其中<external_interface>是外部接口的名称,比如eth0

B. 使用socat工具

socat是一款强大的网络工具,可以进行各种网络连接和转发。以下是通过socat设置端口转发的示例代码:

socat TCP-LISTEN:<external_port>,fork TCP:<internal_ip>:<internal_port>
로그인 후 복사

其中<external_port>是外部端口,<internal_ip>是内部服务器的IP地址,<internal_port>是内部服务器的端口号。这条命令将会将外部流量转发到内部服务器上。

  1. 应用转发规则

无论是使用iptables还是socat工具,设置的转发规则都只在当前会话中有效。如果希望在系统重启后依然有效,需要将这些规则应用到系统中。

A. 使用iptables

通过运行以下命令可以将iptables规则应用到系统中:

iptables-save > /etc/sysconfig/iptables
로그인 후 복사

B. 使用socat工具

socat工具默认在后台运行,如果希望socat规则在系统重启后依然有效,可以将socat配置加入到系统启动脚本中。例如,在Ubuntu系统上可以编辑/etc/rc.local文件并添加以下内容:

/path/to/socat TCP-LISTEN:<external_port>,fork TCP:<internal_ip>:<internal_port> &
로그인 후 복사

注意,/path/to/socatrrreee

전달 기능을 영구적으로 켜야 하는 경우 /etc/sysctl.conf를 편집하면 됩니다. 파일을 선택하고 다음 매개변수를 추가하거나 수정하세요.

rrreee

수정 후 파일을 저장하고 다음 명령을 실행하여 적용하세요.

rrreee

    포트 전달 설정🎜🎜🎜여기 포트 전달을 구현하는 방법은 여러 가지가 있습니다. 아래에서는 일반적으로 사용되는 두 가지 방법인 iptables 사용과 socat 도구 사용을 소개합니다. 🎜🎜A. iptables 사용🎜🎜iptables는 Linux 시스템에서 일반적으로 사용되는 방화벽 도구로, 포트 전달을 설정하는 데 사용할 수 있습니다. 다음은 iptables를 통해 포트 전달을 설정하는 샘플 코드입니다. 🎜rrreee🎜여기서 <external_port>는 외부 포트이고, <internal_ip>는 IP 주소입니다. 내부 서버, <internal_port>는 내부 서버의 포트 번호입니다. 이 두 명령은 외부 트래픽을 내부 서버로 전달합니다. 외부 트래픽이 전달된 후 소스 IP 주소를 올바르게 식별하려면 다음 명령을 추가하면 됩니다. 🎜rrreee🎜여기서 <external_interface>는 eth0 . 🎜🎜B. socat 도구 사용🎜🎜socat은 다양한 네트워크 연결 및 전달을 수행할 수 있는 강력한 네트워크 도구입니다. 다음은 socat을 통해 포트 전달을 설정하는 샘플 코드입니다. 🎜rrreee🎜여기서 <external_port>는 외부 포트이고, <internal_ip>는 IP 주소입니다. 내부 서버, <internal_port>는 내부 서버의 포트 번호입니다. 이 명령은 외부 트래픽을 내부 서버로 전달합니다. 🎜
      🎜전달 규칙 적용🎜🎜🎜iptables를 사용하든 socat 도구를 사용하든 전달 규칙 세트는 현재 세션에서만 유효합니다. 시스템을 다시 시작한 후에도 규칙이 유효한 상태로 유지되도록 하려면 이러한 규칙을 시스템에 적용해야 합니다. 🎜🎜A. iptables 사용🎜🎜다음 명령을 실행하여 시스템에 iptables 규칙을 적용할 수 있습니다: 🎜rrreee🎜B. socat 도구를 사용하세요🎜🎜 socat 규칙을 원하는 경우 시스템이 다시 시작된 후에도 유효한 상태를 유지하려면 시스템 시작 스크립트에 socat 구성을 추가할 수 있습니다. 예를 들어 Ubuntu 시스템에서는 /etc/rc.local 파일을 편집하고 다음 콘텐츠를 추가할 수 있습니다. 🎜rrreee🎜 /path/to/socat가 필요하다는 점에 유의하세요. 실제 socat 도구 경로로 대체됩니다. 🎜🎜요약🎜🎜이 문서에서는 Linux 시스템에서 포트 전달을 설정하는 방법을 설명하고 iptables 및 socat 도구를 사용하는 코드 예제를 제공합니다. 포트 전달을 설정하면 외부 트래픽을 내부 서버로 유연하게 전달하여 네트워크 애플리케이션에 대한 로드 밸런싱, 포트 매핑 및 기타 기능을 구현할 수 있습니다. 🎜

위 내용은 Linux에서 포트 전달을 설정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

데비안에서 tigervnc의 로그를 볼 수있는 곳 데비안에서 tigervnc의 로그를 볼 수있는 곳 Apr 13, 2025 am 07:24 AM

Debian Systems에서 TigervNC 서버의 로그 파일은 일반적으로 사용자의 홈 디렉토리의 .VNC 폴더에 저장됩니다. TigervNC를 특정 사용자로 실행하는 경우 로그 파일 이름은 일반적으로 XF : 1.Log와 유사합니다. 여기서 XF : 1은 사용자 이름을 나타냅니다. 이 로그를 보려면 다음 명령을 사용할 수 있습니다. cat ~/.vnc/xf : 1. log 또는 텍스트 편집기를 사용하여 로그 파일을 열 수 있습니다. nano ~/.vnc/xf : 1. 로그 파일에 액세스하고 보는 것은 시스템의 보안 설정에 따라 루트 허가가 필요할 수 있습니다.

Debian Readdir가 다른 도구와 통합하는 방법 Debian Readdir가 다른 도구와 통합하는 방법 Apr 13, 2025 am 09:42 AM

데비안 시스템의 readdir 함수는 디렉토리 컨텐츠를 읽는 데 사용되는 시스템 호출이며 종종 C 프로그래밍에 사용됩니다. 이 기사에서는 ReadDir를 다른 도구와 통합하여 기능을 향상시키는 방법을 설명합니다. 방법 1 : C 언어 프로그램을 파이프 라인과 결합하고 먼저 C 프로그램을 작성하여 readDir 함수를 호출하고 결과를 출력하십시오.#포함#포함#포함#포함#includinTmain (intargc, char*argv []) {dir*dir; structdirent*entry; if (argc! = 2) {

Linux Architecture : 5 개의 기본 구성 요소를 공개합니다 Linux Architecture : 5 개의 기본 구성 요소를 공개합니다 Apr 20, 2025 am 12:04 AM

Linux 시스템의 5 가지 기본 구성 요소는 다음과 같습니다. 1. Kernel, 2. System Library, 3. System Utilities, 4. 그래픽 사용자 인터페이스, 5. 응용 프로그램. 커널은 하드웨어 리소스를 관리하고 시스템 라이브러리는 사전 컴파일 된 기능을 제공하며 시스템 유틸리티는 시스템 관리에 사용되며 GUI는 시각적 상호 작용을 제공하며 응용 프로그램은 이러한 구성 요소를 사용하여 기능을 구현합니다.

데비안 스니퍼의 출력 결과를 해석하는 방법 데비안 스니퍼의 출력 결과를 해석하는 방법 Apr 12, 2025 pm 11:00 PM

Debiansniffer는 네트워크 패킷 타임 스탬프를 캡처하고 분석하는 데 사용되는 네트워크 스나이퍼 도구입니다. 일반적으로 몇 초 만에 패킷 캡처 시간을 표시합니다. 소스 IP 주소 (sourceip) : 패킷을 보낸 장치의 네트워크 주소. 대상 IP 주소 (대상 IP) : 데이터 패킷을 수신하는 장치의 네트워크 주소. Sourceport : 패킷을 전송하는 장치에서 사용하는 포트 번호. Destinatio

더 이상 사용되지 않는 패키지를 재활용하는 방법 더 이상 사용되지 않는 패키지를 재활용하는 방법 Apr 13, 2025 am 08:51 AM

이 기사는 데비안 시스템에서 쓸모없는 소프트웨어 패키지를 청소하고 디스크 공간을 확보하는 방법에 대해 설명합니다. 1 단계 : 패키지 목록 업데이트 패키지 목록이 최신 상태인지 확인하십시오. sudoaptupdate 2 단계 : 설치된 패키지보기 다음 명령을 사용하여 설치된 모든 패키지를 보려면 다음 명령을 사용하십시오. Aptitude는 패키지를 안전하게 삭제하는 데 도움이되는 제안을 제공합니다.

주요 Linux 운영 : 초보자 가이드 주요 Linux 운영 : 초보자 가이드 Apr 09, 2025 pm 04:09 PM

Linux 초보자는 파일 관리, 사용자 관리 및 네트워크 구성과 같은 기본 작업을 마스터해야합니다. 1) 파일 관리 : mkdir, touch, ls, rm, mv 및 cp 명령을 사용하십시오. 2) 사용자 관리 : userAdd, passwd, userdel 및 usermod 명령을 사용합니다. 3) 네트워크 구성 : ifconfig, echo 및 ufw 명령을 사용하십시오. 이러한 운영은 Linux 시스템 관리의 기초이며, 마스터하면 시스템을 효과적으로 관리 할 수 ​​있습니다.

데비안에서 nginx ssl 성능을 모니터링하는 방법 데비안에서 nginx ssl 성능을 모니터링하는 방법 Apr 12, 2025 pm 10:18 PM

이 기사에서는 데비안 시스템에서 NGINX 서버의 SSL 성능을 효과적으로 모니터링하는 방법에 대해 설명합니다. NginxOxporter를 사용하여 Nginx 상태 데이터를 프로 메테우스로 내보낸 다음 Grafana를 통해 시각적으로 표시합니다. 1 단계 : nginx 구성 먼저 Nginx 구성 파일에서 stub_status 모듈을 활성화하여 nginx의 상태 정보를 얻어야합니다. nginx 구성 파일에 다음 스 니펫을 추가하십시오 (일반적으로 /etc/nginx/nginx.conf에 있거나 포함 파일에 위치) : location/nginx_status {stub_status

Debian이 Hadoop 데이터 처리 속도를 향상시키는 방법 Debian이 Hadoop 데이터 처리 속도를 향상시키는 방법 Apr 13, 2025 am 11:54 AM

이 기사에서는 데비안 시스템에서 Hadoop 데이터 처리 효율성을 향상시키는 방법에 대해 설명합니다. 최적화 전략에는 하드웨어 업그레이드, 운영 체제 매개 변수 조정, Hadoop 구성 수정 및 효율적인 알고리즘 및 도구 사용이 포함됩니다. 1. 하드웨어 리소스 강화는 모든 노드에 일관된 하드웨어 구성, 특히 CPU, 메모리 및 네트워크 장비 성능에주의를 기울일 수 있도록합니다. 전반적인 처리 속도를 향상시키기 위해서는 고성능 하드웨어 구성 요소를 선택하는 것이 필수적입니다. 2. 운영 체제 조정 파일 설명 자 및 네트워크 연결 : /etc/security/limits.conf 파일을 수정하여 파일 설명자의 상한을 늘리고 동시에 시스템에 의해 열 수 있습니다. JVM 매개 변수 조정 : Hadoop-env.sh 파일에서 조정

See all articles