BrowserSync无法打开浏览器LaravelMixDocker,无法访问本地主机

如何解决BrowserSync无法打开浏览器LaravelMixDocker,无法访问本地主机

目标
我想用docker为一个PHP项目设置一个开发环境,其中包括一个引导程序主题以及一些JS和CSS文件。 目的是,我可以运行npm run watch,并可以在浏览器中打开具有实时重新加载功能的窗口。当我编辑并保存JS,SCSS或PHP文件时,浏览器应重新加载页面。 到目前为止,从src/assets/public/assets的JS文件和SCSS的复制和捆绑(到CSS)工作正常。

问题描述

问题是,无法通过浏览器访问browsersync服务的页面。当我在docker容器中运行npm run watch时,出现以下消息:
Couldn't open browser (if you are using BrowserSync in a headless environment,you might want to set the open option to false)
当我打开http://localhost:3000时,什么都没有发生。
我对docker的态度不是很坚定,所以问题可能出在这里,但我不知道。

我在Stackoverflow上找到了这些站点,但是它们没有帮助,或者我只是没有得到它。 Link1 Link2 Link3 Link4
我也毫不费力地阅读了一些Github问题。例如: Github1 Github2

我使用了这些教程来为一个简单的PHP项目设置LaravelMix:
https://dev.to/ms314006/how-to-package-front-end-projects-into-docker-images-and-use-it-with-webpack-go3

https://medium.com/qunabu-interactive/drupal-8-docker-composer-bootstrap-laravel-mix-boilerplate-ci-on-gitlab-754b1ccdf3ec

https://www.sitepoint.com/use-laravel-mix-non-laravel-projects/

我认为以下文件有助于了解我的方法:

package.json

{
  "name": "Dinjnection","version": "0.0.1","description": "","scripts": {
    "dev": "node node_modules/cross-env/src/bin/cross-env.js NODE_ENV=development node_modules/webpack/bin/webpack.js --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js","watch": "node node_modules/cross-env/src/bin/cross-env.js NODE_ENV=development node_modules/webpack/bin/webpack.js --watch --host 0.0.0.0 --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js","hot": "node node_modules/cross-env/src/bin/cross-env.js NODE_ENV=development node_modules/webpack-dev-server/bin/webpack-dev-server.js --inline --hot --config=node_modules/laravel-mix/setup/webpack.config.js","production": "node node_modules/cross-env/src/bin/cross-env.js NODE_ENV=production node_modules/webpack/bin/webpack.js --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js"
  },"main": "app.js","author": "","license": "","dependencies": {
  },"devDependencies": {
    "cross-env": "^7.0.2","laravel-mix": "^5.0.5","node-sass": "^4.5.0","browser-sync": "^2.26.12","browser-sync-webpack-plugin": "^2.2.2","resolve-url-loader": "^3.1.1","sass-loader": "^8.0.2","vue-template-compiler": "^2.6.12"
  }
}

webpack.mix.js

const mix = require('laravel-mix');

mix.setPublicPath('public').js('src/Assets/js/app.js','public/js')
    .sass('src/Assets/sass/app.scss','public/css').version().browserSync(
    {
        proxy: 'localhost:8000',host: 'dinjection.test',// => true = the browse opens a new browser window with every npm run watch startup/reload

        files: [
            "src/Assets/*"
        ],open: true,notify: true,ui: false
    }
);

docker-composer.yaml

version: '3'
services:
    nginx:
        container_name: dinjection_dev_nginx
        build: nginx
        ports:
            - "80:80"
            - "443:443"
        volumes:
            - ./..:/var/www/dinjection.test/current
            - ./nginx/nginx.conf:/etc/nginx/nginx.conf
            - ./nginx/sites/:/etc/nginx/sites-available
            - ./nginx/conf.d/:/etc/nginx/conf.d
        networks:
            - dinjection_net

    php:
        container_name: dinjection_dev_php
        build: php
        ports:
            - "3000:3000"
            - "8000:8000"
        volumes:
            - ./..:/var/www/dinjection.test/current
            - "/etc/timezone:/etc/timezone:ro"
            - "/etc/localtime:/etc/localtime:ro"
            - dinjection-volume-session-share:/tmp
        environment:
            APP_ENVIRONMENT: "dev"
            DB_HOST: "localhost"
            DB_PORT: "3306"
            DB_USER: "${DEFAULT_USER}"
            DB_PASSWORD: "${DEFAULT_PASSWORD}"
        networks:
            - dinjection_net

        volumes:
            dinjection-volume-mariadb:
            dinjection-volume-session-share:

        networks:
            dinjection_net:
                driver: bridge
        

Dockerfile PHP容器

FROM php:7.4-fpm


RUN apt-get update \
    && apt-get install -y \
        wget \
        curl \
        git \
        build-essential \
        nodejs \
        ca-certificates \
        zsh \
        nano \
        tzdata\
    && apt-get clean \
    && rm -rf /var/lib/apt/lists/*


ADD https://raw.githubusercontent.com/mlocati/docker-php-extension-installer/master/install-php-extensions /usr/local/bin/
RUN chmod uga+x /usr/local/bin/install-php-extensions && sync && \
    install-php-extensions \
    gd \
    intl \
    redis \
    pdo_mysql \
    opcache \
    pcntl \
    mysqli \
    gettext \
    exif \
    bz2 \
    bcmath \
    amqp \
    mcrypt \
    rdkafka \
    zip \
    yaml


COPY php-ini-overrides.ini /usr/local/etc/php/conf.d/


RUN curl -sL https://deb.nodesource.com/setup_12.x | bash - \
    && curl -L https://www.npmjs.com/install.sh | sh \
    && curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer

RUN composer global require hirak/prestissimo

RUN sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"

WORKDIR /var/www/dinjection.test/current

CMD ["php-fpm"]

EXPOSE 9000

nginx容器

FROM nginx:alpine

# install software
RUN apk update \
    && apk add --update --no-cache openssl

# generate certs
RUN mkdir -p /etc/nginx/ssl \
    && openssl genrsa -out "/etc/nginx/ssl/selfsigned.key" 2048 \
    && openssl req -new -key "/etc/nginx/ssl/selfsigned.key" -out "/etc/nginx/ssl/selfsigned.csr" -subj "/CN=selfsigned/O=acme/C=DE" \
    && openssl x509 -req -days 365 -in "/etc/nginx/ssl/selfsigned.csr" -signkey "/etc/nginx/ssl/selfsigned.key" -out "/etc/nginx/ssl/selfsigned.crt" \
    && openssl dhparam -out "/etc/nginx/ssl/dhparam.pem" 2048 \
    && chown -R root:root /etc/nginx/ssl \
    && chmod -R 600 /etc/nginx/ssl

CMD ["nginx"]

EXPOSE 80 443

所以也许有人有暗示? 提前谢谢。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)> insert overwrite table dwd_trade_cart_add_inc > select data.id, > data.user_id, > data.course_id, > date_format(
错误1 hive (edu)> insert into huanhuan values(1,'haoge'); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive> show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 <configuration> <property> <name>yarn.nodemanager.res