簡體   English   中英

Doctrine無法使用Mamp連接到Symfony2中的數據庫

[英]Doctrine cannot connect to database in Symfony2 using Mamp

我正在嘗試通過學說創建數據庫。

php app/console doctrine:database:create

當我運行上述命令時,出現以下錯誤:

[Doctrine\DBAL\Exception\ConnectionException]                              
An exception occured in driver: SQLSTATE[HY000] [2002] Connection refused  



[Doctrine\DBAL\Driver\PDOException]        
SQLSTATE[HY000] [2002] Connection refused  



[PDOException]                             
SQLSTATE[HY000] [2002] Connection refused

我嘗試過的

這種符號鏈接的創建對我不起作用。

sudo ln -s /Applications/MAMP/tmp/mysql/mysql.sock mysql.sock

我已經嘗試了database_host: localhostdatabase_host: 127.0.0.1沒什么變化。

我知道在MAMP上可以看到我的MySQL端口是8889

由於我沒有MAMP Pro,因此無法在MAMP的MySQL選項卡下選中允許網絡訪問 MySQL選項

這是我的配置文件

配置文件

imports:
    - { resource: parameters.yml }
    - { resource: security.yml }
    - { resource: services.yml }
    - { resource: "@FatihTestBundle/Resources/config/services.yml" }

# Put parameters here that don't need to change on each machine where the app is deployed
# http://symfony.com/doc/current/best_practices/configuration.html#application-related-configuration
parameters:
    locale: en

framework:
    #esi:             ~
    #translator:      { fallbacks: ["%locale%"] }
    secret:          "%secret%"
    router:
        resource: "%kernel.root_dir%/config/routing.yml"
        strict_requirements: ~
    form:            ~
    csrf_protection: ~
    validation:      { enable_annotations: true }
    #serializer:      { enable_annotations: true }
    templating:
        engines: ['twig']
    default_locale:  "%locale%"
    trusted_hosts:   ~
    trusted_proxies: ~
    session:
        # handler_id set to null will use default session handler from php.ini
        handler_id:  ~
    fragments:       ~
    http_method_override: true

# Twig Configuration
twig:
    debug:            "%kernel.debug%"
    strict_variables: "%kernel.debug%"
    cache: false

# Doctrine Configuration
doctrine:
    dbal:
        driver:   pdo_mysql
        host:     "%database_host%"
        port:     "%database_port%"
        dbname:   "%database_name%"
        user:     "%database_user%"
        password: "%database_password%"
        charset:  UTF8
        # if using pdo_sqlite as your database driver:
        #   1. add the path in parameters.yml
        #     e.g. database_path: "%kernel.root_dir%/data/data.db3"
        #   2. Uncomment database_path in parameters.yml.dist
        #   3. Uncomment next line:
        #     path:     "%database_path%"

    orm:
        auto_generate_proxy_classes: "%kernel.debug%"
        naming_strategy: doctrine.orm.naming_strategy.underscore
        auto_mapping: true

# Swiftmailer Configuration
swiftmailer:
    transport: "%mailer_transport%"
    host:      "%mailer_host%"
    username:  "%mailer_user%"
    password:  "%mailer_password%"
    spool:     { type: memory }

parameters.yml:

# This file is auto-generated during the composer install
parameters:
    database_host: localhost
    database_port: 8889
    database_name: todo
    database_user: root
    database_password: root
    mailer_transport: smtp
    mailer_host: 127.0.0.1
    mailer_user: null
    mailer_password: null
    secret: fgnfgmngfm
php app/console cache:clear

問題是由於緩存,無論我做什么都收到錯誤消息。 上面的命令清除了緩存,並將MAMPparamteters.yml中的數據庫端口更改為3306,已解決了該問題。

檢查您的DNS設置。 如果您不使用VPN,請將其關閉。

您可以使用“ Sequel PRO”測試連接

主機名:本地主機-127.0.0.1-IP地址

密碼:1234-root

如果他們不能解決問題,請檢查用戶權限。 在此處輸入圖片說明

mysql數據庫->用戶表

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM