【Docker项目实战】使用Docker部署Portall自托管端口管理系统
@TOC
一、 Portall介绍
1.1 Portall简介
Portall
是一个功能强大的Web界面工具,它为用户提供了一个简便的方法来跨多个主机管理端口和服务。这个应用程序对于那些需要同时处理多个网络服务或应用程序,并且希望简化端口配置流程的IT专业人员、开发者以及系统管理员来说非常有用。
1.2 核心特点
- 轻松的端口管理:用户可以很容易地添加新的端口,删除不再需要的端口,并将它们分配给不同的服务和主机。
- 端口号生成:Portall 能够快速生成唯一的端口号,以避免端口冲突问题,确保您的应用能够顺利运行。
- 导入工具:支持通过粘贴 Caddyfile, Docker-Compose 文件或 JSON 数据等方式快速导入现有配置信息,从而加快设置过程。
- 自定义规则:允许用户根据自己的需求设定特定的端口范围,并在端口生成过程中排除某些不可用或者已经占用的端口号。
- 块级设计:采用直观的拖放机制,方便用户组织端口并在不同主机之间移动应用。
- 主题选择:目前提供了浅色和深色两种主题模式,并计划在未来推出更多个性化选项。
- CSS 自定义:开放了 CSS 定制接口,允许有经验的用户自行调整UI样式,实现高度个性化的视觉体验。
- 移动响应式布局:无论是在桌面还是移动设备上使用,都能获得良好的用户体验,保证随时随地都可以高效地进行端口管理。
1.3 主要使用场景
- 开发环境配置:当开发者需要为多个项目创建独立的服务时,Portall 可以帮助他们迅速完成端口配置工作。
- 微服务架构部署:对于采用了微服务架构的企业而言,Portall 有助于更有效地管理和跟踪各个微服务所使用的端口情况。
- 容器化应用部署:与Docker等容器技术结合使用时,Portall 能够简化容器间通信所需的端口映射配置。
- 多租户平台管理:提供托管服务的公司可以利用Portall来优化其内部资源分配,特别是在面对大量客户请求时更加显得重要。
- 网络安全审计:安全团队可以通过Portall监控整个网络中所有开放端口的状态,及时发现潜在的安全隐患。
二、本次实践规划
2.1 本地环境规划
本次实践为个人测试环境,操作系统版本为|Ubuntu 22.04.1。
hostname | IP地址 | 操作系统版本 | Docker版本 | 镜像版本 |
---|---|---|---|---|
jeven01 | 192.168.3.88 | Ubuntu 22.04.1 LTS | 27.1.1 | latest |
2.2 本次实践介绍
1.本次实践部署环境为个人测试环境,生产环境请谨慎;
2.在Docker环境下部署Portall应用。
三、本地环境检查
3.1 检查Docker服务状态
检查Docker服务是否正常运行,确保Docker正常运行。
root@jeven01:~# systemctl status docker
● docker.service - Docker Application Container Engine
Loaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled)
Active: active (running) since Mon 2024-09-09 10:43:35 CST; 3 weeks 5 days ago
Docs: https://docs.docker.com
Main PID: 695 (dockerd)
Tasks: 135 (limit: 9387)
Memory: 4.0G
CPU: 46min 46.854s
CGroup: /system.slice/docker.service
├─ 695 /usr/bin/dockerd
├─ 846 containerd --config /var/run/docker/containerd/containerd.toml
3.2 检查Docker版本
检查Docker版本
root@jeven01:~# docker -v
Docker version 27.1.1, build 6312585
3.3 检查docker compose 版本
检查Docker compose版本,确保2.0以上版本。
root@jeven01:~# docker compose version
Docker Compose version v2.19.1
四、下载Portall镜像
拉取Portall镜像,镜像名称为:
need4swede/portall:latest
。
root@jeven01:~# docker pull need4swede/portall:latest
latest: Pulling from need4swede/portall
f11c1adaa26e: Pull complete
c1f67e58a3d2: Pull complete
9370038d1185: Pull complete
174cb52e37e5: Pull complete
f259657f3656: Pull complete
8c7ba33c7383: Pull complete
1b1e330f6e57: Pull complete
584bbec0a7bd: Pull complete
f0649a86b5c0: Pull complete
Digest: sha256:8f15ad65667aff4221fcc7c13b2c9ff663b56d96fe4c0b4d7c512b678df557ac
Status: Downloaded newer image for need4swede/portall:latest
docker.io/need4swede/portall:latest
五、部署Portall应用
5.1 创建部署目录
- 创建部署目录
mkdir -p /data/portall && cd /data/portall
5.2 编辑部署文件
- 如果使用docker-cli部署,可参考以下命令:
docker run -d \
--restart always \
--name portall \
-p 9900:8080 \
-v /data/portall/data:/app/instance \
-e PORT=8080 \
-e SECRET_KEY=K8dCmZnXa3LQbPfRtGjW \
need4swede/portall:latest
在`部署目录下,创建docker-compose.yaml文件,其中宿主机映射端口等可以自定义配置。
vim docker-compose.yaml
version: '3'
services:
rediary:
image: need4swede/portall:latest
container_name: portall
restart: always
ports:
- 9900:8080
volumes:
- /data/portall/data:/app/instance
environment:
- PORT=8080
- SECRET_KEY=K8dCmZnXa3LQbPfRtGjW
5.3 创建Portall容器
执行以下命令,创建Portall容器。
root@jeven01:/data/portall# docker compose up -d
[+] Running 2/2
✔ Network portall_default Created 0.1s
✔ Container portall Started 0.3s
5.4 查看Portall容器状态
检查Portall容器状态状态,确保Portall容器正常启动。
root@jeven01:/data/portall# docker compose ps
NAME IMAGE COMMAND SERVICE CREATED STATUS PORTS
portall need4swede/portall:latest "python app.py" rediary 25 seconds ago Up 24 seconds 0.0.0.0:9900->8080/tcp, :::9900->8080/tcp
5.5 查看Portall容器日志
检查Portall容器日志,确保Portall服务正常运行。
root@jeven01:/data/portall# docker compose logs
portall | INFO:root:Existing database found.
portall | INFO:root:No migrations folder found. Ensuring all tables exist...
portall | INFO:root:Database tables verified/created.
portall | INFO:root:Starting Portall on port 8080 with debug mode: False
portall | * Serving Flask app 'app'
portall | * Debug mode: off
portall | INFO:werkzeug:WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.
portall | * Running on all addresses (0.0.0.0)
portall | * Running on http://127.0.0.1:8080
portall | * Running on http://192.168.144.2:8080
portall | INFO:werkzeug:Press CTRL+C to quit
六、访问Portall服务
6.1 访问Portall初始页
访问地址:http://192.168.3.88:9900,将IP替换为自己服务器IP地址。如果无法访问到以下页面,则检查宿主机的防火墙是否关闭或者放行相关端口,云服务器则还需要设置安全组规则。
6.2 生成随机端口
新增IP地址,将宿主机本地IP填写即可。
填写描述信息,确认生成新随机端口。
- 查看ports列表
6.3 生成新端口
- 在ports管理模块中,点击“+”号,自行添加端口。
七、总结
通过Docker部署Portall自托管端口管理系统,我们显著简化了服务器端口的管理流程。利用Docker容器化技术,我们能够快速搭建和配置Portall环境,确保了系统的一致性和可移植性。使用Docker Compose进行多容器管理,不仅简化了服务的启动和维护,还使得依赖项的安装和配置变得轻松。最终,团队能够更方便地监控和管理服务器端口,提高了网络资源的利用率和整体系统的安全性。
- 点赞
- 收藏
- 关注作者
评论(0)