microsoft / WSL

Issues found on WSL
https://docs.microsoft.com/windows/wsl
MIT License
17.42k stars 823 forks source link

windows11 wsl2,The WSL_PAC_URL configuration does not take effect #11998

Open yuwenlong opened 1 month ago

yuwenlong commented 1 month ago

Windows Version

Microsoft Windows [版本 10.0.22635.4145]

WSL Version

2.3.17.0

Are you using WSL 1 or WSL 2?

Kernel Version

5.15.153.1-2

Distro Version

Ubuntu 23.10

Other Software

image

Repro Steps

1、windows .wslconfig image

2、The wsl is started and the WSL_PAC_URL environment variable is found image

3、HTTP_PROXY and HTTPS_PROXY are not set image

4、Proxy service is available image

5、WSL_PAC_URL is invalid image

Expected Behavior

For the reason of Chinese GFW, WSL2 needs to automatically implement PAC implementation proxy according to WSL_PAC_URL.

Windows uses ShadowsocksR, which is set to allow Intranet access, and step 4 above proves to be valid.

image

Actual Behavior

WSL_PAC_URL is invalid

Diagnostic Logs

No response

github-actions[bot] commented 1 month ago

Logs are required for review from WSL team

If this a feature request, please reply with '/feature'. If this is a question, reply with '/question'. Otherwise please attach logs by following the instructions below, your issue will not be reviewed unless they are added. These logs will help us understand what is going on in your machine.

How to collect WSL logs Download and execute [collect-wsl-logs.ps1](https://github.com/Microsoft/WSL/blob/master/diagnostics/collect-wsl-logs.ps1) in an **administrative powershell prompt**: ``` Invoke-WebRequest -UseBasicParsing "https://raw.githubusercontent.com/microsoft/WSL/master/diagnostics/collect-wsl-logs.ps1" -OutFile collect-wsl-logs.ps1 Set-ExecutionPolicy Bypass -Scope Process -Force .\collect-wsl-logs.ps1 ``` The script will output the path of the log file once done. If this is a networking issue, please use [collect-networking-logs.ps1](https://github.com/Microsoft/WSL/blob/master/diagnostics/collect-networking-logs.ps1), following the instructions [here](https://github.com/microsoft/WSL/blob/master/CONTRIBUTING.md#collect-wsl-logs-for-networking-issues) Once completed please upload the output files to this Github issue. [Click here for more info on logging](https://github.com/microsoft/WSL/blob/master/CONTRIBUTING.md#8-collect-wsl-logs-recommended-method) If you choose to email these logs instead of attaching to the bug, please send them to wsl-gh-logs@microsoft.com with the number of the github issue in the subject, and in the message a link to your comment in the github issue and reply with '/emailed-logs'.

View similar issues

Please view the issues below to see if they solve your problem, and if the issue describes your problem please consider closing this one and thumbs upping the other issue to help us prioritize it!

Closed similar issues:

Note: You can give me feedback by thumbs upping or thumbs downing this comment.

yuwenlong commented 1 month ago

/question

I hope developers take a closer look at what I submitted above, thank you

github-actions[bot] commented 1 month ago
Diagnostic information ``` Found '/question', adding tag 'question' ```
yuwenlong commented 1 month ago

/emailed-logs

The email has been sent with the subject line windows11 wsl2, The WSL_PAC_URL configuration does not take effect https://github.com/microsoft/WSL/issues/11998

Please note that check, thank you.

github-actions[bot] commented 1 month ago
Diagnostic information ``` Found '/emailed-logs', adding tag 'emailed-logs' ```
CatalinFetoiu commented 1 month ago

hello. thanks for reporting the issue

Linux does not support PAC URLs by default, so WSL configures the WSL_PAC_URL env variable so that it can be manually consumed by Linux apps that support using PAC URLs please refer as well to docs at https://learn.microsoft.com/en-us/windows/wsl/troubleshooting#considerations-when-using-autoproxy-for-httpproxy-mirroring-in-wsl

my understanding is that curl does not support PAC URLs you will need to use a Linux tool that knows how to resolve PAC URLs and feed the value of WSL_PAC_URL to this tool

let us know if you have any questions

yuwenlong commented 1 month ago

@CatalinFetoiu Linux does not support PAC URLs by default, so it may be possible to add a configuration parameter to the "ubuntu.exe" file to enable support. For example:

ubuntu.exe --proxy-pac-url=http://127.0.0.1:1080/pac

The idea could be to add a virtual network card that intercepts traffic to the PAC server.