什么是Coolify
- 一款超强大的开源自托管 Heroku / Netlify 替代方案
- coolLabs是开源、自托管和以隐私为中心的应用程序和服务的统称
为什么使用Coolify
- 只需单击几下即可托管你的应用、数据库或其他开源服务,等。
- 它是 Heroku 和 Netlify 的一个替代方案。
- 通过 Coolify 可以部署很多应用、数据库、服务,例如:Static、NodeJS、Svelte、React、Vue、Next、Nuxt、Astro、PHP、Rust 等,可以使用自动反向代理和免费 SSL 证书轻松部署应用程序!
- 一键安装 MongoDB、MySQL、PostgreSQL、CouchDB、RedisDB 实例
- 一键安装 WordPress、Ghost Plausible Analytics、NocoDB、BitWarden/VaultWarden、LanguageTool、N8n、VSCode Server 等服务
- 一键将服务部署在任何地方,本地 Docker 引擎、远程 Docker 引擎 (WIP) 或 Kubernetes (WIP)。
- 使用管理系统轻松管理团队。每个团队由一个名称空间分隔,您可以创建任意数量的团队。
- 一键升级您的一体化IaaS平台!
如何使用Coolify
Coolify由以下几部分组成:
- User Interface
- API
- HTTP/TCP Proxy
- TCP Proxies for databases.
- SSL certificates are handled by Let's Encrypt.
各部分详细介绍
User Interface
你可以使用Ul来配置你的实例和所有资源,查看它们的状态,使用情况等。它是一个基于SvelteKit的静态SPA站点。
API
- Coolify的后端部分,用于与远程资源、数据库、Docker引擎等进行通信。
- 它是基于Fastify的后端服务。Fastify is Fast and low overhead web framework, for Node.js
HTTP/TCP Proxy
Coolify动态配置Traefik实例以生成反向代理配置,生成SSL证书并将所有传入流量路由到正确的容器。
TCP Proxies for databases.
使用Coolify部署的数据库可以通过互联网访问。为此,Coolify启动一个单独的Traefik实例,以配置和代理来自internet的TCP连接。
为什么需要一个单独的代理?
- 您可以启动服务器所能处理的任意数量的数据库,因此,例如将100个端口绑定到单个进程可能是CPU密集型任务,如果您只想使用其中的10个端口,则没有意义。
- 使用这种方法,您可以一个接一个地动态绑定主机服务器上的端口。
那么10个数据库将创建10个Traefik实例?#
是的。Traefik是在某种程度上,它只使用~10MB的内存
SSL certificates are handled by Let's Encrypt.
- 如果您定义了以https开头的URL, Coolify将为您的资源生成SSL证书。
- Coolify使用Let’s Encrypt助手来请求、生成和存储SSL证书。
www vs non-www
- 证书仅为已定义的URL生成。如果你指定了一个非www的URL,只有非www的URL才会有证书。你无法到达www网址。
- 通常,你需要在DNS层将www重定向到非www。
- 如果您想为两者生成SSL证书,有一个选项称为Generate SSL for www and non-www?用于应用程序和服务。
TCP数据库代理 HTTP/TCP Proxy
TCP数据库代理 HTTP/TCP Proxy
支持架构
支持AMD64和ARM架构。
支持的操作系统
由于安装脚本的缘故,支持基于Debian的服务器(Coolify本身支持所有可以运行Docker引擎的操作系统)。如果你想要其他的,请考虑在Coolify 的 GitHub 上开放一个问题。
配置要求,Coolify所需的最低资源:
- 2 cpu
- 2gb内存
- 30+ GB的存储空间。
起步
在运行安装脚本之前,请确保您的服务器已经安装了以下包:
- Sudo
- wget
- curl
检测以及安装 以上三个命令的方法
检测是否一经安装了SUDO,如果没有安装,下载软件包进行安装
rpm -q sudo
确定wget是否存在
rpm -qa | grep "wget"
安装 wget
yum -y install wget
验证是否已经安装curl
curl
安装命令
有安装提示
wget -q https://get.coollabs.io/coolify/install.sh \
-O install.sh; sudo bash ./install.sh
最简单的方式就是直接执行下面的命令即可一键安装
wget -q https://get.coollabs.io/coolify/install.sh \
-O install.sh; sudo bash ./install.sh -f
Opt-out from telemetry (count installed instances on the landing page)
wget -q https://get.coollabs.io/coolify/install.sh \
-O install.sh; sudo bash ./install.sh -n
如果想手动安装
- 需要在.env文件中设置所需的环境变量(见下文)
- 需要在服务器上安装Docker引擎v20.10+。
- 配置完成后可以使用 Docker 进行一键启动
COOLIFY_APP_ID= # 一个随机的 UUID,用于区分已安装的实例。
COOLIFY_SECRET_KEY= # 用于加密各种私人数据,长度必须为 32 个字符。
COOLIFY_DATABASE_URL=file:../db/prod.db # SQLite 数据库 URL,必须在 ../db 下。
COOLIFY_SENTRY_DSN=https://[email protected]/6091062 # Sentry 错误报告的 DSN 地址,不是强制性的。
COOLIFY_IS_ON=docker # Coolify 部署的位置,目前,仅支持 docker。
COOLIFY_WHITE_LABELED=false # 会删除 Coolify 实例的“商标”。
COOLIFY_WHITE_LABELED_ICON= # 登录/注册页面上要替换的图标。
COOLIFY_AUTO_UPDATE=false # 它会在后台自动更新你的 Coolify 实例。
docker run -tid --env-file .env -v /var/run/docker.sock:/var/run/docker.sock -v coolify-db-sqlite coollabsio/coolify:latest /bin/sh -c "env | grep COOLIFY > .env && docker compose up -d --force-recreate"
一键安装体验
遇到问题,wget 下载文件出错,没有反应,下载下来的文件是空的,但是下载其他是正常
测试命令正常
wget -c https://download.redis.io/releases/redis-6.0.8.tar.gz
使用这个命令以后下载没有反应
wget -q https://get.coollabs.io/coolify/install.sh -O install.sh; sudo bash ./install.sh -f
生成了文件install.sh,但是vi 它,是空的
问题解决-建立链接时需要在命令行中添加--no-check-certificate
wget -q https://get.coollabs.io/coolify/install.sh --no-check-certificate -O install.sh; sudo bash ./install.sh -f
成功下载,开始安装
又卡住了,拉镜像好慢好慢,卡了十分钟了
尝试更换docker 源
Docker Hub 提供众多镜像,你可以从中自由下载数十万计的免费应用镜像, 这些镜像作为 docker 生态圈的基石,是我们使用和学习 docker 不可或缺的资源。为了解决国内用户使用 Docker Hub 时遇到的稳定性及速度问题,我们需要搞一个加速器,下面介绍我用的三种镜像地址:
打开daemon.json配置文件
vi /etc/docker/daemon.json
添加如下配置
"registry-mirrors": ["https://registry.docker-cn.com"]
重启docker
service docker restart
继续执行指令
sudo bash ./install.sh -f
修改了配置文件
{
"registry-mirrors": ["https://registry.docker-cn.com"]
}
方案一:阿里云:搜索容器服务-镜像加速器
卡太久了,我决定手动拉
配置镜像加速器
针对Docker客户端版本大于 1.10.0 的用户
您可以通过修改daemon配置文件/etc/docker/daemon.json来使用加速器
先粘贴这一段
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://3iew7cd2.mirror.aliyuncs.com"]
}
EOF
再执行下面的
sudo systemctl daemon-reload
sudo systemctl restart docker
方案二:DaoCloud 道客加速器
配置 Docker 镜像站,该脚本可以将 --registry-mirror 加入到你的 Docker 配置文件 /etc/docker/daemon.json 中。适用于 Ubuntu14.04、Debian、CentOS6 、CentOS7、Fedora、Arch Linux、openSUSE Leap 42.1,其他版本可能有细微不同。更多详情请访问文档。
curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s http://f1361db2.m.daocloud.io
方案三:腾讯加速器
https://mirror.ccs.tencentyun.com
docker 下载测速
测试命令:
time docker pull httpd
今天就写到这里啦~
- 小伙伴们,( ̄ω ̄( ̄ω ̄〃 ( ̄ω ̄〃)ゝ我们明天再见啦~~
- 大家要天天开心哦
欢迎大家指出文章需要改正之处~
学无止境,合作共赢