centos系统配置转发和iptables使之成为网关

news2024/9/22 0:52:01

centos系统配置转发和iptables使之成为网关

在当下互联网环境中,有很多内网服务器不能出网,例如安装软件包,更新程序之类的,偶尔会需要出网,下面这种方式就是专门解决这个事情的。
如下配置在 centos 6 7 8 rocky 8 9 都生效
前提是内网环境中是有一台可以出网的服务器。
前期准备
yum install -y epel-release
yum -y install net-tools vim lrzsz wget git  yum-utils telnet  unzip tar iptables-services lm_sensors gcc make

关闭firewalld防火墙及selinux

systemctl disable --now firewalld
sed -i 's/^SELINUX=enforcing$/SELINUX=disabled/' /etc/selinux/config
setenforce 0
配置如下,很简单
找到当前可以出网的那一台服务器
在其服务器上配置
参数优化

vim /etc/sysctl.conf
# 一下这些设置一般用于高负载环境中,比如高并发的Web服务器或数据库服务器,
# 以优化性能和提高系统稳定性。调整这些参数时需要根据具体的使用场景和负载情况进行测试和优化。

net.ipv4.ip_forward = 1
# 启用IPv4数据包转发,通常用于路由器或网关。

net.ipv4.conf.default.rp_filter = 1
# 启用逆向路径过滤,以防止伪造源地址的IP包。

net.ipv4.conf.default.accept_source_route = 0
# 禁用源路由,这样就不会接受源路由数据包。

net.ipv4.tcp_syncookies = 1
# 启用TCP同步 cookies,以防止SYN洪水攻击。

net.ipv4.tcp_tw_reuse = 1	
# 允许重新使用TIME_WAIT状态的TCP连接,以减少资源消耗。

net.ipv4.tcp_tw_recycle = 0
# 禁用TIME_WAIT状态的TCP连接回收,因为它可能会导致NAT环境中的连接问题(该参数在较新的Linux内核中已被弃用)。

net.ipv4.tcp_fin_timeout = 30
# 设置TCP连接的FIN_WAIT2状态超时时间为30秒。

net.ipv4.tcp_keepalive_time = 30
# 设置TCP连接的Keepalive探测时间为30秒,以检测连接的健康状态。

net.ipv4.ip_local_port_range = 2048 65000
# 设置本地端口的范围,供客户端使用的端口号范围从2048到65000。

net.ipv4.tcp_max_syn_backlog = 65536
# 增加TCP SYN队列的最大长度,以防止SYN洪水攻击。

net.ipv4.tcp_mem = 94500000 915000000 927000000
# 设置TCP内存参数,用于调整TCP缓存的大小。这三个值分别表示低水位、中水位和高水位。

net.ipv4.tcp_max_orphans = 3276800
# 设置最大孤儿连接数(即没有任何用户进程处理的连接)。

net.netfilter.nf_conntrack_max = 2097152
# 设置Netfilter连接跟踪表的最大条目数,影响NAT和防火墙的性能。

#####  内核和系统资源相关配置

kernel.sysrq = 0
# 禁用SysRq(系统请求)键,这是一种通过特定的键盘快捷键触发内核功能的方式。

kernel.core_uses_pid = 1
# 启用内核使用PID(进程ID)作为core dump文件的前缀,以便更容易识别core文件来源的进程。

kernel.msgmnb = 65536
# 设置消息队列的最大字节数。

kernel.msgmax = 65536
# 设置消息队列中单个消息的最大字节数。

kernel.shmmax = 68719476736
# 设置共享内存段的最大字节数(64GB)。

kernel.shmall = 4294967296
# 设置系统中共享内存页的最大总数。

fs.file-max = 655350
# 设置系统可以打开的最大文件描述符数量。

vm.overcommit_memory = 1
# 设置内存超分配策略,使系统总是允许超分配内存(尽管实际使用情况可能会导致OOM(内存不足))。

vm.max_map_count = 262144
# 设置每个进程可以拥有的最大内存映射区域数。

##### 网络缓冲区和队列相关配置

net.core.netdev_max_backlog = 32768
# 设置网络设备接收队列的最大长度,以提高网络吞吐量。

net.core.somaxconn = 32768
# 设置每个端口上允许的最大连接队列长度,以提高网络服务的并发能力。

net.core.wmem_default = 8388608
# 设置网络套接字发送缓冲区的默认大小(8MB)。

net.core.rmem_default = 8388608
# 设置网络套接字接收缓冲区的默认大小(8MB)。

net.core.rmem_max = 16777216
# 设置网络套接字接收缓冲区的最大大小(16MB)。

net.core.wmem_max = 16777216
# 设置网络套接字发送缓冲区的最大大小(16MB)。

net.ipv4.tcp_synack_retries = 1
# 设置TCP连接的SYN-ACK重试次数,减少连接建立时间。

net.ipv4.tcp_syn_retries = 1
# 设置TCP连接的SYN重试次数,减少连接建立时间。

在这里插入图片描述

修改配置使得当前的Linux系统可以作为路由器,转发经过的IPv4数据包
echo "1" >/proc/sys/net/ipv4/ip_forward
将IPv4数据包转发功能启用。设置为 1 表示允许数据包转发;如果设置为 0,则禁止数据包转发。

/proc/sys/net/ipv4/ip_forward
一个用于控制Linux内核参数的虚拟文件,专门用于配置IPv4数据包转发功能。
修改iptables配置
vim /etc/sysconfig/iptables

新增
*nat
:PREROUTING ACCEPT [1933951542:108342552632]
:POSTROUTING ACCEPT [0:0]
:OUTPUT ACCEPT [2340407104:140430495260]
-A POSTROUTING -o ens33 -j MASQUERADE
COMMIT

注释掉
# 这条规则的作用是拒绝所有经过本机的转发流量
#-A FORWARD -j REJECT --reject-with icmp-host-prohibited

# 确保 ens33 是系统中存在的网络接口。使用 ip a 命令确认接口名称,改为自己的

在这里插入图片描述
在这里插入图片描述

重启 iptables
systemctl restart iptables

当前能出网的服务器IP,以上配置都是在这台配置

在这里插入图片描述

需要出网的内网服务器IP

在这里插入图片描述
在这里插入图片描述

大功告成! 完结撒花

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2054565.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

FPGA 最小系统 EP2C5T144C8N

参考 : 微雪 ep2c5t 米尔 所需元件: 1.2v 3.3v稳压芯片 7个10k电阻 一个use blast 5v-》3.3v稳压-》1.2v稳压 1.JTAG连接 JTAG连接 NSTATUS nconfig config_done 因为没有外部存储器,直接使用Jtag烧录,从而nconfig 为3.3 &…

全场景——(三)USB开发基础(2)

文章目录 一、USB 描述符1.1 USB 设备状态切换图1.2 标准设备请求1.2.1 SETUP事务的数据格式1.2.2 标准设备请求1.2.3 设备/配置/接口/端点 1.3 描述符1.3.1 设备描述符1.3.2 配置描述符1.3.3 接口描述符1.3.4 端点描述符1.3.5 示例 1.4 设备枚举过程示例 二、USBX 组件2.1 Azu…

Rhinoceros 8 for Mac/Win:重塑三维建模边界的革新之作

Rhinoceros 8(简称Rhino 8),作为一款由Robert McNeel & Assoc公司开发的顶尖三维建模软件,无论是对于Mac还是Windows用户而言,都是一款不可多得的高效工具。Rhino 8以其强大的功能、广泛的应用领域以及卓越的性能&…

阿里云发送短信功能(Java)

(1)注册用户,并且开通短信套餐 (2) 点击快速学习,然后绑定测试的手机号码。 选用专用测试签名(自定义的话阿里可能会验证什么什么的比较麻烦) 然后在选取调用API (3&…

Excel ——3个实用的随机函数(RAND 、RANDBETWEEN、RANDARRAY)

1、RAND 函数 RAND 函数是一个没有参数的函数:RAND () 返回一个大于等于 0,小于 1 的随机实数。 选中任一单元格,在编辑栏输入公式: 如果要生成 a 与 b 之间的随机数,就用: RAND()*(b-a)a 比如要生成-5…

Docker Compose运行Elasticsearch

前提:确保你已经安装了Docker和Docker Compose 创建项目目录 创建一个目录来存放项目文件 mkdir es cd es 创建docker-compose.yml文件 touch docker-compose.yml version: 3.3 services: elasticsearch: image: docker.elastic.co/elasticsearch/elastics…

mysql windows、Ubuntu安装与远程连接配置

下载 在Windows下安装MySQL需要在官网下载安装包 官网地址www.mysql.com 找到社区下载 选择适用于Windows的MYSQL安装程序 选择自己电脑对应的版本和所要下载的mysql版本一般是5.7版本和8.0版本 按照图片上的选项进行安装 到此就安装完成了 需要自己手动配置环境变量…

光纤猫光功率正常值是多少

光纤猫光功率正常值是多少 1. 光猫发送的光功率正常范围为负15dBm。 2. 光猫接收的光功率理想值为负9dBm至负27dBm。 3. 光模块发射的光功率应为0dBm或正1dBm以上。 4. 光信号通过一级光交箱跳纤会损失1到2dBm,因此到达一级光分箱的主纤光功率为负2dBm。 5. 经过一级…

模拟实现Stack的适配器【栈】【C++】

P. S.:以下代码均在VS2022环境下测试,不代表所有编译器均可通过。 P. S.:测试代码均未展示头文件stdio.h的声明,使用时请自行添加。 博主主页:LiUEEEEE                        …

sentinel 02 核心类

01 02. 03. 04. 05. 4.1 4.2 4.3 4.4 5调用链

JavaScript学习笔记(十二):JS Web API

1、Web API - 简介 Web API 是开发人员的梦想。 它可以扩展浏览器的功能它可以极大简化复杂的功能它可以为复杂的代码提供简单的语法 1.1 什么是 Web API? API 指的是应用程序编程接口(Application Programming Interface)。 Web API 是 …

基于SpringBoot的网上宠物店系统

系统背景 在当今快节奏的城市生活中,宠物逐渐成为许多家庭不可或缺的一员,它们不仅是忠诚的伴侣,更是心灵的慰藉。随着宠物市场的日益扩大,人们对于宠物相关服务的需求也日益增长,从宠物食品、玩具到健康护理、训练课程…

SAP-MM-框架协议和货源清单的配合使用

一、业务场景: 某公司一直使用源清单功能,新增框架协议功能, 根据业务需求,公司与供应商签订备货框架协议,供应商要求我司提供单号用于备货使用,但业务部门要求,此单号不能在SRM系统中体现,不能直接做送货单,需要转正式采购订单才能在SRM系统中创建送货单,用于送货…

腾讯云 AI 代码助手四大基础功能介绍

引言 随着技术的不断进步,软件开发者们面临着日益复杂的编程任务和挑战。他们不仅需要处理大量的代码,还要在保证代码质量的前提下,提高开发效率。在这样的背景下,一款能够辅助开发者进行高效编码的工具显得尤为重要。 腾讯云AI…

数字文化产业:融合科技与人文的先锋力量

在当今数字化的时代,数字文化产业正以惊人的速度崛起,成为经济发展和文化繁荣的重要驱动力。那么,究竟什么是数字文化产业呢? 数字文化产业是文化与科技深度融合的产物。它借助先进的数字技术,如大数据、人工智能、虚拟…

【论文分享】通过社交媒体图片和计算机视觉分析城市绿道的使用情况

城市街道为路面跑步提供了环境。本次给大家带来一篇SCI论文的全文翻译!该论文提出了一种非参数方法,使用机器学习模型来预测路面跑步强度。该论文提供了关于路面跑步的实证证据,并突出了规划者、景观设计师和城市管理者在设计适于跑步的城市街…

【数学建模】MATLAB快速入门

文章目录 1. MATLAB界面与基本操作1.1 MATLAB的基本操作 2. MATLAB字符串和文本2.1 string变量2.2 char变量 3. MATLAB的矩阵运算 1. MATLAB界面与基本操作 初始界面: 刚开始的界面只要一个命令行窗口,为了使编辑界面出现我们需要新建一个文件&#xff…

探索 HarmonyOS 的层叠布局:灵活的 Stack 容器

在应用开发中,灵活的布局设计是提高用户体验的关键之一。HarmonyOS 提供了丰富的布局组件,其中层叠布局(Stack Layout)是一个强大的工具,可以帮助开发者轻松实现元素的重叠显示。本文将深入探讨 Stack 容器的功能和应用…

Spring Boot 整合 Spring AI 实现项目接入ChatGPT(OpenAl的调用)

当前各种AI项目层出不穷,但绝大多数都是用python写的,现在Spring开源了Spring AI项目,让Java开发者也可以轻松给自己的springboot项目集成AI能力。目前spring AI正式版本为0.8.1,支持接入openAI、Ollama、Azure openAI、Huggingfa…

流媒体服务器二:2.RTMP协议学习

一 RTMP协议详解 1.总体介绍 RTMP协议是应⽤层协议,是要靠底层可靠的传输层协议(通常是TCP)来保证信息传输的可靠性的。在 基于传输层协议的链接建⽴完成后,RTMP协议也要客户端和服务器通过“握⼿”来建⽴基于传输层链接之 上的…