https://github.com/excellent-84/kittygram_final
Kittygram - приложение для обмена фото питомцев. Автоматизированный деплой
https://github.com/excellent-84/kittygram_final
django django-rest-framework docker github-actions gunicorn nginx postgresql python yandex-cloud
Last synced: 2 months ago
JSON representation
Kittygram - приложение для обмена фото питомцев. Автоматизированный деплой
- Host: GitHub
- URL: https://github.com/excellent-84/kittygram_final
- Owner: Excellent-84
- Created: 2023-06-02T11:56:24.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-11-03T18:29:59.000Z (over 1 year ago)
- Last Synced: 2024-11-03T19:26:29.061Z (over 1 year ago)
- Topics: django, django-rest-framework, docker, github-actions, gunicorn, nginx, postgresql, python, yandex-cloud
- Language: JavaScript
- Homepage:
- Size: 1.23 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## Проект контейнеры и CI/CD для Kittygram.
### Описание проекта:
Програмный интерфейс для социальной сети Kittygram, по средствам которого пользователи могут публиковать фотографии своих питомцев, выбирать их цвет, указывать их имена и достижения, а так же редактировать и удалять их. Также можно просматривать контент других пользователей. Для создания своего контента и просмотра контента других пользователей необходимо пройти аутентификацию и авторизацию.
Настройка запуска проекта Kittygram в контейнерах.
Настройка автоматического тестирования и деплоя проекта на удалённый сервер.
### Стек технологий:









### Как запустить проект:
##### Клонировать репозиторий:
```
git clone https://github.com/Excellent-84/kittygram_final.git
```
##### Настроить Docker:
```
sudo apt update
sudo apt install curl
curl -fSL https://get.docker.com -o get-docker.sh
sudo sh ./get-docker.sh
sudo apt-get install docker-compose-plugin
```
##### Создать файл .env и указать переменные по примеру .env.example:
```
cd kittygram_final
sudo nano .env
```
##### Установить и запустить Nginx:
```
sudo apt install nginx -y
sudo systemctl start nginx
```
##### Настроить и включить firewall:
```
sudo ufw allow 'Nginx Full'
sudo ufw allow OpenSSH
sudo ufw enable
```
##### Открыть файл Nginx и поменять настройкиб сохранить и закрыть:
```
sudo nano /etc/nginx/sites-enabled/default
server {
listen 80;
server_name your_domain_name.com;
location / {
proxy_set_header HOST $host;
proxy_pass http://127.0.0.1:9000;
}
}
```
##### Проверить корректность настроек и перезапустить Nginx:
```
sudo nginx -t
sudo systemctl start nginx
```
##### Загрузить образы из DockerHub:
```
sudo docker compose -f docker-compose.production.yml pull
```
##### Остановить и удалить все контейнеры:
```
sudo docker compose -f docker-compose.production.yml down
```
##### Запустить контейнеры из образов в фоновом режиме:
```
sudo docker compose -f docker-compose.production.yml up -d
```
##### Выполнить миграции:
```
sudo docker compose -f docker-compose.production.yml exec backend python manage.py migrate
```
##### Собрать статику:
```
sudo docker compose -f docker-compose.production.yml exec backend python manage.py collectstatic
```
##### Создать суперпользователя (указать логин, e-mail, пароль):
```
sudo docker compose -f docker-compose.production.yml exec backend python manage.py createsuperuser
```
#### Автор: [Горин Евгений](https://github.com/Excellent-84)