跨地域传文件太麻烦?Nginx+cpolar 让本地服务直接公网访问

跨地域传文件太麻烦?Nginx+cpolar 让本地服务直接公网访问
在这里插入图片描述
在这里插入图片描述


在这里插入图片描述


文章目录

前言

Nginx 是一款轻量级 Web 服务器,能搭建本地测试环境、部署静态网站,还能做反向代理,适合开发者日常开发、测试,以及小团队搭建临时项目演示环境。它占用系统资源少,运行稳定,配置步骤也相对简单,新手也能快速上手。

使用 Nginx 时,要注意避免端口冲突,比如本地同时运行其他服务时,提前规划好 Nginx 的映射端口;另外,若用于项目演示,建议关闭不必要的服务模块,减少服务器负载,让访问更流畅。

但 Nginx 默认只能在局域网内访问,给跨地域开发协作添了不少麻烦:异地同事没办法实时访问本地搭建的测试页面,只能等文件上传到公网服务器后再查看;客户想远程看项目进度演示,还得先压缩打包项目文件,传过去后又可能出现格式错乱,影响沟通效率。

而 Nginx 结合 cpolar 后,不用复杂配置就能生成公网访问地址。比如异地同事直接用公网链接访问你本地的测试环境,实时调试代码;客户通过链接就能查看最新的项目演示,不用反复传文件,整个协作过程像在同一局域网内一样便捷,大大减少跨地域沟通的成本。

本文将介绍如何利用 Ubuntu操作系统、Docker容器技术以及cpolar内网穿透工具来实现公网远程访问本地Nginx服务器的具体操作流程。

image-20240202164626158

1. 安装Docker

本教程操作环境为Linux Ubuntu系统,在开始之前,我们需要先安装Docker。

在终端中执行下方命令:

添加Docker源

# Add Docker's official GPG key:sudoapt-get update sudoapt-getinstall ca-certificates curl gnupg sudoinstall -m 0755 -d /etc/apt/keyrings curl -fsSL https://download.docker.com/linux/ubuntu/gpg |sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg sudochmod a+r /etc/apt/keyrings/docker.gpg # Add the repository to Apt sources:echo\"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu \ $(. /etc/os-release &&echo"$VERSION_CODENAME") stable"|\sudotee /etc/apt/sources.list.d/docker.list > /dev/null sudoapt-get update 

安装Dokcer包

sudoapt-getinstall docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin 

通过运行映像来验证 Docker 引擎安装是否成功

sudo docker run hello-world 

2. 使用Docker拉取Nginx镜像

sudo docker pull nginx:latest 
1706861759156

然后执行查看镜像命令:

sudo docker images 
image-20240202161709942

可以看到成功拉取了Nginx镜像。

3. 创建并启动Nginx容器

成功拉取Nginx镜像后,我们可以使用该镜像创建并运行一个Nginx容器。

在终端执行以下命令:

$ sudo docker run --name nginx-test -p 8080:80 -d nginx 

参数说明:

  • –name mynginx:本例容器名称为mynginx,大家可以自己起名。
  • -p 8080:80: 端口进行映射,将本地 8080 端口映射到容器内部的 80 端口。
  • -d nginx: 设置容器在在后台一直运行。
image-20240202161952894

然后执行下方命令查看容器是否正在运行:

sudo docker ps
image-20240202162120249

可以看到刚才创建的Nginx容器正在运行中。

4. 本地连接测试

现在我们可以通过浏览器直接访问 本机ip:8080 端口的 nginx 服务:

1706862228220

可以看到,本地连接Nginx服务测试成功。

5. 公网远程访问本地Nginx

不过我们目前只能在本地连接刚刚使用docker部署的Nginx服务,如果身在异地,想要远程访问在本地部署的Nginx容器,但又没有公网ip怎么办呢?

我们可以使用cpolar内网穿透工具来实现无公网ip环境下的远程访问需求。

5.1 内网穿透工具安装

下面是安装cpolar步骤:

cpolar官网地址: https://www.cpolar.com
  • 使用一键脚本安装命令
curl -L https://www.cpolar.com/static/downloads/install-release-cpolar.sh |sudobash
  • 向系统添加服务
sudo systemctl enable cpolar 
  • 启动cpolar服务
sudo systemctl start cpolar 

cpolar安装成功后,在外部浏览器上访问Linux 的9200端口即:【http://服务器的局域网ip:9200】,使用cpolar账号登录,登录后即可看到cpolar web 配置界面,结下来在web 管理界面配置即可。

image-20230831171159175

5.2 创建远程连接公网地址

登录cpolar web UI管理界面后,点击左侧仪表盘的隧道管理——创建隧道:

  • 隧道名称:可自定义,注意不要与已有的隧道名称重复,本例使用了:mynginx
  • 协议:http
  • 本地地址:8080
  • 域名类型:随机域名
  • 地区:选择China Top

点击创建

image-20240202162838726

创建成功后,打开左侧在线隧道列表,可以看到刚刚通过创建隧道生成了两个公网地址,接下来就可以在其他电脑(异地)上,使用任意一个地址在浏览器中访问即可。

image-20240202163018023

如下图所示,成功实现在公网环境访问本地Nginx服务!

image-20240202163147725

小结

为了方便演示,我们在上边的操作过程中使用了cpolar生成的HTTP公网地址隧道,其公网地址是随机生成的。

这种随机地址的优势在于建立速度快,可以立即使用。然而,它的缺点是网址是随机生成,这个地址在24小时内会发生随机变化,更适合于临时使用。

如果有长期远程访问本地Nginx服务的需求,但又不想每天重新配置公网地址,还想地址好看又好记,那我推荐大家选择使用固定的二级子域名方式来远程访问。

5.3 使用固定公网地址远程访问

登录cpolar官网,点击左侧的预留,选择保留二级子域名,地区选择China VIP,设置一个二级子域名名称,点击保留,保留成功后复制保留的二级子域名名称

1706863043876
image-20240202163759458

保留成功后复制保留成功的二级子域名的名称:nginx123,返回登录Cpolar web UI管理界面,点击左侧仪表盘的隧道管理——隧道列表,找到所要配置的隧道mynginx,点击右侧的编辑:

image-20240202163857832

修改隧道信息,将保留成功的二级子域名配置到隧道中

  • 域名类型:选择二级子域名
  • Sub Domain:填写保留成功的二级子域名:nginx123
  • 地区:选择China VIP

点击更新(注意,点击一次更新即可,不需要重复提交)

image-20240202164034253

更新完成后,打开在线隧道列表,此时可以看到公网地址已经发生变化,地址名称也变成了固定的二级子域名名称的域名:

image-20240202164246046

最后,我们使用任意一个固定公网地址在浏览器访问,可以看到访问成功,这样一个固定且永久不变的公网地址就设置好了,随时随地都可以远程访问本地Nginx服务了!

image-20240202164418798

以上就是如何在Ubuntu系统使用Docker部署Nginx服务,并结合cpolar内网穿透工具实现公网远程访问内网本地服务的全部流程,感谢您的观看。

当本地服务能轻松实现公网访问,跨地域开发协作不再受物理距离限制,让团队配合更高效、更顺畅。

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

Read more

当 AI 学会“造沙箱“:OpenSandbox 如何让大模型安全地执行代码

当 AI 学会“造沙箱“:OpenSandbox 如何让大模型安全地执行代码

让 AI 写代码容易,让 AI 安全地运行代码?这才是真正的技术硬菜。 你有没有想过这样一个场景:你让 ChatGPT 或 Claude 帮你写了一段 Python 爬虫脚本,它写得漂漂亮亮,但你复制到本地一运行——"rm -rf /"——好家伙,人没了,数据没了,只剩下你和一台空空如也的电脑面面相觑。 当然,这只是一个极端的玩笑。但说真的,AI 生成的代码到底能不能直接运行?运行在哪里?出了问题谁来兜底?这些问题,在 AI 编程助手遍地开花的今天,已经从"理论问题"变成了"每天都要面对的问题"。 今天要介绍的 OpenSandbox,就是阿里巴巴开源的一套专门解决这个问题的"沙箱平台"

By Ne0inhk
OpenClaw macOS 安装配置教程:打造你的本地 AI 助手

OpenClaw macOS 安装配置教程:打造你的本地 AI 助手

✨ Hello,大家好,我是田小新,目前在学 AI,也在用 AI 💡 分享真正 普通人用得上的 AI 方法 👩‍💻 内容包括:AI 工具实操|效率提升|成长方法 作者:田小新 AI 爱好者|阿里云专家博主 🔎 公众号:田小新学AI 👍 关注我,少走弯路 ⭐ 收藏本文,随时回看 一、前言 OpenClaw 是什么? 是啥呢,其实我们可以理解为就是自己的一个Ai小助手,不仅仅是一个聊天机器人 他可以读写我们电脑本地的文件,通过浏览器进行搜索,执行脚本命令,甚至还可以推送到你的飞书里面去,还有定时任务执行等等 详情可以到官网去看额 https://docs.openclaw.ai/zh-CN 本教程适用对象 想学习使用openclaw的同学 预计完成时间(10-15分钟) 二、

By Ne0inhk
【Linux】Linux 系统的目录结构详解

【Linux】Linux 系统的目录结构详解

👋 大家好,欢迎来到我的技术博客! 📚 在这里,我会分享学习笔记、实战经验与技术思考,力求用简单的方式讲清楚复杂的问题。 🎯 本文将围绕Linux这个话题展开,希望能为你带来一些启发或实用的参考。 🌱 无论你是刚入门的新手,还是正在进阶的开发者,希望你都能有所收获! 文章目录 * 【Linux】Linux 系统的目录结构详解 📁 * 1. Linux 目录结构概述 🌐 * 2. 根目录 (/) —— 系统的起点 🚩 * 3. /bin —— 基本命令的家 🛠️ * 4. /sbin —— 系统管理员的工具箱 🛠️ * 5. /lib 和 /lib64 —— 系统库的家园 📦 * 6. /etc —— 系统配置的中枢 📝 * 7. /home —— 用户的私人天地 🏠 * 8. /usr —— 用户程序的宝库 📚 * 9. /var —— 变化的数据中心 🔄 * 10. /dev —— 设备的入口 🖥️ * 11. /proc —— 进程的虚拟文件系统

By Ne0inhk
Ubuntu修改Swap交换空间大小

Ubuntu修改Swap交换空间大小

前言: 安装Ubuntu系统时,选择了默认空间分配方案,Swap空间仅1G,而实际的物理内存有32G,分给Swap空间至少为内存的1倍,最好是内存值的2倍,系统相当卡顿,重做系统后,费力部署的环境怎么又需要重新部署,头痛! 一、查看本机Swap交换空间的内存大小 命令如下 free -m 执行结果如下: longzhiye@longzhiye-laptop:~$ free-m total used free shared buff/cache available Mem: 31995374306039101631142 Swap: 97665911 可以看到本机的Swap空间为976M左右,即1G空间。 下面我们将其扩大64G 二、创建Swap文件 sudo -i 输入密码后,切换root。 mkdir /swap 建立swap文件夹 cd /swap/ 进入到swap文件夹 sudo dd if=/dev/

By Ne0inhk