일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- C++
- SWEA
- CS
- python
- 백준
- SECS
- Spring
- MYSQL
- 비트겟
- java
- spring boot
- Gem
- c
- Baekjoon
- SW Expert Academy
- SECS-II
- 파이썬
- 회원가입
- Spring JPA
- Spotify Api
- SECS/GEM
- Computer Science
- modern c++
- 프로그래머스
- 자바
- spotify
- regression
- 스포티파이
- 회귀
- programmers
- Today
- Total
비버놀로지
[SAYE] Sing About Your Emotion 본문
Sing About Your Emotion (SAYE) 🎶🎶🎶
| 😘 SAYE :: Sing About Your Emotion, 당신의 감정을 노래하다. 자세한 기획 개요는 여기서 보실 수 있습니다.
오늘 하루에 대한 당신의 감정(고민,생각)을 분석하여, 당신을 위한 노래 추천 및 스트리밍 서비스
Table of Contents
🚩What's SAYE?
🤖노래 그리고 감정을 키포인트로 프로젝트명을 생각하던 중, 우리 서비스는 사용자의 감정을 입력받아 해당 감정에 맞는 노래를 추천해주고 들려주는 서비스입니다. 그래서 "사용자의 감정에 대한 노래를 불러주는 서비스"라 생각을 하고 접근을 하다가 최종적으로 "Sing abougt your emotion" 약자를 줄여, SAYE 라는 프로젝트명이 탄생하게 되었습니다.
Features
🎨- [음원 스트리밍]
- 스포티파이의 국내 정책 상 1분만 듣기 가능함
- 유튜브 영상을 맵핑시킴으로 최대한 전체 음원을 들을 수 있도록 구현(크롤링 실패 시 유튜브로 이동)
- 오른쪽 Sidebar에 컨트롤러 구현
- [북마크/플레이리스트]
- 북마크 기능 제공
- 플레이리스트 여러개 생성/삭제 가능
- 마이페이지에서 drag&drop으로 북마크에 있던 음원을 플레이리스트에 추가 가능
- [감정에 따른 음원 추천]
- 직접 텍스트 입력 및 STT 기능 구현
- 입력되는 글을 기반으로 감정 분석
- 해당 감정과 유저의 플레이리스트를 기반으로 음원 추천
- [익명 게시판]
- 댓글 기능
- 익명 게시판에 작성된 글을 기반으로 감정 분석하여 음원 추천
Architecture
🐾Entity Relationship Diagram
Sequence Diagrams
- 회원가입
- 로그인
- STT 검색
- 감정분석 검색
- 일반 검색
- 게시판
Browser Support
🌏Chrome
Internet Explorer
Edge
Safari
Firefox
Yes | 10+ | Yes | Yes | Yes |
Packages (M)
📦Frontend
NameDescription
@gsap | Professional-grade animation for the modern web |
@lodash | The Lodash library exported as Node.js modules. |
@get-youtube-id | Parse a youtube url returning the video ID |
@vue-youtube | Wrapper of YouTube IFrame Player API (YIPA) |
@vue-lottie | Lottie Animation View for Vue |
@lottie-web | Lottie for Web, Android, iOS, React Native, and Windows |
@sweetalert2 | A beautiful, responsive, customizable, accessible (WAI-ARIA) replacement for JavaScript's popup boxes. Zero dependencies. |
@vue-audio-recorder | Audio recorder for Vue.js. It allows to create, play, download and store records on a server |
@vue-cookies | A simple Vue.js plugin for handling browser cookies |
@vuedraggable | allowing drag-and-drop and synchronization with view model array. |
---Basic--- | |
@axios | Promise based HTTP client for the browser and node.js |
@vuetify | Vue Material Component Framework |
@vue-router | vue-router 3.0 which works only with Vue 2.0 |
@vuex | Vuex is a state management pattern + library for Vue.js applications |
@vuex-persistedstate | Promise based HTTP client for the browser and node.js |
Backend
NameDescription
$mysql | MySQL connector |
$mybatis | XML 서술자나 애너테이션을 사용하여 저장 프로시저나 SQL 문으로 객체들을 연결 |
$lombok | getter, setter, toString 등의 메서드 작성 코드를 줄여주는 코드 다이어트 라이브러리 |
$jjwt | JWT 토큰 생성 및 JWT 토큰 파싱, 검증을 해주는 라이브러리 |
$json | JavaScript Object Notation; 경량(Lightweight)의 DATA-교환 형식 |
$jackson | JSON Convertor(컨트롤러에서 전달한 DTO데이터를 JSON으로 변경하기 위해 사용 |
$jython | For use python in spring |
$swagger | REST 웹 서비스를 설계, 빌드, 문서화, 소비하는 일을 도와주는 대형 도구 생태계의 지원을 받는 오픈 소스 소프트웨어 프레임워크 |
$spotify | Spotify Web api |
$youtube | Google api services for youtube |
준비하기
📚DB 생성하고 설정 파일 application.properties(백엔드), .env(프론트엔드) 파일 생성 및 추가하시면 됩니다
- Git clone 받기
git clone https://lab.ssafy.com/s04-bigdata-sub3/s04p23d106.git
- 데이터베이스 준비
- 'saye' 테이터베이스 생성
CREATE SCHEMA `saye`;
- 필요한 테이블 생성
- [Backend] application.properties 설정
- backend\src\main\resources 폴더 아래 생성하시면 됩니다
- mysql 도메인과 아이디/비번 작성
server.port=8000 server.servlet.context-path=/saye # for social login spring.profiles.include=oauth ## JSP #spring.mvc.view.prefix=/WEB-INF/views/ #spring.mvc.view.suffix=.jsp # fileupload spring.servlet.multipart.enabled=true spring.servlet.multipart.max-file-size=20MB spring.servlet.multipart.max-request-size=30MB # db spring.datasource.url=jdbc:mysql://{도메인주소}:3306/saye?serverTimezone=UTC&useUniCode=yes&characterEncoding=UTF-8 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.username={DB 계정 아이디} spring.datasource.password={DB 계정 비밀번호} mybatis.type-aliases-package=com.gokchu.saye.repository.dto mybatis.mapper-locations=mapper/*.xml mybatis.configuration.map-underscore-to-camel-case=true
- [Frontend] .env 작성
- frontend 폴더 아래 생성하시면 됩니다
- nginx에 명시된 location을 따라갑니다
VUE_APP_SERVER_URL={도메인주소} VUE_APP_SPRING_URL={도메인주소}/saye VUE_APP_DJANGO_URL={도메인주소}/recommend
- [Frontend] 모듈 다운로드
# frontend 폴더로 이동해서 다운 cd frontend/ yarn install
- [Backend] (Option) Spring boot를 build(jar 파일 생성)
# backend 폴더로 이동해서 cd backend/ mvn -B -DskipTests -f backend
실행하기
🏁- 백엔드 실행
- 생성한 jar 파일 실행
java -jar [filename].jar
- 혹은 war 파일 생성하지 않고 demon으로 로컬에서 실행하고 싶다면 STS와 같은 IDEA에서 Spring boot Run을 실행하거나 아래 명령어를 통해 실행
mvn spring-boot:run
- 프론트엔드 실행
yarn serve
배포하기
🖥해당 서비스는 AWS EC2를 통해 배포하였고 Docker와 Jenkins를 이용해 CI/CD 구축하였습니다:
- AWS EC2 인스턴스 생성 (ubuntu)
- docker 설치
- 필요한 이미지를 docker hub를 통해 설치
- Jenkins
- MySQL
- Jenkins와 Gitlab repository 연동
- MySQL 컨테이너에 saye DB 스키마 생성
- Nginx 설정 (frontend/nginx 폴더의 homepage.conf)
- frontend, backend 폴더 안에 dockerfile 작성
- 프로젝트 root 위치에 Jenkins 파일 작성
- Build and Test 과정
- Build (frontend, backend)
- Run (컨테이너 실행)
- docker ps 를 통해 frontend, backend, django 컨테이너가 실행되는 것을 확인 (Jenkins, MySQL 포함)
Documents
💬Contributer
👥References
🚀License
📜This software is licensed under the MIT © SSAFY.
깃허브
https://github.com/elwlahd555/SAYE
'Project' 카테고리의 다른 글
[Haggle Credit] 중고 거래 및 경매 기반 이커머스 웹 서비스 (0) | 2021.10.14 |
---|---|
[Let's Meet] 약속 장소 추천 및 모임 관리 서비스 (0) | 2021.10.14 |
[드론자율주행대회] 5. 결과 (0) | 2021.02.26 |
[드론자율주행대회] 4. LED 추가 (0) | 2021.02.26 |
[드론자율주행대회] 3. 기본구조 (0) | 2021.02.26 |