小白必看web专题!配置环境还在用phpstudy?该用docker了!(php+nginx+mysql+phpmyadmin。)

大家好,我是Dest1ny。

大家用mac或者是windows都是使用phpstudy。

今天docker来搭建一整个php+nginx+mysql+phpmyadmin。

而且mac用docker比较方便!

docker才是众望所归。

大家多多点赞,多多支持,谢谢!!!!


CLASS-1 pull环境

1. 先去pull我们需要的环境(PHP,Nginx,MySQL)

下面是pull的部分

docker pull nginx
docker pull php:7.1-fpm
docker pull mysql:5.7
docker pull phpmyadmin

然后就一直pull完,就不掩饰了!

如果pull不成功,基本上是网络问题

CLASS-2 创建映射目录

在宿主机去创建docker需要映射的目录

就类似于在宿主机映射到docker的目录,docker容器里对应的目录会同时改变


mkdir -p ~/docker/www
mkdir -p ~/docker/nginx/conf.d/
mkdir -p ~/docker/mysql/data
mkdir -p ~/docker/mysql/conf.d

这是搞好之后的

CLASS-3 创建容器

nginx容器


docker run -p 8080:80 --name nginx \
-v ~/docker/www:/usr/share/nginx/html \
-v ~/docker/nginx/conf.d:/etc/nginx/conf.d \
--privileged=true \
-d nginx
  • docker run -p 8080:80

    • -p 8080:80:将宿主机的 8080 端口映射到容器的 80 端口,这样你可以通过访问 http://localhost:8080 来访问 Nginx 服务。
  • --name nginx

    • 给这个容器起一个名字叫 nginx,方便以后管理和识别这个容器。
  • -v /docker/www:/usr/share/nginx/html

    • -v 选项用于挂载卷,将宿主机的 /docker/www 目录挂载到容器内的 /usr/share/nginx/html 目录。这个目录是 Nginx 默认的网页目录,所以你可以把网页文件放在 /docker/www 里,容器内的 Nginx 就会自动读取并展示这些文件。
  • -v /docker/nginx/conf.d:/etc/nginx/conf.d

    • 同样使用 -v 挂载,将宿主机的 /docker/nginx/conf.d 目录挂载到容器内的 /etc/nginx/conf.d 目录。这个目录通常用于存放 Nginx 的配置文件,你可以通过修改宿主机的配置文件来动态调整容器内的 Nginx 配置。
  • --privileged=true

    • 赋予容器更高的权限,允许容器访问宿主机的更多资源。通常情况下,运行 Nginx 不需要这个参数,但在某些特定情况下(例如需要更多权限进行特定操作时),可能会使用这个选项。
  • -d nginx

    • -d 表示以后台模式运行容器。
    • nginx 是使用的镜像名称,Docker 将基于该镜像创建并运行容器。

 php容器

docker run -p 9000:9000 --name php-fpm \
-v /docker/www:/var/www/html \
-d php:7.1-fpm
  • docker run -p 9000:9000

    • -p 9000:9000:将宿主机的 9000 端口映射到容器的 9000 端口。这意味着你可以通过宿主机的 9000 端口来访问容器内的 PHP-FPM 服务(PHP FastCGI Process Manager)。
  • --name php-fpm

    • 给这个容器起一个名字叫 php-fpm,方便以后管理和识别这个容器。
  • -v /docker/www:/var/www/html

    • -v 选项用于挂载卷,将宿主机的 /docker/www 目录挂载到容器内的 /var/www/html 目录。这个目录通常是 PHP-FPM 读取 PHP 文件的默认路径,因此你可以将 PHP 项目放在 /docker/www 中,容器内的 PHP-FPM 就会读取并解析这些 PHP 文件。
  • -d php:7.1-fpm

    • -d 表示以后台模式运行容器。
    • php:7.1-fpm 是使用的镜像名称,表示使用 PHP 7.1 版本的 FPM 镜像来创建并运行容器。

 获取一下ip,后面写配置文件要用!

docker inspect php-fpm --format='{{.NetworkSettings.IPAddress}}'# 返回 IP
172.17.0.3

打开nginx的配置文件 


vim ~/docker/nginx/conf.d/default.conf

 直接写入内容即可,172.17.0.3是我自己的容器ip地址,你们的就按照前面那个命令去获取就行

server {listen       80;server_name  localhost;location / {root   /usr/share/nginx/html;index  index.php index.html index.htm;}location ~ \.php(.*)$ {root          	/var/www/html;           # php 容器的目录,进 php 容器查看fastcgi_pass	172.17.0.3:9000;         # php 容器的IPfastcgi_index	index.php;fastcgi_param	SCRIPT_FILENAME $document_root$fastcgi_script_name;include	fastcgi_params;}}

现在测试一下,去www下面去写一个php文件,看看有什么反应 

echo "<?php phpinfo(); ?>" > ~/docker/www/info.php

成功!!!


mysql容器

下面是mysql的,步骤是一样的 

docker run --name mysql -p 3306:3306 \
-v /docker/mysql/conf.d:/etc/mysql/conf.d \
-v /docker/mysql/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7
  • docker run --name mysql

    • 给这个容器起一个名字叫 mysql,方便以后管理和识别这个容器。
  • -p 3306:3306

    • 将宿主机的 3306 端口映射到容器的 3306 端口,这样你可以通过访问宿主机的 3306 端口来连接到 MySQL 数据库(MySQL 默认的端口是 3306)。
  • -v /docker/mysql/conf.d:/etc/mysql/conf.d

    • -v 选项用于挂载卷,将宿主机的 /docker/mysql/conf.d 目录挂载到容器内的 /etc/mysql/conf.d 目录。这个目录通常用于存放 MySQL 的配置文件(例如自定义的 my.cnf 文件),这样你可以通过修改宿主机的配置文件来调整容器内的 MySQL 配置。
  • -v /docker/mysql/data:/var/lib/mysql

    • 将宿主机的 /docker/mysql/data 目录挂载到容器内的 /var/lib/mysql 目录。这个目录是 MySQL 存储数据库文件的默认路径,这样可以实现数据持久化,即使容器被删除或停止,数据依然保存在宿主机上。
  • -e MYSQL_ROOT_PASSWORD=123456

    • -e 选项用于设置环境变量,这里设置了 MySQL 的根用户密码为 123456。在第一次启动容器时,MySQL 会用这个密码创建 root 用户。
  • -d mysql:5.7

    • -d 表示以后台模式运行容器。
    • mysql:5.7 是使用的镜像名称,表示使用 MySQL 5.7 版本的镜像来创建并运行容器。

看一下ip

docker inspect mysql --format='{{.NetworkSettings.IPAddress}}'# 返回 IP
172.17.0.1

创建好之后,我们去下载一个mysqli,后面会用到 

# 进入容器
docker exec -it php-fpm /bin/bash# 安装 pdo_mysql mysqli
docker-php-ext-install pdo_mysql mysqli# CTRL + D 退出容器
docker restart php-fpm

phpmyadmin容器 

sudo  docker run --restart=always -d --name myadmin  -e PMA_HOST=172.17.0.1 -e PMA_PORT=49153 -p 20888:80 phpmyadmin

这里172.17.0.1是mysql的ip,大家自己有自己的不要搞混

之后访问一下,密码我们之前也设置好了,root/root

ok,全部配置好了,上个前端测试一下

访问一下


大家多多支持,您的关注和点赞是我最大的动力!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/56579.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux 重置 root 密码

如果您在Linux系统中忘记了root密码&#xff0c;可以按照以下步骤重置&#xff1a; 重启系统。在启动时&#xff0c;当GRUB菜单出现时&#xff0c;选择要启动的内核版本&#xff0c;然后按 e 键编辑启动选项。找到以linux或linux16开头的行&#xff0c;它包含了启动内核的命令…

Qml-Item的构造和显示顺序

Qml-Item的构造和显示顺序 qml文件中组件构造顺序 在同一个qml文件中&#xff0c;同层级的Item, 文件尾的Item优先构造&#xff0c;文件首的Item后构造。这就能解释默认情况下同一个qml文件中&#xff0c;几个同层级的item都设置了focus:true&#xff0c;为啥最上面item最终有…

echarts设置x轴中文垂直显示,x轴滚动条

echarts官网配置&#xff0c;主要配置dataZoom option {xAxis: {type: category,data: [张三,李四,王五,赵六,孙七,周八,吴九,郑十,钱十一,陈十二,刘十三,杨十四,黄十五,何十六,宋十七],axisLabel: {formatter: function (value) {return value.split().join(\n); // 使用换行…

超全!一文详解大型语言模型的11种微调方法

导读&#xff1a;大型预训练模型是一种在大规模语料库上预先训练的深度学习模型&#xff0c;它们可以通过在大量无标注数据上进行训练来学习通用语言表示&#xff0c;并在各种下游任务中进行微调和迁移。随着模型参数规模的扩大&#xff0c;微调和推理阶段的资源消耗也在增加。…

pdf内容三张以上转图片,使用spire.pdf.free

一、依赖 <spire.pdf.free.version>9.13.0</spire.pdf.free.version><itextpdf.version>5.5.13</itextpdf.version><dependency><groupId>e-iceblue</groupId><artifactId>spire.pdf.free</artifactId><version>$…

下载并安装 WordPress 中文版

下载并安装 WordPress 中文版 1. 安装 LAMP 环境(Linux, Apache, MySQL, PHP)1. 安装 Apache2. 安装 MySQL3. 安装 PHP1. 下载并安装 WordPress 中文版1. 下载 WordPress2. 配置文件权限3 . 创建 MySQL 数据库4 . 配置 WordPress1. 安装 LAMP 环境(Linux, Apache, MySQL, PH…

Android Studio简易项目|随机选择器(类似转盘)

一、背景 为了强化对flowlayout流式布局的理解和简易安卓项目架构结构的理解&#xff0c;写一个小项目&#xff0c;随机选择器&#xff0c;控制可见等 二、项目代码 2.1流式布局 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns…

爬虫实战(黑马论坛)

1.定位爬取位置内容&#xff1a; # -*- coding: utf-8 -*- import requests import time import re# 请求的 URL 和头信息 url https://bbs.itheima.com/forum-425-1.html headers {user-agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like…

【存储设备专栏 2.3 -- 环回设备和块设备区别与联系】

> 请阅读【嵌入式及芯片开发学必备专栏】< 文章目录 环回设备和块设备区环回设备&#xff08;Loop Device&#xff09;定义用途示例 块设备&#xff08;Block Device&#xff09;定义用途示例 区别总结 环回设备和块设备区 在 Linux 系统中&#xff0c;存储设备常通过设…

基于Java实现(PC)大学班级事务管理系统

courseDesign_Java Java 课设 要求 本次设计要求利用 Java 实现 C/S 模式的大学班级内日常事务管理系统&#xff08;PC 版&#xff0c;应用于校内网有线网络访问&#xff0c;暂不开发移动端&#xff09;&#xff0c;不得依赖现有的建模框架&#xff0c;使用 swings 技术完成如…

华为OD机试 - 爱吃蟠桃的孙悟空 - 二分查找(Python/JS/C/C++ 2024 E卷 100分)

华为OD机试 2024E卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试真题&#xff08;Python/JS/C/C&#xff09;》。 刷的越多&#xff0c;抽中的概率越大&#xff0c;私信哪吒&#xff0c;备注华为OD&#xff0c;加入华为OD刷题交流群&#xff0c;…

决策树和集成学习的概念以及部分推导

一、决策树 1、概述 决策树是一种树形结构&#xff0c;树中每个内部节点表示一个特征上的判断&#xff0c;每个分支代表一个判断结果的输出&#xff0c;每个叶子节点代表一种分类结果 决策树的建立过程&#xff1a; 特征选择&#xff1a;选择有较强分类能力的特征决策树生成…

闯关leetcode——110. Balanced Binary Tree

大纲 题目地址内容 解题代码地址 题目 地址 https://leetcode.com/problems/balanced-binary-tree/description/ 内容 Given a binary tree, determine if it is height-balanced. A height-balanced binary tree is a binary tree in which the depth of the two subtrees…

决策树算法新手入门:从基础理论到Python实现

决策树新手入门详细教程 一、数学基础1. 信息熵(1) 基本定义(2) 条件熵(3) 有关定律 2. 信息增益 二、决策树的组成1. 决策节点2. 叶子节点3. 决策树的深度 三、决策树的建立&#xff08;基于信息增益&#xff09;—— ID31. 计算根节点的信息熵2. 计算属性的信息增益(1) 职业(…

linux之rm使用技巧

对于包含乱码的文件或目录名&#xff0c;在Linux中删除它们可能会有些棘手&#xff0c;但还是可以通过一些方法来实现。下面是一些处理这种情况的方法&#xff1a; 方法1: 使用通配符 如果这些乱码文件或目录的名字有共同的特征&#xff08;例如都是乱码&#xff09;&#xf…

ModuleNotFoundError: No module named ‘pdfminer.high_level‘

解决办法&#xff1a; pip uninstall pdfminer pip install pdfminer.six 如果还报错&#xff1a;重启计算机 参考资料&#xff1a;https://blog.csdn.net/xigewang_/article/details/132319419

【升华】python基础包NumPy学习

NumPy是使用Python进行科学计算的基础软件包。除其他外&#xff0c;它包括&#xff1a; 功能强大的N维数组对象。精密广播功能函数。集成 C/C和Fortran 代码的工具。强大的线性代数、傅立叶变换和随机数功能。 # 1、安装包 $ pip install numpy# 2、进入python的交互式界面 $…

策略模式-实现方式三

一 枚举类 Getter public enum AuthTypeEnum {QCT_PASSWORD("qct_password", "密码"),MOBILE("mobile", "验证码");public final String code;public final String desc;AuthTypeEnum(String code, String desc) {this.code code;th…

蓄电池在线监测:保障电力安全的智能之选---安科瑞 吴雅芳

一、蓄电池在线监测的重要性 随着科技的飞速发展&#xff0c;蓄电池在各个领域的应用日益广泛&#xff0c;从通信、电力到金融、医疗等行业&#xff0c;蓄电池都扮演着至关重要的角色。然而&#xff0c;蓄电池在使用过程中也面临着诸多问题。 蓄电池老化可能导致鼓胀、短路、漏…

React 子组件调用父组件的方法,以及互相传递数据

<script type"text/babel" data-type"module"> import React, { StrictMode, useState } from react; import { createRoot } from react-dom/client;const ParentComponent () > {const [message, setMessage] useState("")//父组件…