Heroku 에 PHP 애플리케이션 배포하는 2가지 방법 (Web, CLI), Laravel 배포 방법
몇가지 방법이 더 있겠지만 여기에서는 제가 해본 2가지 방법에 대해 설명합니다.
아래 내용을 진행하기 전에 PC 에 Heroku CLI 와 Git 명령어를 설치해야 합니다. 아래 URL 을 참고해 주세요.
추가로 Heroku 가입, PHP 개발 소스는 미리 준비 하였다는 가정하에 진행합니다.
https://devcenter.heroku.com/articles/heroku-cli
1. Heroku 웹에서 배포 (with Github)
- 방법 : Heroku 웹사이트에서 Github 소스를 배포
Heroku 로그인 후 대시보드 (https://dashboard.heroku.com/apps) 에 들어갑니다.
[Create new app] 을 클릭
App name : php1 입력, Choose a region : United States 선택 후 [Create app] 클릭
Deployment method 에서 GitHub 선택
Search for a repository to connect to 에서 계정과 repo-name 입력, [Search] 클릭, 출력된 주소 옆에 [Connect] 클릭
- Automatic deploys
- Manual deploys
이렇게 두개 섹션이 출력되는데 아래 Manual deploys 에서 [Deploy Branch] 를 클릭하면, Building 결과가 실시간으로 출력됩니다.
작업이 완료되면 하단의 [View] 버튼을 눌러 결과를 확인합니다.
2. Heroku CLI 에서 배포
- 방법 : PC CLI 에서 로컬 소스를 배포
CLI 에서 PHP소스 디렉토리로 이동해 아래 명령을 순차적으로 실행합니다.
CLI 에서 Heroku 사용자로 로그인을 할때 URL 이 출력되는데 이를 웹브라우저에서 접속해 [로그인] 버튼을 누르면 CLI 에서 로그인 되어집니다.
# heroku login
php2 앱을 생성합니다.
# heroku create php2
Creating ⬢ php2... done
https://php2-637bfaa5dd48.herokuapp.com/ | https://git.heroku.com/php2.git
추가 명령을 실행합니다.
# git init
# git add .
# git commit -m 'new project'
# heroku git:remote -a php2
# git push heroku mastar // 에러 발생시 master 대신 main 입력 후, 재실행
CLI 에서 현재 디렉토리의 소스가 Heroku 로 업로드 되며 Building 결과가 실시간으로 출력됩니다.
작업의 완료되면 아래와 같은 URL 이 출력되는데, 브라우저로 접근해 결과를 확인합니다.
remote: https://php2-d394c22d4ef6.herokuapp.com/ deployed to Heroku
* 소스 업데이트
소스 수정 후에 다시 반영하려면 아래와 같은 절차를 따릅니다.
# git add .
# git commit -m "edited"
# git push heroku master // 에러 발생시 master 대신 main 입력 후, 재실행
3. Laravel 배포
Laravel 소스를 배포하기 위한 Composer 설치 및 Laravel 프로젝트 생성 방법은 아래 포스팅을 참고해 주세요.
https://sysdocu.tistory.com/1874
이후의 방법은 아래 URL 을 참고하여 재작성 하였습니다.
https://devcenter.heroku.com/articles/getting-started-with-laravel
- 방법 : PC CLI 에서 로컬 Laravel 소스를 배포
위 포스팅에서와 같이 Laravel 프로젝트 생성 준비가 되었다면, 다음과 같은 과정을 거쳐 배포가 가능합니다.
Laravel 프로젝트를 생성합니다. (예 : laravel_test)
# composer create-project laravel/laravel --prefer-dist laravel_test
# cd laravel_test
Git 저장소를 초기화하고 현재 상태를 커밋 합니다.
# git init -b main
# git add .
# git commit -m "laravel project"
기본적으로 Heroku 는 프로젝트의 루트 디렉터리에서 응용 프로그램을 서비스하기 위해 PHP 와 함께 Apache 웹 서버를 시작합니다.
아래 내용으로 Procfile 파일을 생성합니다.
# echo "web: heroku-php-apache2 public/" > Procfile
# git add .
# git commit -m "Procfile for Heroku"
Push 할 수 있는 새로운 Heroku 애플리케이션을 만듭니다. (예 : php3)
# heroku create php3
Laravel 암호화 키를 설정합니다. Larvel 은 애플리케이션의 암호화 키를 사용하여 사용자 세션 및 기타 정보를 암호화합니다.
구성에서 선택한 암호의 규칙을 준수해야 하므로 유효한 키를 생성하는 가장 쉬운 방법은 php artisan key:generate --show 명령어를 사용하는 것입니다.
# php artisan --no-ansi key:generate --show
base64:GZ4rIBZ0MGKFvQro67ytUV4jYb7YheswHn/v0BCjQ5A=
출력 결과를 복사하여 아래와 같이 입력 후 실행합니다.
# heroku config:set APP_KEY=GZ4rIBZ0MGKFvQro67ytUV4jYb7YheswHn/v0BCjQ5A=
마지막으로, Heroku 애플리케이션에 Push 합니다.
# git push heroku main
heroku open 명령을 이용하여 페이지를 확인하거나, 출력된 URL 주소로 접근해보면 Laravel 프로젝트 초기화면이 출력됩니다.
> https://php3-2f101eb6942b.herokuapp.com/
'리눅스 > PaaS' 카테고리의 다른 글
AWS Elastic Beanstalk 으로 PHP 소스 배포하기 (Console / CLI) (0) | 2023.12.26 |
---|---|
CloudFoundry Paketo-buildpacks 버전 관리 (빌드팩 내 버전 선택, 구버전 사용, 버전 고정 방법) (0) | 2023.12.08 |
CF (Cloud Foundry) Paketo Buildpack 의 개발언어 제공 버전 확인하기 (0) | 2023.11.21 |
Ubuntu 22.04 Kind Cluster 에서 Korifi 설치하기 (스크립트를 이용한 간단 설치) (0) | 2023.11.02 |
Kubernetes 1.28, Kind 에서 Korifi 설치 및 PHP 애플리케이션 배포하기 (0) | 2023.10.24 |