網頁開發 設定WSL2 開放 local network 連線
開起 Create-React-App 的測試專案
我們就會看到第一個問題,開發頁面不能照常開啟,因為網站是在 Linux 底下開啟的,所以在windows系統下的 localhost:3000是沒有連線,但因為WSL是windows底下的虛擬機,所以連WSL的IP卻能正常顯示。
data:image/s3,"s3://crabby-images/a9213/a92136fb7291ea3ff1369c33900cf21e4261718d" alt=""
data:image/s3,"s3://crabby-images/3f6f8/3f6f866ee13d781243a29c580d6e2f39641e2f63" alt=""
確認WSL2的IP Address
我們先開啟wsl2的終端機輸入指令取得 IP address,172.21.221.189
ip addr | grep eth0
data:image/s3,"s3://crabby-images/0b81e/0b81e70bc51b8064a913a7b7d0ed7419d0a0004a" alt=""
打開 windows 的 Powershell 系統管理員,輸入指令,修改網站的port 跟 wsl2的 ip address
netsh interface portproxy add v4tov4 listenport=3000 listenaddress=0.0.0.0 connectport={網站的port} connectaddress={ wsl2的 ip address}
範例:
netsh interface portproxy add v4tov4 listenport=3000 listenaddress=0.0.0.0 connectport=3000 connectaddress=172.21.221.189
設定防火牆
data:image/s3,"s3://crabby-images/bad54/bad54938b54683ab5408c7505d55ac566acb0b3b" alt=""
data:image/s3,"s3://crabby-images/f4773/f4773fc66badcd51d03e4f499c994ddfd3e7430b" alt=""
data:image/s3,"s3://crabby-images/4e877/4e8771c5da4e9d3afdd88bf50f96a548b7813ca3" alt=""
data:image/s3,"s3://crabby-images/c6b56/c6b56c4eede02c8bbf2af313f2c7aadb01b70c64" alt=""
data:image/s3,"s3://crabby-images/0192d/0192df1592b0d98eb133ce8409408d6c8f9b1381" alt=""
data:image/s3,"s3://crabby-images/a0157/a0157cc0d89b27ed2e38df33d38f9af6e3e8ef08" alt=""
取得 Local Network ip address
data:image/s3,"s3://crabby-images/3d9e3/3d9e368aec3567f89251cc82413e400e7499b9e8" alt=""
取得 Local Network ip address 加上網站的 port 即可對外連線了
http://192.168.2.90:3000/