首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Docker部署laravel项目时出现mysql错误

使用Docker部署laravel项目时出现mysql错误
EN

Stack Overflow用户
提问于 2017-01-09 18:56:29
回答 1查看 1.2K关注 0票数 1

我想用与远程服务器相同的环境来测试我的laravel项目。所以我试着使用Docker (以前从来不知道)。我安装了docker,并按照项目中的说明将其部署到docker。设置

将文件.env.example复制到.env,将docker-compose.yml.example复制到docker-compose.yml

修改.env配置文件(可选)。如果您在.env文件中修改mysql、mongo、redis配置,请记住也要修改docker-compose.yml文件中的配置。安装或运行Docker

代码语言:javascript
复制
docker-compose up -d

//停止

代码语言:javascript
复制
docker-compose stop

chmod缓存文件夹

代码语言:javascript
复制
chmod -R 777 storage

chmod -R 777 bootstrap/cache

部署

代码语言:javascript
复制
sh deploy.sh

在运行sh doploy.sh之后,我得到了这个错误:

代码语言:javascript
复制
   [Illuminate\Database\QueryException]                                                              
  SQLSTATE[HY000] [2002] No such file or directory (SQL: select * from information_schema.tables where table_schema = awesome_teacher and table_name = migrations)
 [Doctrine\DBAL\Driver\PDOException]               
  SQLSTATE[HY000] [2002] No such file or directory  

  [PDOException]                                    
  SQLSTATE[HY000] [2002] No such file or directory  

  [Illuminate\Database\QueryException]                                                              
  SQLSTATE[HY000] [2002] No such file or directory (SQL: select * from information_schema.tables w  
  here table_schema = homestead_test and table_name = migrations)                                                               
  [Doctrine\DBAL\Driver\PDOException]               
  SQLSTATE[HY000] [2002] No such file or directory
[PDOException]                                    
    SQLSTATE[HY000] [2002] No such file or directory  

docker-compose.yml文件:

代码语言:javascript
复制
version: '2'

### Change the `teacher` with your own teacher name ###
services:
    application:
        container_name: teacher_application
        image: debian
        volumes:
            - ./:/var/www/laravel
    workspace:
        container_name: teacher_workspace
        restart: always
        image: my_company/laravel-workspace
        volumes_from:
            - application
        tty: true
    php-fpm:
        container_name: teacher_php-fpm
        restart: always
        image: my_company/laravel-php-fpm
        volumes_from:
            - application
        expose:
            - "9000"
        links:
            - workspace
    nginx:
        container_name: teacher_nginx
        restart: always
        image: my_company/laravel-nginx
        volumes_from:
            - data
            - logs
            - application
        ports:
            - "8000:80"
        links:
            - php-fpm
    data:
        container_name: teacher_data
        image: debian
        volumes:
            - .docker/mysql:/var/lib/mysql
            - .docker/data:/data
    data_test:
        container_name: teacher_data_test
        image: debian
        volumes:
            - .docker/mysql_test:/var/lib/mysql
            - .docker/data_test:/data
    logs:
        container_name: teacher_logs
        image: debian
        volumes:
            - .docker/logs/nginx:/var/log/nginx
            - .docker/logs/mongodb:/var/log/mongodb
    mysql:
        container_name: teacher_mysql
        restart: always
        image: mysql
        volumes_from:
            - data
            - logs
        expose:
            - "3306"
        environment:
            MYSQL_DATABASE: awesome_teacher
            MYSQL_USER: root
            MYSQL_PASSWORD: blablabla
            MYSQL_ROOT_PASSWORD: blablabla
    mysql_test:
        container_name: teacher_mysql_test
        restart: always
        image: mysql
        volumes_from:
            - data_test
        expose:
            - "3306"
        environment:
            MYSQL_DATABASE: homestead_test
            MYSQL_USER: homestead_test
            MYSQL_PASSWORD: secret
            MYSQL_ROOT_PASSWORD: root

.env文件:

代码语言:javascript
复制
APP_ENV=local
APP_KEY=base64:hl4qkfCdHiJrCG4sGfYfMU8faq3WywMHkH+mr/FiDu9PM=
APP_DEBUG=true
APP_LOG_LEVEL=debug
APP_URL=awesome-teacher.local
APP_DOMAIN='awesome-teacher.local'


DB_CONNECTION=mysql
DB_HOST=localhost
DB_PORT=3306
DB_DATABASE=awesome_teacher
DB_USERNAME=root
DB_PASSWORD=blablabla

DB_TEST_CONNECTION=mysql_test
DB_TEST_HOST=localhost
DB_TEST_PORT=3308
DB_TEST_DATABASE=homestead_test
DB_TEST_USERNAME=homestead_test
DB_TEST_PASSWORD=secret

BROADCAST_DRIVER=log
CACHE_DRIVER=file
SESSION_DRIVER=file
QUEUE_DRIVER=sync

PUSHER_APP_ID=
PUSHER_KEY=
PUSHER_SECRET=
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-01-09 19:18:19

对于一个简单的laravel应用程序,您有一个相当复杂的设置。问题是您的laravel应用程序试图连接到它自己容器中的MySQL服务器实例。

DB_HOST=localhost更改为DB_HOST=mysql以连接到mysql容器。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41546422

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档