РЕШЕНО: Не удается установить стек Yii2 + Vagrant + PHP-FPM + Nginx + Mongo

Различные вопросы по установке и настройке фреймворка, конфигурции веб-сервера и IDE.
Ответить
Аватара пользователя
theorist
Сообщения: 70
Зарегистрирован: 2012.12.24, 00:30
Откуда: Киев

РЕШЕНО: Не удается установить стек Yii2 + Vagrant + PHP-FPM + Nginx + Mongo

Сообщение theorist »

Использую Vagrant + puPHPet для конфигурации.
Ниже приложу config.yaml, который Пуппет на выходе генерит.

Проблема №1 - после vagrant up захожу на хост и вижу 502 ошибку (бэд, мать его, гейтвей). Логи говорят, что нельзя прослушать php-fpm на 9000 порту.

Проблема №2 - в консоли попытка запуска php5-fpm говорит, что не может загрузить либу mongodb.so
service php5-fpm start запускает сервис, но тот моментально отваливается.

Не знаю, может тут есть добрые самаритяне, которым не жалко 5 минут времени и на основе данных моего файла составить правильный конфиг. Что уже только не пробовал с версиями, настройками. В какие только .INI не писал extension=mongo.so - все напрасно. Примерно 40 переустановок за несколько недель, но ошибки примерно одни и те же.

Как не стараюсь - не устанавливается у меня либа для Монго. Это основная проблема. Руками иногда удавалось после установки по 100500 мануалам из сети добиться нужного результата, но ведь Вагрант не для того, чтобы поставить окружение и руками потом еще кучу всего конфижить и доустанавливать. На puPHPet либу для Монго устанавливаю с помощью PECL Modules (пробовал и mongo, и mongodb).

Код: Выделить всё

vagrantfile:
    target: local
    vm:
        provider:
            local:
                box: puphpet/ubuntu1404-x64
                box_url: puphpet/ubuntu1404-x64
                box_version: '0'
                chosen_virtualizer: virtualbox
                virtualizers:
                    virtualbox:
                        modifyvm:
                            natdnshostresolver1: false
                        showgui: 0
                    vmware:
                        numvcpus: 1
                    parallels:
                        use_linked_clone: 0
                        check_guest_tools: 0
                        update_guest_tools: 0
                machines:
                    vflm_zhrhe5mx68fd:
                        id: lottery
                        hostname: lottery.puphpet
                        network:
                            private_network: 192.168.56.101
                        memory: '512'
                        cpus: '1'
        provision:
            puppet:
                manifests_path: puphpet/puppet/manifests
                module_path: puphpet/puppet/modules
                options:
                    - '--verbose'
                    - '--hiera_config /vagrant/puphpet/puppet/hiera.yaml'
        synced_folder:
            vflsf_3jq64tjo0viv:
                source: ./
                target: /var/www/lottery
                sync_type: default
                smb:
                    smb_host: ''
                    smb_username: ''
                    smb_password: ''
                    mount_options:
                        dir_mode: '0775'
                        file_mode: '0664'
                rsync:
                    args:
                        - '--verbose'
                        - '--archive'
                        - '-z'
                    exclude:
                        - .vagrant/
                        - .git/
                    auto: 'true'
                owner: www-data
                group: www-data
        usable_port_range:
            start: 10200
            stop: 10500
        post_up_message: ''
    ssh:
        host: 'false'
        port: 'false'
        private_key_path: 'false'
        username: vagrant
        guest_port: 'false'
        keep_alive: '1'
        forward_agent: 'false'
        forward_x11: 'false'
        shell: 'bash -l'
        insert_key: 'false'
    vagrant:
        host: detect
    proxy:
        http: ''
        https: ''
        ftp: ''
        no_proxy: ''
server:
    install: '1'
    packages:
        - vim
        - htop
        - git
users_groups:
    install: '1'
    groups: {  }
    users: {  }
locale:
    install: '1'
    settings:
        default_locale: en_US.UTF-8
        locales:
            - en_US.UTF-8
            - ru_RU.UTF-8
        timezone: Europe/Kiev
firewall:
    install: '1'
    rules: {  }
cron:
    install: '1'
    jobs: {  }
nginx:
    install: '1'
    settings:
        default_vhost: 1
        proxy_buffer_size: 128k
        proxy_buffers: '4 256k'
        proxy_connect_timeout: 600s
        proxy_send_timeout: 600s
        proxy_read_timeout: 600s
        names_hash_bucket_size: 128
    upstreams: {  }
    vhosts:
        nxv_im92y7l75g0g:
            server_name: lottery.dev
            server_aliases:
                - www.lottery.dev
            www_root: /var/www/lottery/web
            listen_port: '80'
            index_files:
                - index.html
                - index.htm
                - index.php
            client_max_body_size: 1m
            ssl: '0'
            ssl_cert: ''
            ssl_key: ''
            ssl_port: '443'
            ssl_protocols: ''
            ssl_ciphers: ''
            rewrite_to_https: '1'
            spdy: '1'
            locations:
                nxvl_ecpos4jv0q76:
                    location: /
                    try_files:
                        - $uri
                        - $uri/
                        - /index.php$is_args$args
                    fastcgi: ''
                    fastcgi_index: ''
                    fastcgi_split_path: ''
                    proxy: ''
                    proxy_redirect: ''
                nxvl_6xk6iib8ct2v:
                    location: '~ \.php$'
                    try_files:
                        - $uri
                        - $uri/
                        - /index.php$is_args$args
                    fastcgi: '127.0.0.1:9000'
                    fastcgi_index: index.php
                    fastcgi_split_path: '^(.+\.php)(/.*)$'
                    fast_cgi_params_extra:
                        - 'SCRIPT_FILENAME $request_filename'
                        - 'APP_ENV dev'
                    set:
                        - '$path_info $fastcgi_path_info'
                    proxy: ''
                    proxy_redirect: ''
    proxies: {  }
apache:
    install: '0'
    settings:
        version: 2.4
        user: www-data
        group: www-data
        default_vhost: true
        manage_user: false
        manage_group: false
        sendfile: 0
    modules:
        - proxy_fcgi
        - rewrite
    vhosts:
        av_w76nk5b14lvk:
            servername: awesome.dev
            serveraliases:
                - www.awesome.dev
            docroot: /var/www/awesome
            port: '80'
            setenv:
                - 'APP_ENV dev'
            setenvif:
                - 'Authorization "(.*)" HTTP_AUTHORIZATION=$1'
            custom_fragment: ''
            ssl: '0'
            ssl_cert: ''
            ssl_key: ''
            ssl_chain: ''
            ssl_certs_dir: ''
            ssl_protocol: ''
            ssl_cipher: ''
            directories:
                avd_jgin89c5ll8g:
                    path: /var/www/awesome
                    options:
                        - Indexes
                        - FollowSymlinks
                        - MultiViews
                    allow_override:
                        - All
                    require:
                        - 'all granted'
                    custom_fragment: ''
                    files_match:
                        avdfm_mv5b3za8inov:
                            path: \.php$
                            sethandler: 'proxy:fcgi://127.0.0.1:9000'
                            custom_fragment: ''
                            provider: filesmatch
                    provider: directory
letsencrypt:
    install: '1'
    settings:
        email: ''
    domains: {  }
php:
    install: '1'
    settings:
        version: '55'
    modules:
        php:
            - cli
            - intl
            - dev
            - fpm
            - cgi
            - common
            - curl
            - gd
            - mcrypt
            - mbstring
        pear: {  }
        pecl:
            - mongodb
    ini:
        display_errors: 'On'
        error_reporting: '-1'
        session.save_path: /var/lib/php/session
        date.timezone: UTC
    fpm_ini:
        error_log: /var/log/php-fpm.log
        include: '/etc/php5/fpm/*.conf'
    fpm_pools:
        phpfp_kd8pvomhy2bz:
            ini:
                prefix: www
                listen: '127.0.0.1:9000'
                security.limit_extensions: .php
                user: www-user
                group: www-data
    composer: '1'
    composer_home: ''
xdebug:
    install: '0'
    settings:
        xdebug.default_enable: '1'
        xdebug.remote_autostart: '0'
        xdebug.remote_connect_back: '1'
        xdebug.remote_enable: '1'
        xdebug.remote_handler: dbgp
        xdebug.remote_port: '9000'
blackfire:
    install: '0'
    settings:
        server_id: ''
        server_token: ''
        agent:
            http_proxy: ''
            https_proxy: ''
            log_file: stderr
            log_level: '1'
        php:
            agent_timeout: '0.25'
            log_file: ''
            log_level: '1'
xhprof:
    install: '0'
wpcli:
    install: '0'
    version: v0.21.1
drush:
    install: '0'
    version: 8.0.5
ruby:
    install: '1'
    versions:
        rv_vpdlkm2rzknd:
            default: '1'
            bundler: '1'
            version: 1.9.3
            gems:
                - deep_merge
                - activesupport
                - vine
python:
    install: '1'
    packages: {  }
    versions: {  }
nodejs:
    install: '0'
    settings:
        version: '5'
    npm_packages: {  }
hhvm:
    install: '0'
    nightly: 0
    composer: '1'
    composer_home: ''
    settings: {  }
    server_ini:
        hhvm.server.host: 127.0.0.1
        hhvm.server.port: '9000'
        hhvm.log.use_log_file: '1'
        hhvm.log.file: /var/log/hhvm/error.log
    php_ini:
        display_errors: 'On'
        error_reporting: '-1'
        date.timezone: UTC
mariadb:
    install: '1'
    settings:
        version: '10.1'
        root_password: some_root_password
        override_options: {  }
    adminer: 0
    users:
        mariadbnu_93t0p409stwi:
            name: lottery
            password: some_password
    databases:
        mariadbnd_vzs3jfi3jb2s:
            name: lottery
            sql: ''
    grants:
        mariadbng_fszbyxrvfwk8:
            user: lottery
            table: 'lottery.*'
            privileges:
                - ALL
mysql:
    install: '0'
    settings:
        version: '5.6'
        root_password: '123'
        override_options: {  }
    adminer: 0
    users:
        mysqlnu_1i7bz15vwabo:
            name: dbuser
            password: '123'
    databases:
        mysqlnd_j32bl5tqm1kn:
            name: dbname
            sql: ''
    grants:
        mysqlng_57e74jp8mege:
            user: dbuser
            table: '*.*'
            privileges:
                - ALL
postgresql:
    install: '0'
    settings:
        global:
            encoding: UTF8
            version: '9.4'
        server:
            postgres_password: '123'
    databases: {  }
    users: {  }
    grants: {  }
    adminer: 0
mongodb:
    install: '1'
    settings:
        bind_ip: 127.0.0.1
        port: '27017'
    globals:
        version: 2.6.0
    databases: {  }
redis:
    install: '1'
    settings:
        port: '6379'
sqlite:
    install: '0'
    adminer: 0
    databases: {  }
mailhog:
    install: '0'
    settings:
        smtp_ip: 0.0.0.0
        smtp_port: 1025
        http_ip: 0.0.0.0
        http_port: '8025'
        path: /usr/local/bin/mailhog
beanstalkd:
    install: '0'
    settings:
        listenaddress: 0.0.0.0
        listenport: '11300'
        maxjobsize: '65535'
        maxconnections: '1024'
        binlogdir: /var/lib/beanstalkd/binlog
        binlogfsync: null
        binlogsize: '10485760'
    beanstalk_console: 0
rabbitmq:
    install: '0'
    settings:
        port: '5672'
    users: {  }
    vhosts: {  }
    plugins: {  }
elastic_search:
    install: '0'
    settings:
        version: 2.3.1
        java_install: true
    instances:
        esi_kg7z16spw9d9:
            name: es-01
solr:
    install: '0'
    settings:
        version: 4.10.2
        port: '8984'
Последний раз редактировалось theorist 2016.05.12, 16:44, всего редактировалось 1 раз.
zelenin
Сообщения: 10596
Зарегистрирован: 2013.04.20, 11:30

Re: Не удается установить стек Yii2 + Vagrant + PHP-FPM + Nginx + Mongo

Сообщение zelenin »

юзай докер. вагрант - легаси
Аватара пользователя
theorist
Сообщения: 70
Зарегистрирован: 2012.12.24, 00:30
Откуда: Киев

Re: Не удается установить стек Yii2 + Vagrant + PHP-FPM + Nginx + Mongo

Сообщение theorist »

Разобрался.
Мало ли, вдруг кому понадобится (потому что именно с Монгой такая лажа, все остальное четко и ровно ставилось всегда).

На puPHPet в модули PHP дописать mongo, это создаст в conf.d файл mongo.ini, который автоматом инклюдится к основному .ini-файлу, с содержимым "extension=mongo.so". mongodb.so и PHP 5.5 почему-то не пашет с официальной Yii2-либой для Монги.
Ответить