WSL2Linux 子系统(八)

WSL 设置端口号

上一篇文章中讲解《WSL2Linux 子系统(七)》,本篇则讲解WSL与Windows之间端口转发规则和正向端口代理。代理分为正向代理和反向代理。正向代理是为了减少避免用户直接访问服务器,造成服务器压力过大,内网用户要通过代理服务器才能访问外网。反向代理是外部的客户请求要通过代理服务器才能访问内部服务器,将服务器内部化的操作。在 Windows Subsystem for Linux (WSL) 中端口需要借用Windows netsh 添加端口转发规则,实现与Windows之间端口代理;而外网则需要指定代理服务器实现。

作者:炭烤毛蛋 ,点击博主了解更多。


提示:端口代理规则需要重启wsl生效。

文章目录

  • WSL 设置端口号
  • 1. Windows 设置代理端口号
    • 1.1 IPV4 端口转发
    • 1.2 IPV6 端口转发
    • 1.3 端口映射错误
  • 2. WSL启用代理
  • 3. WSL 启用proxychains代理
  • Tips
  • 结语


1. Windows 设置代理端口号

在WSL (Windows Subsystem for Linux) 中,端口转发通常是通过Windows上的网络工具来实现的,而不是在Linux子系统内部直接处理。使用Windows上的netsh命令进行端口转发,打开Windows命令提示符或powershell(管理员)。

1.1 IPV4 端口转发

  • 创建端口转发规则
    从端口80到WSL的端口9090的流量转发,接下来以简单连接方法。
netsh interface portproxy add v4tov4 listenport=80 listenaddress=0.0.0.0 connectport=9090 connectaddress=<WSL IP>
参数说明
listenport表示要监听的 Windows 端口
listenaddress表示监听地址, 0.0.0.0 表示匹配所有地址, 比如Windows 既有Wifi网卡, 又有有线网卡, 那么访问任意两个网卡, 都会被监听到,当然也可以指定其中之一的IP的地址,从而隔离内网
connectport表示要连接的 WSL 端口
connectaddress表示要转发的地址,如果可用通过localhost来访问WSL2,这里设置为localhost;如果暂不支持, 需要改为 WSL2的IP地址

替换为你的WSL实例的IP地址。如果不知道WSL IP,可以通过WSL查询。

ip addr show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever
2: bond0: <BROADCAST,MULTICAST,MASTER> mtu 1500 qdisc noop state DOWN group default qlen 1000
    link/ether 46:d8:85:b4:23:20 brd ff:ff:ff:ff:ff:ff
3: dummy0: <BROADCAST,NOARP> mtu 1500 qdisc noop state DOWN group default qlen 1000
    link/ether 3e:2c:06:c4:9c:66 brd ff:ff:ff:ff:ff:ff
4: tunl0@NONE: <NOARP> mtu 1480 qdisc noop state DOWN group default qlen 1000
    link/ipip 0.0.0.0 brd 0.0.0.0
5: sit0@NONE: <NOARP> mtu 1480 qdisc noop state DOWN group default qlen 1000
    link/sit 0.0.0.0 brd 0.0.0.0
6: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
    link/ether 00:15:55:78:A3:8C brd ff:ff:ff:ff:ff:ff
    inet 172.24.60.66/20 brd 172.24.63.255 scope global eth0
       valid_lft forever preferred_lft forever
    inet6 fe80::215:5dff:fe7f:a38c/64 scope link
       valid_lft forever preferred_lft forever

如果你使用的是Windows防火墙,需要添加一个规则来允许这些端口的流量。确保防火墙设置允许流量通过用到的端口。

  • 查看当前端口转发规则
netsh interface portproxy show all

侦听 ipv4:                 连接到 ipv4:

地址            端口        地址            端口
--------------- ----------  --------------- ----------
0.0.0.0         80          172.24.60.66    9090
  • 删除端口转发规则
    删除之前创建的端口转发规则
netsh interface portproxy delete v4tov4 listenport=80 listenaddress=0.0.0.0

1.2 IPV6 端口转发

ipv6端口与ipv4基本相同,唯一区别参数 v4tov6。

netsh interface portproxy add v4tov6 listenport=80 listenaddress=0.0.0.0 connectport=9090 connectaddress=<WSL IP>

查看之前创建的ipv6端口转发规则

netsh interface portproxy show all

侦听 ipv4:                 连接到 ipv6:

地址            端口        地址            端口
--------------- ----------  --------------- ----------
0.0.0.0         80          172.24.60.66    9090

可以看到已经连接到 ipv6 地址

删除之前创建的ipv6端口转发规则

netsh interface portproxy delete v4tov6 listenport=80 listenaddress=0.0.0.0

1.3 端口映射错误

错误 ssh_exchange_identification: read: Connection reset by peer

建议将connectaddress指定为WSL2的ipv4的回环地址:

netsh interface portproxy add v4tov4 listenport=80 listenaddress=0.0.0.0 connectport=9090 connectaddress=`WSL2 IP Address`

2. WSL启用代理

在WSL(Windows Subsystem for Linux)中设置代理通常涉及两个步骤:配置网络和修改环境变量。

# 打开WSL的网络配置文件
notepad $Env:WINDIR\System32\drivers\etc\hosts

在文件中添加代理服务器的IP和端口

# 代理服务器的IP和端口
0. 0.0.0 3128 your.proxy.server

WSL 修改环境变量以使用代理

# 设置环境变量
export http_proxy=http://your.proxy.server:3128
export https_proxy=https://your.proxy.server:3128
export ftp_proxy=http://your.proxy.server:3128
export no_proxy="localhost,127.0.0.1,::1"

请将your.proxy.server替换为你的代理服务器的实际IP地址或域名,将3128替换为你的代理端口。
需要用户名和密码的代理,你需要在URL中包含这些信息。

export http_proxy=http://username:password@your.proxy.server:3128

3. WSL 启用proxychains代理

某些场景中无法下载软件包,需要使用proxychains工具来强制应用程序通过代理服务器进行网络连接。
proxychains是一个在Linux下非常流行的工具,它可以用来通过SOCKS代理来转发TCP连接。

安装proxychains

sudo apt-get install proxychains

修改 proxychains 代理配置
proxychains.conf文件通常位于/etc/proxychains.conf。

#socks5 127.0.0.1 1080
socks5 192.168.1.100 3128

取消注释(删除#)并修改socks5行,将192.168.1.100和3128替换为你的代理服务器的实际IP地址和端口。

proxychains3 链接错误

ERROR: ld.so: object 'libproxychains.so.3' from LD_PRELOAD cannot be preloaded (cannot open shared object file): ignored.

查找当前系统正确 libproxychains.so.3的路径信息

find /usr/lib/ -name libproxychains.so.3
/usr/lib/x86_64-linux-gnu/libproxychains.so.3

解决方式则是修正 LD_PRELOAD 声明

sudo vim /usr/bin/proxychains3

#!/bin/sh
echo "ProxyChains-3.1 (http://proxychains.sf.net)"
if [ $# = 0 ] ; then
        echo "  usage:"
        echo "          proxychains <prog> [args]"
        exit
fi
-export LD_PRELOAD=libproxychains.so.3
+#export LD_PRELOAD=libproxychains.so.3
+export LD_PRELOAD=/usr/lib/x86_64-linux-gnu/libproxychains.so.3
exec "$@"

Tips

查找wsl IP

ip addr show eth0 | grep inet | awk '{ print $2; }' | sed 's/\/.*$//'

结语

不枉博主详细讲解,欢迎订阅博主–炭烤毛蛋 。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

正点原子[第二期]Linux之ARM(MX6U)裸机篇学习笔记-13-按键实验

前言&#xff1a; 本文是根据哔哩哔哩网站上“正点原子[第二期]Linux之ARM&#xff08;MX6U&#xff09;裸机篇”视频的学习笔记&#xff0c;在这里会记录下正点原子 I.MX6ULL 开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了正点原子教学视频和链接中的内容。…

FTP协议与工作原理

一、FTP协议 FTP&#xff08;FileTransferProtocol&#xff09;文件传输协议&#xff1a;用于Internet上的控制文件的双向传输&#xff0c;是一个应用程序&#xff08;Application&#xff09;。基于不同的操作系统有不同的FTP应用程序&#xff0c;而所有这些应用程序都遵守同…

计算机网络【应用层】邮件和DNS

文章目录 电子邮件DNSDNS提供的服务&#xff1a;域名分级域名解析流程DNS资源记录DNS服务器类型 电子邮件 使用SMTP协议发送邮件之前&#xff0c;需要将二进制多媒体数据编码为ASCII码SMTP一般不使用中间邮件服务器发送邮件&#xff0c;如果收件服务器没开机&#xff0c;那么会…

解决jar包中没有主清单目录的问题

文章目录 解决jar包中没有主清单目录的问题问题描述环境描述方法一 | 阿里巴巴构造器的通用解决方案方式二 | 指定MANIFEST.MF路径 解决jar包中没有主清单目录的问题 问题描述 很简单可能很多人都遇到过&#xff0c;maven项目打成jar包后执行报错&#xff1a;jar包中没有主清单…

在模方中已经选好水岸线了,但是点处理瓦块的时候还是提示水岸线没选

答&#xff1a;能部分位置不闭合&#xff0c;双击右键闭合一下&#xff0c;可以强行闭合缺口。 模方是一款针对实景三维模型的冗余碎片、水面残缺、道路不平、标牌破损、纹理拉伸模糊等共性问题研发的实景三维模型修复编辑软件。模方4.1新增自动单体化建模功能&#xff0c;支持…

高情商回复(不是)

背景介绍 在抖音上有这样的视频&#xff0c;视频就是一张图&#xff0c;图上问了一个问题&#xff1a;饭局上&#xff0c;你去帮领导盛饭&#xff0c;领导接过后说&#xff1a;‘盛这么多&#xff0c;喂猪呢&#xff1f;’咋回&#xff1f; 底下有一个搞笑评论&#xff1a;猪可…

迅雷永久破解

链接&#xff1a;https://pan.baidu.com/s/1ZGb1ljTPPG3NFsI8ghhWbA?pwdok7s 下载后解压 以管理员身份运行绿化.bat&#xff0c;会自动生成快捷方式&#xff0c;如果没有可以在program中运行Thunder.exe

UDP如何端口映射?

UDP端口映射是一种网络技术&#xff0c;通过它可以实现在异地组网的情况下&#xff0c;不暴露在公网上&#xff0c;通过私有通道传输数据&#xff0c;并对数据进行安全加密&#xff0c;以保障数据的安全性。这项技术在如今日益复杂和危险的网络环境中显得尤为重要。 UDP&#x…

Rust 适合哪些场景?

目录 二、Rust 适合哪些场景&#xff1f; 三、Rust 社区的发展趋势如何&#xff1f; 四、Rust 快速搭建一个WebServer服务器 一、Rust是什么&#xff1f; Rust是一门赋予每个人构建可靠且高效软件能力的语言。 Rust 程序设计语言 一门帮助每个人构建可靠且高效软件的语言。…

tomcat-以服务的方式重启tomcat

背景 双击tomcat的bin目录下面的startup.bat&#xff0c;会留下一个cmd的窗口&#xff0c;很不优雅 使用service服务的方式启动&#xff0c;并且设置为自动启动 找到tomcat的bin目录输入cmd&#xff0c;按Enter&#xff0c;进入命令行界面。执行“service.bat install” 。&…

详解嵌入式MCU运行时分配的stack和heap

目录 概述 1 认识stack和heap 1.1 栈区&#xff08;stack&#xff09; 1.2 堆区&#xff08;heap&#xff09; 2 stack和heap的区别 2.1 管理方式的不同 2.2 空间大小不同 2.3 产生碎片不同 2.4 增长方式不同 2.5 分配方式不同 2.6 分配效率不同 3 确定stack和heap…

架构师:搭建Spring Security、OAuth2和JWT 的安全认证框架

1、简述 Spring Security 是 Spring 生态系统中的一个强大的安全框架,用于实现身份验证和授权。结合 OAuth2 和 JWT 技术,可以构建一个安全可靠的认证体系,本文将介绍如何在 Spring Boot 中配置并使用这三种技术实现安全认证,并分析它们的优点。 2、Spring Security Spri…

Linux基础04-Linux中目录和文件都能操作的命令

前面两节我们分别学习了目录操作命令和文件操作命令&#xff0c;那么有没有一些既可以操作目录&#xff0c;又可以操作文件的命令呢&#xff1f; 这样我们就不需要记住两套命令了。 其实还真有&#xff0c;今天这一章就带大家学习Linux中目录和文件都能操作的命令 最近无意间获…

深度学习之DCGAN

目录 须知 转置卷积 DCGAN 什么是DCGAN 生成器代码 判别器代码 补充知识 LeakyReLU&#xff08;x&#xff09; torch.nn.Dropout torch.nn.Dropout2d DCGAN完整代码 运行结果 图形显示 须知 在讲解DCGAN之前我们首先要了解转置卷积和GAN 关于GAN在这片博客中已经很…

GraphGPT——图结构数据的新语言模型

在人工智能的浪潮中&#xff0c;图神经网络&#xff08;GNNs&#xff09;已经成为理解和分析图结构数据的强大工具。然而&#xff0c;GNNs在面对未标记数据时&#xff0c;其泛化能力往往受限。为了突破这一局限&#xff0c;研究者们提出了GraphGPT&#xff0c;这是一种为大语言…

ASP.NET MVC(二) HtmlHelper

强类型 》》》 Form Html.Action() 执行一个Action&#xff0c;并返回html字符串。 Html.ActionLink() 生成一个超链接。 》》》 htmlhelper 扩展方法 /// 扩展方法 三要素 静态类静态方法this 》》》》上面需要引入命名空间&#xff0c; 》》》 不需要引入命名空间 pu…

每日OJ题_DFS解决FloodFill⑥_力扣529. 扫雷游戏

目录 力扣529. 扫雷游戏 解析代码 力扣529. 扫雷游戏 529. 扫雷游戏 难度 中等 让我们一起来玩扫雷游戏&#xff01; 给你一个大小为 m x n 二维字符矩阵 board &#xff0c;表示扫雷游戏的盘面&#xff0c;其中&#xff1a; M 代表一个 未挖出的 地雷&#xff0c;E 代表…

计算机系列之数据库技术

13、数据库技术&#xff08;重点、考点&#xff09; 1、三级模式-两级映像&#xff08;考点&#xff09; 内模式&#xff1a;管理如何存储物理的数据&#xff0c;对应具体物理存储文件。 **模式&#xff1a;**又称为概念模式&#xff0c;就是我们通常使用的基本表&#xff0c…

AquiSense实现UV-C发光二极管里程碑

国际空间站饮水机上使用的UV-C LED技术 紫外线LED水消毒系统制造商AquiSense Technologies宣布&#xff0c;该公司的UV-C LED技术已成功集成到美国国家航空航天局&#xff08;NASA&#xff09;国际空间站&#xff08;ISS&#xff09;上的饮用水分配器中&#xff0c;并自2023年8…

【Git】回滚旧提交版本且不影响最新提交版本

【Git】回滚旧提交版本且不影响最新提交版本 一、场景假设 远程仓库origin中有一个分支main&#xff0c;有4次提交记录&#xff1a;v1、v2、v3、v4。 二、需求 需要回滚旧提交版本&#xff0c;但不影响已有的所有提交版本&#xff08;即不影响最新提交版本&#xff09;&…
最新文章