forked from gomzyakov/secretnotes
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Updated application deployment via CI (on VDS) (gomzyakov#402)
- Loading branch information
Showing
6 changed files
with
140 additions
and
138 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,18 +2,47 @@ | |
|
||
For simplicity, we will deploy the project to VDS. The deployment process consists of several steps: | ||
|
||
## 1. Create a VDS on your preferred hosting | ||
## Create a VDS on your preferred hosting | ||
|
||
Create a VDS virtual machine for Docker, for example, at [NetAngels](https://panel.netangels.ru). | ||
Create a VDS virtual machine for example at [NetAngels](https://panel.netangels.ru). | ||
|
||
For [secretic.app](https://secretic.app) we used distribution `Docker` (Debian 11): | ||
For [secretic.app](https://secretic.app) we used distribution `Ubuntu 20.04`. | ||
|
||
data:image/s3,"s3://crabby-images/05dfa/05dfa0c0ca590d54bd9f8d7272b1716ff5708f13" alt="Docker VDS" | ||
## Set up VDS | ||
|
||
We will launch the project on [Laravel Sail](https://laravel.com/docs/9.x/sail) - yes, this is not ideal, but for non-production purposes it will do. | ||
Login via SSH (as `root` user) and check PHP version (`php -v`). | ||
|
||
If necessary, [upgrade to PHP 8](https://php.watch/articles/php-8.0-installation-update-guide-debian-ubuntu): | ||
|
||
## 2. Generate RSA-key (for access to GitHub) | ||
```bash | ||
sudo apt update | ||
sudo apt install software-properties-common | ||
sudo apt update | ||
sudo add-apt-repository ppa:ondrej/php | ||
sudo apt update | ||
sudo apt install php8.1-common php8.1-cli php8.1-mysql php8.1-xml php8.1-curl php8.1-bcmath php8.1-mbstring -y | ||
``` | ||
|
||
Manually [install](https://getcomposer.org/download/) Composer: | ||
|
||
```bash | ||
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');" | ||
php composer-setup.php | ||
php -r "unlink('composer-setup.php');" | ||
``` | ||
|
||
And make it available for calling through `composer`: | ||
|
||
```bash | ||
sudo mv composer.phar /usr/local/bin/composer | ||
``` | ||
|
||
## CHANGE USER! | ||
|
||
Next, we do everything from the user `web`, not `root`!!! | ||
|
||
|
||
## Generate RSA-key (for access to GitHub) | ||
|
||
First, generate SSH-keys with `ssh-keygen`: | ||
|
||
|
@@ -46,10 +75,9 @@ The key's randomart image is: | |
+----[SHA256]-----+ | ||
``` | ||
## Add RSA-key to GitHub | ||
## 3. Add RSA-key to GitHub | ||
In the GitHub-repository, in the [Deploy Keys](https://github.com/gomzyakov/secretic/settings/keys) section, set the value of the public key from the virtual machine. | ||
In the GitHub-repository, in the `Settings > Deploy Keys` section ([link](https://github.com/gomzyakov/secretic/settings/keys)), set the value of the public key from the virtual machine. | ||
You can get it via: | ||
|
@@ -59,77 +87,54 @@ cat ~/.ssh/id_rsa.pub | |
This will allow deployment via `git pull` from VDS. | ||
## 4. Set secrets in the repository on GitHub | ||
After that, in the GitHub repository, in the `Settings > Secrets > Actions` section, set the values: | ||
## Set secrets on GitHub | ||
After that, in the GitHub repository, in the `Settings > Secrets > Actions` section ([link](https://github.com/gomzyakov/secretic/settings/secrets/actions)), set the values: | ||
- `SSH_HOST`: This is the IP address of the server. | ||
- `SSH_USERNAME`: This is the server username. | ||
- `SSH_USERNAME`: This is the `web` username. | ||
- `SSH_PASSWORD`: This is the user password. | ||
## 5. Clone repository from GitHub | ||
## Clone repository from GitHub | ||
Login to VDS via SSH as `root` user. | ||
Go to path `/var/www/web/sites` and clone current repository (or your own fork). For example, use `secretic.app` folder name: | ||
Go to path `/usr` and clone current repository (or your own fork). By default, Git clone to `secretic` folder: | ||
```bash | ||
git clone [email protected]:gomzyakov/secretic.git && cd secretic | ||
`````` | ||
```bash | ||
cd /var/www/web/sites | ||
git clone [email protected]:gomzyakov/secretic.git secretic.app | ||
cd secretic | ||
``` | ||
## 6. Init & run Laravel Sail on VDS | ||
## Set up Laravel | ||
Run the command for the first time: | ||
Then go to path `/var/www/web/sites/secretic.app` and run some commands: | ||
```bash | ||
docker run --rm \ | ||
-u "$(id -u):$(id -g)" \ | ||
-v $(pwd):/opt \ | ||
-w /opt \ | ||
laravelsail/php81-composer:latest \ | ||
composer install --ignore-platform-reqs | ||
php -r "file_exists('.env') || copy('.env.example', '.env');" | ||
composer install | ||
chmod -R 777 storage bootstrap/cache | ||
php artisan key:generate | ||
``` | ||
Copy the environment settings: | ||
- Write the correct database requisites in the `.env` file | ||
- Create a `secretnotes` database via phpMyAdmin | ||
- Run migrations `php artisan migrate:fresh --seed` | ||
```bash | ||
cp .env.example .env | ||
``` | ||
And replace `DB_HOST` to `mysql` in `.env` (for local development). | ||
Set permissions for some directories: | ||
```bash | ||
chmod -R 777 bootstrap/cache | ||
chmod -R 777 ./storage/logs | ||
chmod -R 777 ./storage/framework | ||
``` | ||
Start containers with Sail: | ||
Open assigned to VDS URL (like `dd`) in your favorite browser. Happy using Secretic! | ||
```bash | ||
./vendor/bin/sail up -d | ||
``` | ||
After that go to shell: | ||
```bash | ||
./vendor/bin/sail shell | ||
``` | ||
And run final commands: | ||
## Optional: Make domain aliases (if needed) | ||
```bash | ||
./artisan key:generate | ||
./artisan migrate:fresh --seed | ||
cd /var/www/web/sites | ||
ln -s secretic.app www.secretic.app | ||
ln -s secretic.app secretic.ru | ||
ln -s secretic.app secretnotes.ru | ||
``` | ||
Open VDS IP-address in your favorite browser. Happy using Secretic! | ||
## 7. Optional: Set up HTTPS | ||
## Optional: Set up HTTPS | ||
>No need if you are using mode `Flexible` on Cloudflare | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Binary file not shown.