'localAddr' of https2http seems not working.
Catboy96 opened this issue · comments
Ralf Ren commented
Bug Description
When using frpc
and frps
version 0.58.0, using https2http
plugin to proxy LAN HTTP service to Internet, frpc seems not working.
The output log shows it dials TCP 127.0.0.1:0
instead of 127.0.0.1:3000
, which is abnormal.
I checked netstat -lntp
, shows the following output:
[root@abc frpc]# netstat -lntp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1248/sshd: /usr/sbi
tcp 0 0 0.0.0.0:3000 0.0.0.0:* LISTEN 253334/docker-proxy
tcp 0 0 0.0.0.0:8989 0.0.0.0:* LISTEN 2312/docker-proxy
tcp 0 0 0.0.0.0:2222 0.0.0.0:* LISTEN 253353/docker-proxy
tcp 0 0 0.0.0.0:5230 0.0.0.0:* LISTEN 2294/docker-proxy
tcp 0 0 0.0.0.0:111 0.0.0.0:* LISTEN 1011/rpcbind
tcp 0 0 0.0.0.0:2224 0.0.0.0:* LISTEN 2334/docker-proxy
tcp 0 0 0.0.0.0:8081 0.0.0.0:* LISTEN 2272/docker-proxy
tcp6 0 0 :::22 :::* LISTEN 1248/sshd: /usr/sbi
tcp6 0 0 :::3000 :::* LISTEN 253341/docker-proxy
tcp6 0 0 :::8989 :::* LISTEN 2321/docker-proxy
tcp6 0 0 :::2222 :::* LISTEN 253360/docker-proxy
tcp6 0 0 :::5230 :::* LISTEN 2304/docker-proxy
tcp6 0 0 :::111 :::* LISTEN 1011/rpcbind
tcp6 0 0 :::2224 :::* LISTEN 2340/docker-proxy
tcp6 0 0 :::8081 :::* LISTEN 2279/docker-proxy
Which indicates the TCP port 3000 is open.
frpc Version
0.58.0
frps Version
0.58.0
System Architecture
linux/arm64
Configurations
frps.toml
bindAddr = "0.0.0.0"
bindPort = 7000
vhostHTTPPort = 8080
vhostHTTPSPort = 8443
subDomainHost = "domain.ext"
auth.method = "token"
auth.token = "12345678"
frpc.toml
user = "abc"
serverAddr = "xxx.xxx.xxx.xxx"
serverPort = 7000
auth.method = "token"
auth.token = "12345678"
[[proxies]]
name = "gitea-ssh"
type = "tcp"
localIP = "127.0.0.1"
localPort = 2222
remotePort = 2222
[[proxies]]
name = "gitea-https"
type = "https"
subdomain = "git"
[proxies.plugin]
name = "https2http"
localAddr = "127.0.0.1:3000"
crtPath = "domain.pem"
keyPath = "domain.key"
hostHeaderRewrite = "127.0.0.1"
requestHeaders.set.x-from-where = "frp"
Logs
2024-05-23 12:11:35.690 [I] [sub/root.go:142] start frpc service for config file [frpc.toml]
2024-05-23 12:11:35.690 [I] [client/service.go:294] try to connect to server...
2024-05-23 12:11:35.774 [I] [client/service.go:286] [df40e7da7806f48e] login to server success, get run id [df40e7da7806f48e]
2024-05-23 12:11:35.774 [I] [proxy/proxy_manager.go:173] [df40e7da7806f48e] proxy added: [abc.gitea-ssh abc.gitea-https]
2024-05-23 12:11:35.805 [I] [client/control.go:168] [df40e7da7806f48e] [abc.gitea-https] start proxy success
2024-05-23 12:11:35.806 [I] [client/control.go:168] [df40e7da7806f48e] [abc.gitea-ssh] start proxy success
2024-05-23 12:11:49.541 [E] [proxy/proxy.go:206] [df40e7da7806f48e] [abc.gitea-https] connect to local service [127.0.0.1:0] error: dial tcp 127.0.0.1:0: connect: connection refused
2024-05-23 12:11:49.665 [E] [proxy/proxy.go:206] [df40e7da7806f48e] [abc.gitea-https] connect to local service [127.0.0.1:0] error: dial tcp 127.0.0.1:0: connect: connection refused
2024-05-23 12:11:50.527 [E] [proxy/proxy.go:206] [df40e7da7806f48e] [abc.gitea-https] connect to local service [127.0.0.1:0] error: dial tcp 127.0.0.1:0: connect: connection refused
2024-05-23 12:11:50.655 [E] [proxy/proxy.go:206] [df40e7da7806f48e] [abc.gitea-https] connect to local service [127.0.0.1:0] error: dial tcp 127.0.0.1:0: connect: connection refused
2024-05-23 12:11:56.531 [E] [proxy/proxy.go:206] [df40e7da7806f48e] [abc.gitea-https] connect to local service [127.0.0.1:0] error: dial tcp 127.0.0.1:0: connect: connection refused
2024-05-23 12:11:57.524 [E] [proxy/proxy.go:206] [df40e7da7806f48e] [abc.gitea-https] connect to local service [127.0.0.1:0] error: dial tcp 127.0.0.1:0: connect: connection refused
2024-05-23 12:11:58.246 [E] [proxy/proxy.go:206] [df40e7da7806f48e] [abc.gitea-https] connect to local service [127.0.0.1:0] error: dial tcp 127.0.0.1:0: connect: connection refused
2024-05-23 12:11:59.229 [E] [proxy/proxy.go:206] [df40e7da7806f48e] [abc.gitea-https] connect to local service [127.0.0.1:0] error: dial tcp 127.0.0.1:0: connect: connection refused
Steps to reproduce
- Set
*.domain.ext
A record to IP Addressxxx.xxx.xxx.xxx
. - Use above configuration file and version 0.58.0 arm64 binaries.
- Start
frps -c frps.toml
- Start
frpc -c frpc.toml
- Use browser to navigate to
https://git.domain.ext:8443
...
Affected area
- Docs
- Installation
- Performance and Scalability
- Security
- User Experience
- Test and Release
- Developer Infrastructure
- Client Plugin
- Server Plugin
- Extensions
- Others
fatedier commented
https://github.com/fatedier/frp?tab=readme-ov-file#client-plugins
参考文档,声明 plugin 类型是 type ,不是 name,下个版本这样的配置会直接报错而不是允许运行。
Ralf Ren commented
Thanks a lot!