Websocket+cpolar:如何轻松实现服务远程访问?

文章目录

    • 前言
        • [1. Java 服务端demo环境](#1. Java 服务端demo环境)
        • [2. 在pom文件引入第三包封装的netty框架maven坐标](#2. 在pom文件引入第三包封装的netty框架maven坐标)
        • [3. 创建服务端,以接口模式调用,方便外部调用](#3. 创建服务端,以接口模式调用,方便外部调用)
        • [4. 启动服务,出现以下信息表示启动成功,暴露端口默认9999](#4. 启动服务,出现以下信息表示启动成功,暴露端口默认9999)
        • [5. 创建隧道映射内网端口](#5. 创建隧道映射内网端口)
        • [6. 查看状态->在线隧道,复制所创建隧道的公网地址加端口号](#6. 查看状态->在线隧道,复制所创建隧道的公网地址加端口号)
        • [7. 以基于go的socket客户端为例,通过公网连接java socket服务端](#7. 以基于go的socket客户端为例,通过公网连接java socket服务端)
        • [8. 通过git下载websocket框架](#8. 通过git下载websocket框架)
        • [9. 创建客户端, 注意:Host值为上面复制的隧道公网地址!!](#9. 创建客户端, 注意:Host值为上面复制的隧道公网地址!!)
        • [10. 接着启动服务,与服务端连接,出现服务端返回的字样表示连接成功](#10. 接着启动服务,与服务端连接,出现服务端返回的字样表示连接成功)
        • [11. 客户端在控制台输入信息,回车](#11. 客户端在控制台输入信息,回车)
        • [12. 服务端出现客户端发送的信息](#12. 服务端出现客户端发送的信息)
        • [13. 服务端控制台输入消息,回车](#13. 服务端控制台输入消息,回车)
        • [14. 客户端收到服务端回复的消息,连接成功](#14. 客户端收到服务端回复的消息,连接成功)
        • 实时通信的价值在于打破距离限制,Websocket与cpolar的组合正是这一理念的技术实现。它没有复杂的网络配置,却用最直接的方式连接服务与用户。当技术工具变得如此易用,每个开发者都能专注于创造真正有价值的实时应用。

前言

Websocket作为一种全双工通信协议,为实时应用提供了高效的双向数据传输能力,广泛应用于在线聊天、实时监控和协同编辑等场景。无论是开发者调试实时系统,还是企业部署内部通信工具,它都能满足低延迟、高并发的需求。其核心优势在于持久连接减少资源消耗,原生支持跨域通信,且兼容性良好。

实际使用中,Websocket的本地开发体验十分流畅,但公网部署却常遇阻碍------传统端口转发配置复杂,动态IP环境下连接不稳定,防火墙设置更是让新手望而却步。注意事项方面,服务端需妥善处理连接断开重连机制,避免数据丢失。

局域网限制成为实时应用开发的最大瓶颈:团队成员无法远程测试WebSocket服务,客户演示需依赖临时云服务器,既增加成本又影响效率。这种"看得见却连不上"的困境,让优质的实时功能难以快速落地。

而cpolar内网穿透工具的出现,彻底解决了这一难题。通过简单配置,即可为WebSocket服务生成安全的公网访问地址,无需公网IP和复杂路由设置。无论是异地联调、客户演示还是生产环境临时访问,都能轻松应对,让实时通信应用的开发与部署效率倍增。

下面我们就来试试吧!

1. Java 服务端demo环境
  • jdk1.8
  • 框架:springboot+maven
  • 工具IDEA
2. 在pom文件引入第三包封装的netty框架maven坐标
shell 复制代码
<dependency>
   <groupId>io.github.fzdwx</groupId>
   <artifactId>sky-http-springboot-starter</artifactId>
   <version>0.10.6</version>
</dependency>

注意:pom文件里需注释掉springbootweb启动器,web启动器默认是tomcat服务启动,会和netty服务冲突

3. 创建服务端,以接口模式调用,方便外部调用
shell 复制代码
@GetMapping("/getConnect")
public void getConnect(HttpServerRequest request){

    request.upgradeToWebSocket(ws -> {

    ws.mountOpen(h->{

           ws.send("连接成功,开始聊天吧!");
       });

     ws.mountText(s -> {

         System.out.println(s);

             //对方回复
             System.out.println("客户端回复: "+s);

             //获取控制台输入的值
             Scanner scanner =new Scanner(System.in);

             String next = scanner.next();

             ws.send(next);

     });

    });

}
4. 启动服务,出现以下信息表示启动成功,暴露端口默认9999
5. 创建隧道映射内网端口

这里我们用cpolar内网穿透来映射内网端口,它支持http/https/tcp协议,不限制流量,无需公网ip,也不用设置路由器,操作简单。

  • cpolar一键安装脚本:(国内用户)
shell 复制代码
curl -L https://www.cpolar.com/static/downloads/install-release-cpolar.sh | sudo bash
  • 或短链接安装方式:(国外用户)
shell 复制代码
curl -sL https://git.io/cpolar | sudo bash
  • 查看cpolar版本信息
shell 复制代码
cpolar version

如果正常显示,则安装成功

  • cpolar进行token认证

cpolar官网:https://www.cpolar.com/

进入cpolar官网,注册一个账号并登录进入后台,点击左侧的验证,可以查看到token码,复制并执行命令进行认证

shell 复制代码
cpolar authtoken xxxxxxxxxxxxxxxxxx
  • 配置cpolar开机自启动
shell 复制代码
sudo systemctl enable cpolar
  • 守护进程方式,启动cpolar
shell 复制代码
sudo systemctl start cpolar
  • 查看cpolar守护进程状态,如正常为active,则为正常启动状态
shell 复制代码
sudo systemctl status cpolar

cpolar安装成功后,默认会配置两个默认隧道:一个ssh隧道和一个website隧道,可自行删减或者修改。

接着把本地服务通过cpolar暴露到公网,浏览器访问http://127.0.0.1:9200,登录cpolar web ui 界面,创建一个tcp隧道,指向9999端口

注意:该隧道选择的是临时tcp地址和端口,24小时内会变化,如需固定tcp地址,可升级为专业套餐做tcp地址固定!

6. 查看状态->在线隧道,复制所创建隧道的公网地址加端口号

此时,websocket服务端已经从本地localhost暴露至公网,接着我们创建一个客户端测试公网访问socket服务端连接

7. 以基于go的socket客户端为例,通过公网连接java socket服务端
  • go版本:1.19
  • 工具:vscode
8. 通过git下载websocket框架
shell 复制代码
go get github.com/gorilla/websocket
9. 创建客户端, 注意:Host值为上面复制的隧道公网地址!!
shell 复制代码
package main

import (
    "fmt"
    "log"
    "net/url"

    "github.com/gorilla/websocket"
)

func main() {

    // 定义服务端的地址

    u := url.URL{
        Scheme: "ws",
        Host:   "3.tcp.vip.cpolar.cn:10793", //地址为复制隧道的公网地址
        Path:   "/eth/getConnect"} //服务端controller 映射地址

    // 与服务端建立连接
    c, _, err := websocket.DefaultDialer.Dial(u.String(), nil)
    if err != nil {
        log.Fatal("dial:", err)
    }
    defer c.Close()

    // 阻塞主线程
    down := make(chan byte)

    // 启动一个线程,读取从服务端发送过来的数据
    go func() {
        for {
            _, message, _ := c.ReadMessage()
            fmt.Println("服务端回复:" + string(message))
        }
    }()

    //启动一个线程输入消息
    go func() {

        for {
            var input string

            fmt.Scanln(&input)

            c.WriteMessage(websocket.TextMessage, []byte(input))

        }

    }()

    for {
        <-down
    }
}
10. 接着启动服务,与服务端连接,出现服务端返回的字样表示连接成功
11. 客户端在控制台输入信息,回车
12. 服务端出现客户端发送的信息
13. 服务端控制台输入消息,回车
14. 客户端收到服务端回复的消息,连接成功

需要注意,免费使用cpolar所生成的公网地址为随机临时地址,24小时内会发生变化。如果需要长期远程连接,建议为其配置固定的tcp端口地址。即登录cpolar官网后,点击预留,保留一个固定tcp端口地址,然后将其配置到相应的隧道中即可。

实时通信的价值在于打破距离限制,Websocket与cpolar的组合正是这一理念的技术实现。它没有复杂的网络配置,却用最直接的方式连接服务与用户。当技术工具变得如此易用,每个开发者都能专注于创造真正有价值的实时应用。

cpolar官网-安全的内网穿透工具 | 无需公网ip | 远程访问 | 搭建网站

相关推荐
Mr.Ja2 小时前
【关于虚拟机执行ip addr 命令不显示ip地址问题】
网络协议·tcp/ip·php
雨声不在3 小时前
cronet从编译到修改之: 支持IP直连
python·网络协议·tcp/ip·cronet
8K超高清3 小时前
汇世界迎全运 广州国际社区运动嘉年华举行,BOSMA博冠现场展示并分享与科技全运的故事
运维·服务器·网络·数据库·人工智能·科技
2503_924806853 小时前
动态IP的适用业务场景
网络·网络协议·tcp/ip
康一夏4 小时前
git fatal:Server aborted the SSL handshake
git·网络协议·ssl
weixin_446260854 小时前
提升开发效率的RPC系统!
网络·网络协议·rpc
黄豆匿zlib5 小时前
OpenSpeedy下载 - 全平台网盘提速加速工具|官网入口
网络·娱乐
jiunian_cn5 小时前
【Linux网络】TCP协议
linux·网络·tcp/ip
墨白曦煜7 小时前
HTTP首部字段(速查-全47种)
网络·网络协议·http