"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Docker를 사용하여 몇 초 만에 새로운 Laravel 프로젝트를 생성해보세요!

Docker를 사용하여 몇 초 만에 새로운 Laravel 프로젝트를 생성해보세요!

2024-11-04에 게시됨
검색:633

Docker를 사용하면 새 프로젝트를 훨씬 쉽게 시작할 수 있으므로 작업에 필요한 개별 도구를 설정하는 데 드는 시간이 절약됩니다. 라라벨도 예외는 아닙니다. MySQL 데이터베이스가 포함된 Docker를 사용하여 새로운 Laravel 프로젝트를 설정하는 방법은 다음과 같습니다.

1단계: 새 프로젝트 디렉터리 만들기

먼저, Laravel 프로젝트를 수용할 새로운 빈 디렉토리를 설정하겠습니다. myApp이라고 부르거나 원하는 이름으로 부르세요.

mkdir myApp
cd myApp

2단계: Docker Compose 파일 만들기

다음으로 두 개의 컨테이너를 정의하겠습니다.

  • 필요한 모든 PHP 코드를 포함하는 Laravel 프로젝트용 하나입니다.

  • MySQL 데이터베이스용 하나입니다. MariaDB를 사용하려면 이미지: mysql:8.0을 이미지: mariadb.
    로 바꾸세요.

services:
  web:
    image: bitnami/laravel
    volumes:
      - ./app:/app
    working_dir: /app
    environment:
      - LARAVEL_DATABASE_HOST=db
      - LARAVEL_DATABASE_USER=root
      - LARAVEL_DATABASE_NAME=laravel
      - LARAVEL_DATABASE_PASSWORD=pass1
      - LARAVEL_DATABASE_PORT_NUMBER=3306
    restart: always
    ports:
      - 8000:8000

  db:
    image: mysql:8.0
    environment:
      - MYSQL_ROOT_PASSWORD=pass1
      - MYSQL_DATABASE=laravel

여기서 무슨 일이 일어나고 있나요?

Docker Compose는 동시에 여러 구성 요소를 빌드하는 데 도움이 되는 Docker의 도구입니다. 데이터베이스처럼 움직이는 부분이 여러 개인 프로젝트를 실행하는 경우 정말 유용합니다.

이 경우 web은 Laravel 프로젝트이고 db는 데이터베이스입니다. 웹 컨테이너는 Laravel이 사전 설치된 편리한 이미지인 기본 이미지인 bitnami/laravel에서 생성됩니다. 앱 폴더를 컨테이너에 "볼륨"으로 추가하여 앱을 실행할 수 있습니다. 파일은 컨테이너에 연결할 수 있도록 데이터베이스 자격 증명을 제공하고, 브라우저로 사이트를 열 수 있도록 포트 8080도 공개합니다!

db 컨테이너는 MySQL이 설치된 간단한 컨테이너입니다. 파일은 루트 사용자의 비밀번호와 데이터베이스를 생성할 수 있는 데이터베이스 이름을 제공합니다.

그렇습니다!

 3단계: 컨테이너 실행

이제 docker-compose.yml 파일이 준비되었으므로 Docker에게 간단한 명령을 사용하여 두 컨테이너를 모두 생성할 수 있는 권한을 부여할 수 있습니다.

docker compose up

4단계: 사이트 확인

몇 초만 기다리면 사이트가 실행될 것입니다. 터미널에 다음 줄이 표시되어야 합니다.

INFO  Server running on [http://0.0.0.0:8000].

열려면 브라우저에서 http://localhost:8000을 엽니다.

성공!

Create a new Laravel project in seconds using Docker!

새로운 Laravel 사이트를 즐겨보세요!

릴리스 선언문 이 기사는 https://dev.to/savvasstephnds/create-a-new-laravel-project-in-seconds-using-docker-n9c?1에서 복제됩니다. 침해가 있는 경우, [email protected]에 문의하십시오. 그것을 삭제하려면
최신 튜토리얼 더>
  • Node.js에서 `setImmediate`와 `process.nextTick`을 언제 사용해야 합니까?
    Node.js에서 `setImmediate`와 `process.nextTick`을 언제 사용해야 합니까?
    setImmediate와 nextTick의 차이점 이해Node.js 버전 0.10에서는 process.nextTick을 보완하기 위한 새로운 API인 setImmediate를 도입했습니다. 두 함수 모두 콜백을 비동기적으로 실행하는 수단을 제공하지만 사용법을 관리하는 ...
    프로그램 작성 2024-11-05에 게시됨
  • jQuery에서 숨겨진 요소의 높이를 효율적으로 얻는 방법은 무엇입니까?
    jQuery에서 숨겨진 요소의 높이를 효율적으로 얻는 방법은 무엇입니까?
    jQuery에서 숨겨진 요소의 높이 가져오기숨겨진 요소를 처리할 때 높이를 검색하는 것이 어려울 수 있습니다. 높이를 측정하기 위해 요소를 일시적으로 표시한 후 다시 숨기는 기존 방식은 비효율적입니다. 더 최적의 솔루션이 있나요?jQuery 1.4.2 접근 방식다음은 ...
    프로그램 작성 2024-11-05에 게시됨
  • Go 구조체 태그에 변수를 사용할 수 없는 이유는 무엇입니까?
    Go 구조체 태그에 변수를 사용할 수 없는 이유는 무엇입니까?
    Go 구조체 태그에서 변수 사용Go에서 구조체 태그는 구조체 내의 필드에 대한 메타데이터를 지정하는 데 사용됩니다. 문자열 리터럴을 사용하여 태그를 정의하는 것이 가능하지만 해당 위치에 변수를 사용하려고 하면 오류가 발생합니다.잘못된 사용:const ( TYPE...
    프로그램 작성 2024-11-05에 게시됨
  • Qopy: 개발자로서 제가 가장 좋아하는 클립보드 관리자
    Qopy: 개발자로서 제가 가장 좋아하는 클립보드 관리자
    개발자로서 저는 항상 작업 흐름을 더 원활하고 효율적으로 만들 수 있는 도구를 찾고 있습니다. 최근에 저는 Linux와 Windows에서 작동하는 오픈 소스 클립보드 관리자인 Qopy를 우연히 발견했습니다. 큐피(Qopy)는 무엇인가요? Qopy는 표준 ...
    프로그램 작성 2024-11-05에 게시됨
  • 내 버튼에 호버 효과가 작동하지 않는 이유는 무엇입니까?
    내 버튼에 호버 효과가 작동하지 않는 이유는 무엇입니까?
    호버 시 버튼 색상 변경: 대체 해결 방법호버 시 버튼 색상을 변경하려고 할 때 다음과 같은 경우 실망스러울 수 있습니다. 솔루션이 원하는 효과를 내지 못합니다. 제공된 샘플 코드를 고려하십시오.a.button { ... } a.button a:hover{ ...
    프로그램 작성 2024-11-05에 게시됨
  • Python만 사용하여 프런트엔드 구축
    Python만 사용하여 프런트엔드 구축
    프런트엔드 개발은 백엔드에 초점을 맞춘 개발자에게 벅차고 심지어 악몽 같은 작업이 될 수 있습니다. 내 경력 초기에는 프런트엔드와 백엔드 사이의 경계가 모호했고 모두가 두 가지를 모두 처리해야 했습니다. 특히 CSS는 끊임없는 투쟁이었습니다. 불가능한 임무처럼 느껴졌습...
    프로그램 작성 2024-11-05에 게시됨
  • Laravel에서 Cron 작업을 실행하는 방법
    Laravel에서 Cron 작업을 실행하는 방법
    이 튜토리얼에서는 Laravel에서 크론 작업을 실행하는 방법을 보여드리겠습니다. 무엇보다도 학생들을 위해 간단하고 쉽게 작업을 수행할 수 있습니다. Laravel 앱을 구축하는 동안 여러분의 컴퓨터에서 바로 이러한 자동화된 작업을 설정하고 실행하는 방법을 살펴보겠습니...
    프로그램 작성 2024-11-05에 게시됨
  • 패딩은 인라인 요소의 간격에 어떤 영향을 미치며 충돌을 어떻게 해결할 수 있습니까?
    패딩은 인라인 요소의 간격에 어떤 영향을 미치며 충돌을 어떻게 해결할 수 있습니까?
    인라인 요소의 패딩: 효과 및 제한소스에 따르면 인라인 요소의 상단과 하단에 패딩을 추가해도 영향을 미치지 않습니다. 주변 요소의 간격. 그러나 "패딩은 다른 인라인 요소와 겹칩니다"라는 설명은 패딩이 영향을 미치는 특정 상황이 있을 수 있음을 나타냅...
    프로그램 작성 2024-11-05에 게시됨
  • Django 클래스 기반 뷰가 쉬워졌습니다.
    Django 클래스 기반 뷰가 쉬워졌습니다.
    우리 모두 알고 있듯이 django는 웹 애플리케이션 개발 디자인에 MVT(모델-뷰-템플릿)를 사용합니다. 뷰 자체는 요청을 받고 응답을 반환하는 호출 가능 항목입니다. Django는 클래스 기반 뷰라는 것을 제공하므로 개발자는 클래스 기반 접근 방식을 사용하거나 O...
    프로그램 작성 2024-11-05에 게시됨
  • VAKX로 노코드 AI 에이전트 구축
    VAKX로 노코드 AI 에이전트 구축
    If you’ve been keeping up with the AI space, you already know that AI agents are becoming a game-changer in the world of automation and customer inter...
    프로그램 작성 2024-11-05에 게시됨
  • jQuery Datatable에서 커서 기반 페이지 매김을 구현하는 방법은 다음과 같습니다.
    jQuery Datatable에서 커서 기반 페이지 매김을 구현하는 방법은 다음과 같습니다.
    웹 애플리케이션에서 대규모 데이터세트로 작업할 때 페이지 매김은 성능과 사용자 경험에 매우 중요합니다. 데이터 테이블에 일반적으로 사용되는 표준 오프셋 기반 페이지 매김은 대규모 데이터 세트에는 비효율적일 수 있습니다. 커서 기반 페이지 매김은 특히 실시간 업데이트나...
    프로그램 작성 2024-11-05에 게시됨
  • 동기화 엔진이 웹 애플리케이션의 미래가 될 수 있는 이유
    동기화 엔진이 웹 애플리케이션의 미래가 될 수 있는 이유
    진화하는 웹 애플리케이션 세계에서는 효율성, 확장성, 원활한 실시간 경험이 무엇보다 중요합니다. 전통적인 웹 아키텍처는 응답성 및 동기화에 대한 현대적인 요구로 인해 어려움을 겪을 수 있는 클라이언트-서버 모델에 크게 의존합니다. 이것이 동기화 엔진이 등장하여 오늘날 ...
    프로그램 작성 2024-11-05에 게시됨
  • Python을 사용한 컴퓨터 비전 소개(1부)
    Python을 사용한 컴퓨터 비전 소개(1부)
    참고: 이 게시물에서는 쉽게 따라할 수 있도록 회색조 이미지만 사용합니다. 이미지란 무엇입니까? 이미지는 값의 행렬로 생각할 수 있으며, 각 값은 픽셀의 강도를 나타냅니다. 이미지 형식에는 세 가지 주요 유형이 있습니다. 이진: 이 형식의 이미지는 값이 ...
    프로그램 작성 2024-11-05에 게시됨
  • 웹사이트용 HTML 코드
    웹사이트용 HTML 코드
    항공 관련 웹사이트를 구축하려고 노력해왔습니다. 저는 AI를 사용하여 코드를 생성하는 전체 웹사이트를 생성할 수 있는지 확인하고 싶었습니다. HTML 웹사이트가 블로그와 호환됩니까, 아니면 자바스크립트를 사용해야 합니까? 데모로 사용한 코드는 다음과 같습니다. <...
    프로그램 작성 2024-11-05에 게시됨
  • 프로그래머처럼 생각하기: Java의 기본 사항 배우기
    프로그래머처럼 생각하기: Java의 기본 사항 배우기
    이 글에서는 자바 프로그래밍의 기본 개념과 구조를 소개합니다. 변수와 데이터 유형에 대한 소개로 시작한 다음 연산자와 표현식은 물론 제어 흐름 프로세스에 대해 논의합니다. 둘째, 메서드와 클래스를 설명하고 입력 및 출력 작업을 소개합니다. 마지막으로 이 기사에서는 급여...
    프로그램 작성 2024-11-05에 게시됨

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3