Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/chevereto/vps

Collection of universal bash scripts to install Chevereto in any VPS
https://github.com/chevereto/vps

chevereto debian shell-scripts ubuntu vps

Last synced: 2 months ago
JSON representation

Collection of universal bash scripts to install Chevereto in any VPS

Awesome Lists containing this project

README

        

# Chevereto VPS

> 🔔 [Subscribe](https://chevereto.com/go/newsletter) to don't miss any update regarding Chevereto.

Chevereto

[![Chevereto Docs](https://img.shields.io/badge/chevereto-docs-50C878?style=flat-square)](https://v4-docs.chevereto.com/)
[![Chevereto Community](https://img.shields.io/badge/chevereto-community-blue?style=flat-square)](https://chevereto.com/community)
[![Chevereto Discord](https://img.shields.io/badge/chevereto-discord-5865F2?style=flat-square)](https://chevereto.com/go/discord)
[![Chevereto Demo](https://img.shields.io/badge/chevereto-demo-d4af37?style=flat-square)](https://demo.chevereto.com)

Collection of universal bash scripts to install Chevereto in any VPS (Virtual Private Server). We strongly recommend [DigitalOcean](https://chevereto.com/go/digitalocean), [Vultr](https://chevereto.com/go/vultr) and [Linode](https://chevereto.com/go/linode).

## Instructions

* Root login to your VPS
* Run the following script(s)

## Ubuntu

> **Note**: Ubuntu LTS 24.04 is recommended. If you run other system you may need to alter the scripts. Feel free to contribute.

### Prepare

The [prepare.sh](ubuntu/24.04/prepare.sh) script install the system stack (PHP, Apache HTTP Web server, MySQL Server, Composer, FFmpeg and Certbot) on Ubuntu.

Reboot the VPS to make sure to apply any pending kernel updates:

```sh
systemctl reboot
```

Make sure to change `24.04` to match your Ubuntu LTS (available 20.04, 22.04 and 24.04).

```sh
bash <(curl -s https://raw.githubusercontent.com/chevereto/vps/4.1/ubuntu/24.04/prepare.sh)
```

This message will be shown on success:

```plain
[OK] Stack ready for Chevereto!
```

## Common

* The scripts at `common/` will work under any unix-like system
* Requires `curl` and `unzip`

### New

The [new.sh](common/new.sh) script downloads Chevereto and configures Apache HTTP Web server, MySQL and CRON. Its purpose is to prepare for [Chevereto Installation](https://v4-docs.chevereto.com/application/installing/installation.html).

This is intended to brand new installations and it should run after [prepare](#prepare) as it assumes that the system stack is ready.

```sh
bash <(curl -s https://raw.githubusercontent.com/chevereto/vps/4.1/common/new.sh)
```

#### Notes

On the server:

* The web root is located at `/var/www/html`
* The MySQL root password is saved at `/root/.mysql_password`
* Logs are at `/var/log/apache2`

IMPORTANT:

* Secure your database by running `mysql_secure_installation`

### Get

The [get.sh](common/get.sh) script download and extracts Chevereto in the **current working folder**.

* `cd` into the website project folder (for example `/var/www/html`)
* Run the following command

```sh
bash <(curl -s https://raw.githubusercontent.com/chevereto/vps/4.1/common/get.sh)
```

### Cloudflare remote IP

The [cf-remoteip.sh](common/cf-remoteip.sh) script syncs the known IPs for CloudFlare remote IP. This **must** be used if you are using CloudFlare.

> **Warning**: If you use CloudFlare and not complete this setup your Chevereto installation won't be able to retrieve real visitors IP.

```sh
bash <(curl -s https://raw.githubusercontent.com/chevereto/vps/4.1/common/cf-remoteip.sh)
```

* To save the above script in your VPS:

```sh
curl -f -SOJL \
--output-dir /etc/apache2 \
https://raw.githubusercontent.com/chevereto/vps/4.1/common/cf-remoteip.sh
```

* To add the above script to CRON (cron.d) to keep these IP ranges auto updated:

```sh
cat >/etc/cron.d/cf-remoteip </dev/null 2>&1
EOM
```

## HTTPS setup

Run the following command to get automatic renewable HTTPS thanks to certbot. Mind to change `example.com` with the target domain(s).

```sh
certbot --apache -d example.com
```

If you are using `www.` subdomain you can add it like this:

```sh
certbot --apache -d example.com -d www.example.com
```