一键部署开源PaaS服务Dokploy,代替Vercel, Netlify 以及 Heroku

2024-06-22 22:36

本文主要是介绍一键部署开源PaaS服务Dokploy,代替Vercel, Netlify 以及 Heroku,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

Vercel, Netlify 以及 Heroku都是知名的PaaS(Platform as a Service|平台即服务)服务商,利用这些平台我们可以方便快捷的进行项目部署。尤其是各家生态完善,是很多独立开发者的首选之地。

但是随之而来的就是另外的隐患了:因为各种问题导致项目使用额度超标导致的天价账单

PaaS作为服务商基本上都是属于没有访问限制的说法,用户激增、代码错误、恶意CC攻击都有可能在极短的时间内产生巨额的账单。比如

该用户首次部署服务,却因为一个小小的程序错误导致6个小时内产生三千刀的账单。如果不是发现的及时,可能还会造成更大的损失。虽然经过来回的协商,最终Vercel还是免除了这个账单,但是这名用户已经决定放弃继续使用Vercel了,因为如果再来一次这种事件,很难说是否还会被免单。

一般常见的云厂商的实例只要做好服务器的安全防范措施,最大的危险也只是停机、流量超额罢了,流量方面可以通过限制访问速率等措施避免,或者监控服务器流量异常,都是很容易实现的。但是使用VPS/云服务器之类的相对于PaaS平台来说CI/CD之类的相对麻烦很多。
所以在VPS/云服务器上部署一个开源的PaaS服务相较而言就能较好的结合这两者之间的优点了。

Dokploy简介

引用自官网:
Dokploy是一个免费的可自托管平台即服务(PaaS),简化了应用程序和数据库的部署和管理。
特点
Dokploy包括多种功能,让您的生活更轻松。

应用程序:部署任何类型的应用程序(Node.js、PHP、Python、Go、Ruby等)。
数据库:创建并管理支持MySQL、PostgreSQL、MongoDB、MariaDB和Redis的数据库。
备份:自动将数据库备份到外部存储目标。
Docker Compose:原生支持Docker Compose来管理复杂应用程序。
多节点:使用docker swarm将应用程序扩展到多个节点以管理集群。
模板:一键部署开源模板(Plausible,Pocketbase,Calcom等)。
Traefik集成:自动与Traefik集成进行路由和负载均衡。
实时监控:监视每个资源的CPU、内存、存储和网络使用情况。
Docker管理: 轻松部署和管理Docker容器.
CLI (即将推出⌛) : 使用命令行管理您的应用程序和数据库.
自托管: 在您的VPS上自托管 Dokploy。

Github: Dokploy

官网:dokploy.com/

目前该项目还在快速迭代之中,基本上每周都会有一两个小版本更新

部署

要求:

服务器硬件:2C2GB起步 硬盘30GB以上

支持系统:

  • Ubuntu 24.04 LTS
  • Ubuntu 23.10
  • Ubuntu 22.04 LTS
  • Ubuntu 20.04 LTS
  • Ubuntu 18.04 LTS
  • Debian 12
  • Debian 11
  • Fedora 40
  • Centos 9
  • Centos 8

安装会安装docker,如果服务器内原先没有docker,则会自动启动安装。由于国内docker服务的公开镜像都没有了,所以如果要在国内服务器上安装可以先自己安装docker,然后再运行安装脚本。海外服务器正常步骤即可。

演示服务器为腾讯云的轻量服务器2C4G80GB,同款服务器购买

如果是国内服务器请选择系统镜像时选择使用容器镜像–然后选择Debian或者Ubuntu系统

这样docker就会默认配置使用腾讯云的内网镜像

非常方便,海外服务器随便。

运行脚本

curl -sSL https://dokploy.com/install.sh | sh

由于是内网镜像所以拉取速度很快,一分钟左右就会出现完成提示,趁着15秒系统启动时间,我们先去打开服务器的3000端口以便后续访问。

配置防火墙规则

平台设置

这个没啥好说的,直接设置就行。首次完成后就默认是管理员了。

进入管理面板后是这样的:

这是系统监控:

这是Traefik:

这是docker管理;

图中的docker是我之前玩幻兽帕鲁安装的服务器镜像。

设置页面

设置页面其他的可以自己探索,这里简单推荐一下优先考虑设置的。
Server Domain内的域名,证书申请邮箱,证书提供商这三个建议都填上。

Profile内的账户也可以考虑开启2fa

避免账户被盗

最后一个集群,需要的可以自己尝试一下,也很简单,只需要加一个自己的registry即可。

个人建议直接开一个自托管的。

项目创建及部署

这个也很简单。

创建项目——创建服务即可

数据库支持5种:PostgreSQL、MongoDB 、MariaDB、 MySQL、 Redis

Compose支持docker Compose和Stack

官方提供的模板目前只有三个:

Pocketbase 是 Firebase 的自托管替代方案,允许您构建和托管自己的后端服务。
Plausible是一个开源的、自托管的网络分析平台,可以让您跟踪网站流量和用户行为。
Calcom是Calendly的开源替代品,允许创建日程安排和预订服务。

创建自己的第一个应用

示例:https://github.com/Dokploy/next-todo-app

由于这是一个公开的git项目所以我们只需要在Provider选择Git即可,自己的私有项目可以设置好个人设置内的Github相关项创建APP——授权APP

设置完成后点击deploy即可

你可以进入Deployments——view查看项目部署进展

项目右上角显示黄色的点表示运行中,可以用来判断是否完成

项目部署完成后可以点击logs查看log输出,
想要更改项目的资源占用可以点击Advanced——Resources设置|

域名设置也是按照要求设置即可

不过由于没有对接DNF解析商,所以我们需要自己添加解析,证书是自动申请的。

应用部署完成后会显示:

之后直接访问前面解析的地址即可。

注意事项:

国内的服务器要注意一下应用是不是会大量拉取海外的资源。推荐是在项目中先设置好npm,pnpm,yarn之类的镜像源。这样部署会快很多。不然可能受网速影响,首次部署要耗费大量时间。

总结

如果是成熟的项目,且不对外开放或者使用人数很少的项目还是可以放在Vercel的,免费的层级已经能够覆盖大部分小项目了。

能够承担起vercel之类的月费以及超额费用的也可以继续使用,毕竟生态完善,开发起来配套设施齐全。

价格敏感型用户或者害怕天价账单或者本身就有VPS的可以考虑部署一个Dokploy尝试尝试的。部署难度低,适配性较好。

这篇关于一键部署开源PaaS服务Dokploy,代替Vercel, Netlify 以及 Heroku的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1085607

相关文章

UnrealScriptIDE调试环境部署

先安装vs2010   再安装VSIsoShell.exe, 下载地址 https://pan.baidu.com/s/10kPNUuDGTbWXbz7Nos-1WA       fd3t   最后安装unside,下载地址 https://archive.codeplex.com/?p=uside  安装中间有一步选择Binary文件夹要选对路径。   安装好以后,启动 UDKDe

android一键分享功能部分实现

为什么叫做部分实现呢,其实是我只实现一部分的分享。如新浪微博,那还有没去实现的是微信分享。还有一部分奇怪的问题:我QQ分享跟QQ空间的分享功能,我都没配置key那些都是原本集成就有的key也可以实现分享,谁清楚的麻烦详解下。 实现分享功能我们可以去www.mob.com这个网站集成。免费的,而且还有短信验证功能。等这分享研究完后就研究下短信验证功能。 开始实现步骤(新浪分享,以下是本人自己实现

springboot家政服务管理平台 LW +PPT+源码+讲解

3系统的可行性研究及需求分析 3.1可行性研究 3.1.1技术可行性分析 经过大学四年的学习,已经掌握了JAVA、Mysql数据库等方面的编程技巧和方法,对于这些技术该有的软硬件配置也是齐全的,能够满足开发的需要。 本家政服务管理平台采用的是Mysql作为数据库,可以绝对地保证用户数据的安全;可以与Mysql数据库进行无缝连接。 所以,家政服务管理平台在技术上是可以实施的。 3.1

探索Elastic Search:强大的开源搜索引擎,详解及使用

🎬 鸽芷咕:个人主页  🔥 个人专栏: 《C++干货基地》《粉丝福利》 ⛺️生活的理想,就是为了理想的生活! 引入 全文搜索属于最常见的需求,开源的 Elasticsearch (以下简称 Elastic)是目前全文搜索引擎的首选,相信大家多多少少的都听说过它。它可以快速地储存、搜索和分析海量数据。就连维基百科、Stack Overflow、

青龙面板部署通用教程,含服务器、路由器、X86等部署方法

1. 拉取镜像/更新镜像 docker pull whyour/qinglong:latest 2. 删除镜像 docker rmi whyour/qinglong:latest 3. 启动容器 普通服务器 docker run -dit \-v $PWD/ql/config:/ql/config \-v $PWD/ql/log:/ql/log \-v $PWD/ql/db:

宝塔面板部署青龙面板教程【简单易上手】

首先,你得有一台部署了宝塔面板的服务器(自己用本地电脑也可以)。 宝塔面板部署自行百度一下,很简单,这里就不走流程了,官网版本就可以,无需开心版。 首先,打开宝塔面板的软件商店,找到下图这个软件(Docker管理器)安装,青龙面板还是安装在docker里,这里依赖宝塔面板安装和管理docker。 安装完成后,进入SSH终端管理,输入代码安装青龙面板。ssh可以直接宝塔里操作,也可以安装ssh连接

微服务中RPC的强类型检查与HTTP的弱类型对比

在微服务架构中,服务间的通信是一个至关重要的环节。其中,远程过程调用(RPC)和HTTP是两种最常见的通信方式。虽然它们都能实现服务间的数据交换,但在类型检查方面,RPC的强类型检查和HTTP的弱类型之间有着显著的差异。本文将深入探讨这两种通信方式在类型检查方面的优缺点,以及它们对微服务架构的影响。 一、RPC的强类型检查 RPC的强类型检查是其核心优势之一。在RPC通信中,客户端和服务端都使

手把手教你入门vue+springboot开发(五)--docker部署

文章目录 前言一、前端打包二、后端打包三、docker运行总结 前言 前面我们重点介绍了vue+springboot前后端分离开发的过程,本篇我们结合docker容器来研究一下打包部署过程。 一、前端打包 在VSCode的命令行中输入npm run build可以打包前端代码,出现下图提示表示打包完成。 打包成功后会在前端工程目录生成dist目录,如下图所示: 把

[Centos7] 部署Zabbix5.0

目录 0 卸载 Zabbix1 准备工作1.1 关闭防火墙1.2 关闭SELinux1.3 重启服务器1.4 安装MySQL 2 配置 Zabbix yum 源2.1 安装zabbix的软件仓库配置包2.2 安装 Software Collections 仓库2.3 修改 Zabbix 仓库配置文件 3 安装 Zabbix3.1 遇到报错Requires: libmysqlclient.so

中国341城市生态系统服务价值数据集(2000-2020年)

生态系统服务反映了人类直接或者间接从自然生态系统中获得的各种惠益,对支撑和维持人类生存和福祉起着重要基础作用。目前针对全国城市尺度的生态系统服务价值的长期评估还相对较少。我们在Xie等(2017)的静态生态系统服务当量因子表基础上,选取净初级生产力,降水量,生物迁移阻力,土壤侵蚀度和道路密度五个变量,对生态系统供给服务、调节服务、支持服务和文化服务共4大类和11小类的当量因子进行了时空调整,计算了