windows本地使用docker+nginx+mysql部署thinkphp5

以下是一个基于Docker的ThinkPHP5项目本地部署的示例。

  1. 创建一个新的目录用于存放Docker相关文件。
  2. 创建一个名为Dockerfile的文件,用于构建ThinkPHP5的Docker镜像。
  3. 创建一个名为docker-compose.yml的文件,用于定义Docker容器的网络和服务。

Dockerfile




FROM php:7.4-fpm
 
# 安装PDO扩展
RUN docker-php-ext-install pdo pdo_mysql
 
# 安装ThinkPHP5框架
RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer
RUN composer require topthink/framework 5.*
 
# 配置Nginx
RUN apt-get update && apt-get install -y nginx
RUN echo "\ndaemon off;" >> /etc/nginx/nginx.conf
 
# 复制Nginx配置文件和ThinkPHP应用
COPY nginx.conf /etc/nginx/conf.d/default.conf
COPY ./thinkphp /var/www/html/
 
# 暴露80端口
EXPOSE 80
 
# 启动Nginx和PHP-FPM
CMD service php7.4-fpm start && nginx -g 'daemon off;'

docker-compose.yml




version: '3'
 
services:
  web:
    build: .
    ports:
      - "8080:80"
    volumes:
      - ./thinkphp:/var/www/html
    depends_on:
      - db
  
  db:
    image: mysql:5.7
    environment:
      MYSQL_ROOT_PASSWORD: root
      MYSQL_DATABASE: your_database
    ports:
      - "33060:3306"

Nginx配置文件(nginx.conf)




server {
    listen       80;
    server_name  localhost;
 
    location / {
        root   /var/www/html/public;
        index  index.php index.html index.htm;
        try_files $uri $uri/ /index.php?$query_string;
    }
 
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
 
    location ~ \.php$ {
        fastcgi_pass   php:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  /var/www/html/$fastcgi_script_name;
        include        fastcgi_params;
    }
}

在这些文件的同一级目录下,执行以下命令来启动容器:




docker-compose up -d

这将会启动一个包含Nginx、PHP-FPM和MySQL的Docker容器。你可以通过访问http://localhost:8080来查看你的ThinkPHP5应用。

注意:

  • 确保你的ThinkPHP5应用已配置好数据库连接。
  • 根据你的ThinkPHP5应用的具体配置,可能需要调整Nginx配置文件和docker-compose.yml中的配置。

评论已关闭

推荐阅读

Vue中使用mind-map实现在线思维导图
2024年08月04日
VUE
Web前端最全Vue实现免密登录跳转的方式_vue怎么样不登录返回首页,最强技术实现
2024年08月04日
VUE
vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)
2024年08月04日
VUE
Vue-颜色选择器实现方案——>Vue-Color( 实战*1+ Demo*7)
2024年08月04日
VUE
Vue项目卡顿慢加载?这些优化技巧告诉你!_vue数据多渲染卡顿
2024年08月04日
VUE
vue中的keep-alive详解与应用场景
2024年08月04日
VUE
Vue、React实现excel导出功能(三种实现方式保姆级讲解)
2024年08月04日
vue-office/docx插件实现docx文件预览
2024年08月04日
VUE
java调用js文件的两种方法(支持V8引擎)
2024年08月04日
JavaScript:解决计算精度问题/mathjs/bignumber.js/big.js/decimal.js
2024年08月04日
两周从爬虫小白变大神 _yjs_js_security_passport
2024年08月04日
JS笔记(对象、函数、数组)
2024年08月04日
Markdown.js:强大的纯JavaScript Markdown解析器
2024年08月04日
Vue项目:js模拟点击a标签下载文件并重命名,URL文件地址下载方法、请求接口下载文件方法总结。
2024年08月04日
vue 父组件怎么获取子组件里面的data数据
2024年08月04日
VUE
个人开发实现AI套壳网站快速搭建(Vue+elementUI+SpringBoot)
2024年08月04日
el-table 表格封装并改造实现单元格可编辑
2024年08月04日
none
nodejs环境下创建vue项目、SSH密钥登陆!!!
2024年08月04日
vue+quill+element-ui实现视频、图片上传及缩放保姆级教程,轻松使用富文本
2024年08月04日
【three.js】22. Imported Models导入模型
2024年08月04日