Docker部署lnmp 实战 (多注意配置文件,不管访问试试换个浏览器)

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS Agent(兼容OpenClaw),2核4GB
简介: Docker部署LNMP环境

Docker部署LNMP环境


关闭防火墙,设置自定义网络


systemctl stop firewalld 
systemctl disable firewalld
setenforce 0
docker network create --subnet=172.18.0.0/16 --opt "com.docker.network.bridge.name"="docker1"  mynetwork


部署nginx(容器IP 为 172.18.0.10)

2390224-20211014231753426-1240526362.png

mkdir /opt/nginx
cd /opt/nginx/
上传 nginx-1.12.0.tar.gz、wordpress-4.9.4-zh_CN.tar.gz 到 /opt/nginx/ 目录中
mkdir /opt/nginx/html
tar zxvf wordpress-4.9.4-zh_CN.tar.gz -C /opt/nginx/html
复制代码
复制代码
复制代码
复制代码
 1 vim Dockerfile
 2 
 3 FROM centos:7
 4 MAINTAINER this is nginx image <xyc>
 5 RUN yum -y install pcre-devel zlib-devel gcc gcc-c++ make
 6 RUN useradd -M -s /sbin/nologin nginx
 7 ADD nginx-1.12.0.tar.gz /usr/local/src/
 8 WORKDIR /usr/local/src/nginx-1.12.0
 9 RUN ./configure \
10 --prefix=/usr/local/nginx \
11 --user=nginx \
12 --group=nginx \
13 --with-http_stub_status_module && make && make install
14 ENV PATH /usr/local/nginx/sbin:$PATH
15 ADD nginx.conf /usr/local/nginx/conf/
16 ADD wordpress-4.9.4-zh_CN.tar.gz /usr/local/nginx/html/
17 RUN chmod 777 -R /usr/local/nginx/html/
18 EXPOSE 80
19 EXPOSE 443
20 ENTRYPOINT [ "/usr/local/nginx/sbin/nginx", "-g", "daemon off;" ]
复制代码
复制代码
docker build -t nginx:lnmp .
docker run -d --name nginx -p 80:80 -v /opt/nginx/html:/usr/local/nginx/html --net mynetwork -


修改nginx配置文件

2390224-20211014231753426-1240526362.png


2390224-20211014232306297-930377108.png


部署mysql(容器IP 为 172.18.0.20)


mkdir /opt/mysqld
cd /opt/mysqld
上传 mysql-boost-5.7.20.tar.gz 到 /opt/mysqld 目录中
复制代码
复制代码
 1 vim Dockerfile
 2 
 3 FROM centos:7
 4 MAINTAINER this is mysql image <lv>
 5 RUN yum -y install gcc gcc-c++ ncurses ncurses-devel bison cmake make
 6 RUN useradd -M -s /sbin/nologin  mysql
 7 ADD mysql-boost-5.7.20.tar.gz /usr/local/src/
 8 WORKDIR /usr/local/src/mysql-5.7.20/
 9 RUN cmake \
10 -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
11 -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
12 -DSYSCONFDIR=/etc \
13 -DSYSTEMD_PID_DIR=/usr/local/mysql \
14 -DDEFAULT_CHARSET=utf8  \
15 -DDEFAULT_COLLATION=utf8_general_ci \
16 -DWITH_INNOBASE_STORAGE_ENGINE=1 \
17 -DWITH_ARCHIVE_STORAGE_ENGINE=1 \
18 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
19 -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
20 -DMYSQL_DATADIR=/usr/local/mysql/data \
21 -DWITH_BOOST=boost \
22 -DWITH_SYSTEMD=1 && make -j4 && make install
23 RUN chown -R mysql:mysql /usr/local/mysql/
24 ADD my.cnf /etc/my.cnf
25 RUN chown mysql:mysql /etc/my.cnf
26 ENV PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH
27 WORKDIR /usr/local/mysql/
28 RUN bin/mysqld \
29 --initialize-insecure \
30 --user=mysql \
31 --basedir=/usr/local/mysql \
32 --datadir=/usr/local/mysql/data
33 RUN cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
34 EXPOSE 3306
35 RUN systemctl enable mysqld
36 VOLUME [ "/usr/local/mysql" ]
37 CMD /usr/sbin/init


2390224-20211014231921815-1479483449.png


vim my.cnf
[client]
port = 3306
socket = /usr/local/mysql/mysql.sock
[mysql]
port = 3306
socket = /usr/local/mysql/mysql.sock
[mysqld]
user = mysql
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
port = 3306
character_set_server=utf8
pid-file = /usr/local/mysql/mysqld.pid
socket = /usr/local/mysql/mysql.sock
server-id = 1
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES
1 vim run.sh
2 #!/bin/bash
3 /usr/local/mysql/bin/mysqld    
4 systemctl enable mysqld
5 
6 
7 docker build -t mysql:lnmp .
8 
9 docker run --name=mysql -d --privileged -v /usr/local/mysql --net mynetwork --ip 172.18.0.20 mysql:lnmp /usr/sbin/init


部署php(容器IP 为 172.18.0.30)


mkdir /opt/php
 cd /opt/php 
上传 php-7.1.10.tar.bz2 到 /opt/php 目录中
vim Dockerfile
FROM centos:7
MAINTAINER this is php image <wl>
RUN yum -y install gd \
libjpeg libjpeg-devel \
libpng libpng-devel \
freetype freetype-devel \
libxml2 libxml2-devel \
zlib zlib-devel \
curl curl-devel \
openssl openssl-devel \
gcc gcc-c++ make pcre-devel 
RUN useradd -M -s /sbin/nologin nginx
ADD php-7.1.10.tar.bz2 /usr/local/src/
WORKDIR /usr/local/src/php-7.1.10
RUN ./configure \
--prefix=/usr/local/php \
--with-mysql-sock=/usr/local/mysql/mysql.sock \
--with-mysqli \
--with-zlib \
--with-curl \
--with-gd \
--with-jpeg-dir \
--with-png-dir \
--with-freetype-dir \
--with-openssl \
--enable-fpm \
--enable-mbstring \
--enable-xml \
--enable-session \
--enable-ftp \
--enable-pdo \
--enable-tokenizer \
--enable-zip && make && make install
ENV PATH /usr/local/php/bin:/usr/local/php/sbin:$PATH
ADD php.ini    /usr/local/php/lib/
ADD php-fpm.conf /usr/local/php/etc/
ADD www.conf /usr/local/php/etc/php-fpm.d/
EXPOSE 9000
ENTRYPOINT [ "/usr/local/php/sbin/php-fpm", "-F" ]


2390224-20211014231921815-1479483449.png


docker build -t php:lnmp .
 docker run --name=php -d -p 9000:9000 --volumes-from mysql --volumes-from nginx --net mynetwork --ip 172.18.0.30 php:lnmp
 docker run --name=mysql -d --privileged --device-write-bps /dev/sda:10M -v /usr/local/mysql --net mynetwork --ip 172.18.0.20 mysql:lnmp
 docker exec -it mysql /bin/bash
mysql
create database wordpress;
grant all privileges on wordpress.* to 'wordpress'@'%' identified by 'xcc123'
grant all privileges on *.* to 'root'@'%' identified by 'xcc123';
flush privileges;



2387773-20211015133543420-1010356726.png

浏览器访问:

http://20.0.0.40/wordpress/index.php

2387773-20211015133510032-743151215.png



相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
关系型数据库 MySQL 应用服务中间件
Linux 手动安装快速部署 LNMP 环境实战
本文详细记录了在阿里云ECS上手动搭建LNMP环境的过程,系统选用Ubuntu 24.04。主要内容包括:1) 使用`apt`安装Nginx和MySQL,并更新软件源;2) 编译安装PHP 8.4.5,配置PHP-FPM及环境路径;3) 配置MySQL root用户密码;4) 调整Nginx支持PHP解析并测试整体环境。通过此过程,重现手动配置服务器的细节,帮助熟悉各组件的安装与协同工作。
1019 23
|
数据采集 JavaScript 前端开发
Pyppeteer实战:基于Python的无头浏览器控制新选择
本文详细讲解了如何使用 Pyppeteer 结合爬虫代理高效采集小红书热点推荐信息。通过设置代理 IP、Cookie 和自定义 User-Agent,突破目标网站的反爬机制,实现标题、内容和评论的数据提取。文章结合代码示例与技术关系图谱,清晰展示从数据采集到分析的全流程,为复杂网站的数据获取提供参考。读者可在此基础上优化异常处理、并发抓取等功能,提升爬虫性能。
983 8
|
Web App开发 编解码 vr&ar
使用Web浏览器访问UE应用的最佳实践
在3D/XR应用开发中,尤其是基于UE(虚幻引擎)开发的高精度场景,传统终端因硬件局限难以流畅运行高帧率、复杂效果的三维应用。实时云渲染技术,将渲染任务转移至云端服务器,降低终端硬件要求,确保用户获得流畅体验。具备弹性扩展、优化传输协议、跨平台支持和安全性等优势,适用于多种终端和场景,特别集成像素流送技术,帮助UE开发者实现低代码上云操作,简化部署流程,保留UE引擎的强大开发能力,确保画面精美且终端轻量化。
751 17
使用Web浏览器访问UE应用的最佳实践
|
应用服务中间件 PHP nginx
Docker-compose 编排lnmp(dockerfile) 完成Wordpress
通过使用Docker Compose,我们可以轻松编排LNMP环境并部署WordPress。本文详细介绍了各组件的Dockerfile和配置文件编写,并通过docker-compose.yml文件实现了整个环境的自动化部署。这种方法不仅简化了部署过程,还提高了环境的可移植性和一致性。希望本文能帮助你更好地理解和使用Docker Compose来管理和部署复杂的应用程序。
873 4
|
域名解析 网络协议 前端开发
浏览器输入域名网址访问后的过程详解
1、以91处理网为例,客户端浏览器通过DNS解析到www.91chuli.com,IP地址是202.108.22.5,通过这个IP地址找到客户端到服务器的路径。客户端浏览器发起一个HTTP会话到202.108.22.5,然后通过TCP进行封装数据包,输入到网络层。
1008 2
|
Web App开发 API Windows
取接口访问者信息[IP,浏览器,操作系统]免费API接口教程
此API用于获取访问者的IP地址、浏览器和操作系统信息,支持70多种浏览器和操作系统。通过POST或GET请求至`https://cn.apihz.cn/api/ip/getapi.php`,需提供用户ID和KEY。返回结果包括状态码、消息、IP、浏览器和操作系统信息。示例:{&quot;code&quot;:200,&quot;ip&quot;:&quot;175.154.88.178&quot;,&quot;browser&quot;:&quot;Chrome&quot;,&quot;os&quot;:&quot;Windows 10&quot;}。详情见官网文档。
693 0
|
机器学习/深度学习 存储 前端开发
实战揭秘:如何借助TensorFlow.js的强大力量,轻松将高效能的机器学习模型无缝集成到Web浏览器中,从而打造智能化的前端应用并优化用户体验
【8月更文挑战第31天】将机器学习模型集成到Web应用中,可让用户在浏览器内体验智能化功能。TensorFlow.js作为在客户端浏览器中运行的库,提供了强大支持。本文通过问答形式详细介绍如何使用TensorFlow.js将机器学习模型带入Web浏览器,并通过具体示例代码展示最佳实践。首先,需在HTML文件中引入TensorFlow.js库;接着,可通过加载预训练模型如MobileNet实现图像分类;然后,编写代码处理图像识别并显示结果;此外,还介绍了如何训练自定义模型及优化模型性能的方法,包括模型量化、剪枝和压缩等。
1156 1
Edge——如何打开IE浏览器进行访问
Edge——如何打开IE浏览器进行访问
288 4
|
安全 网络安全
用IE浏览器访问网站提示证书错误
当你在Internet Explorer中遇到证书错误提示,通常是因网站SSL/TLS证书问题或浏览器安全设置需调整。解决方法包括: 检查时间设置 调整IE设置 安装证书 调整计算机时间
2179 3
|
Web App开发 Cloud Native 测试技术
云原生之使用Docker部署Firefox浏览器
【7月更文挑战第21天】云原生之使用Docker部署Firefox浏览器
1436 3