12.1 LNMP架构介绍;12.2 MySQL安装;12.3 PHP安装(上);12.4 PHP安装(下);12.5 Nginx介绍

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
简介:

扩展:

Nginx为什么比Apache Httpd高效:原理篇 http://www.toxingwang.com/linux-unix/linux-basic/1712.html

apache和nginx工作原理比较 http://www.server110.com/nginx/201402/6543.html

mod_php 和 mod_fastcgi以及php-fpm的比较 http://dwz.cn/1lwMSd

概念了解:CGI,FastCGI,PHP-CGI与PHP-FPMhttp://www.nowamagic.net/librarys/veda/detail/1319/


12.1 LNMP架构介绍


1和LAMP不同的是,提供web服务的是Nginx

2 并且php是作为一个独立服务存在的,这个服务叫做php-fpm

3 Nginx直接处理静态请求,动态请求会转发给php-fpmwKiom1mKsJXQmz8fAABvHeMzlV4123.png

spacer.gif



12.2 MySQL安装


删除之前安装的mysql

1. 查看之前安装mysql是否开启:

[root@hao-01 ~]# ps aux |grep mysql


2. 关闭之前安装的mysql服务:

[root@hao-01 ~]# service mysqld stop


3. 删除之前安装的mysql目录:

[root@hao-01 ~]# rm -rf /usr/local/mysql


4. 删除之前安装的mysql启动脚本:

[root@hao-01 ~]# rm -rf /etc/init.d/mysqld


5. 删除之前安装的mysql目录:

[root@hao-01 ~]# rm -rf /data/mysql


安装mysql

安装下载工具: yum -y install wget


1. 进入下载安装包目录:

[root@hao-01 ~]# cd /usr/local/src/


2. 下载mysql安装包

[root@hao-01 src]# wget http://mirrors.sohu.com/mysql/MySQL-5.6/mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz


3. 解包解压mysql包:

[root@hao-01 src]# tar zxvf mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz


4. 解压的mysql包,移动到/usr/local/目录下,并重命名为mysql目录:

((注意:/usr/local/目录下,不能已经存在mysql目录,

如果存在,再用mv移动,会放在已存的mysql目录下面,而不会覆盖!!!))

[root@hao-01 src]# mv mysql-5.6.35-linux-glibc2.5-x86_64 /usr/local/mysql


5. 列出mysql目录下所有文件目录(检查是否和下图一样):

[root@hao-01 local]# ls /usr/local/mysqlwKioL1mKsK_jYFOmAAAUh10lNVk390.png

spacer.gif


6. 进入mysql目录下:

[root@hao-01 src]# cd /usr/local/mysql


7. 创建mysql用户:

[root@hao-01 mysql]# useradd mysql


8. 根目录下,创建data目录:

(注意:如果根目录下已存在data目录,一定要把data里的mysql目录先删除!!!)

[root@hao-01 mysql]# mkdir /data/


9. 安装依赖包:

[root@hao-01 mysql]# yum install -y perl-Data-Dumper

[root@hao-01 mysql]# yum install -y libaio 


10. mysql目录下初始化(mysql所需要的目录,会自动生成;指定用户为mysql,指定数据库目录为/data/mysql):

[root@hao-01 mysql]# ./scripts/mysql_install_db --user=mysql --datadir=/data/mysql


11. 检验上一条命令执行是否有错?(数值0为没问题):

[root@hao-01 mysql]# echo $?


12. 编辑my.cnf配置文件:

[root@hao-01 mysql]# vim /etc/my.cnf

更改内容(图片中三行用#号暂时注释掉):

datadir=/data/mysql

socket=/tmp/mysql.sockwKiom1mKsMjgSkvBAABcCco3WuU357.png

spacer.gif


13. 拷贝mysql.server配置文件,并改名mysqld

[root@hao-01 mysql]# cp support-files/mysql.server /etc/init.d/mysqld


14. 编辑mysqld配置文件:

[root@hao-01 mysql]# vim /etc/init.d/mysqld

更改内容(定义basedir和datadir)

basedir=/usr/local/mysql

datadir=/data/mysqlwKiom1mKsOuw4sROAAAdeuCC0Cc702.png

spacer.gif


15. 启动mysqld服务:

[root@hao-01 mysql]# /etc/init.d/mysqld start


16. mysqld服务加入到服务列表里面

[root@hao-01 mysql]# chkconfig --add mysqld


17. 设置mysqld服务加入开机启动项

[root@hao-01 mysql]# chkconfig mysqld on


18. 搜索mysql进程,查看是否启动?

[root@hao-01 mysql]# ps aux |grep mysql


19. 查看mysql对应的端口号(3306)

[root@hao-01 mysql]# netstat -lntp


20. 关闭mysqld服务:

[root@hao-01 mysql]# service mysqld stop


12.3 PHP安装(上)12.4 PHP安装(下)


1. 进入下载安装包目录:

[root@hao-01 ~]# cd /usr/local/src/


2. 下载php-5.6.30版本安装包

[root@hao-01 src]# wget http://cn2.php.net/distributions/php-5.6.30.tar.gz

3. 解包解压php安装包

[root@hao-01 src]# tar zxf php-5.6.30.tar.gz


4. 进入php目录下:

[root@hao-01 src]# cd php-5.6.30

5. 如果之前编译过php-5.6.30包,进入这个包下解除删除之前的编译

[root@hao-01 php-5.6.30]# make cleanwKioL1mKsQaCvESTAAAz8dCuvEk378.png

spacer.gif


6. 编译

[root@hao-01 php-5.6.30]# ./configure --prefix=/usr/local/php-fpm --with-config-file-path=/usr/local/php-fpm/etc --enable-fpm --with-fpm-user=php-fpm --with-fpm-group=php-fpm --with-mysql=/usr/local/mysql --with-mysqli=/usr/local/mysql/bin/mysql_config --with-pdo-mysql=/usr/local/mysql --with-mysql-sock=/tmp/mysql.sock --with-libxml-dir --with-gd --with-jpeg-dir --with-png-dir --with-freetype-dir --with-iconv-dir --with-zlib-dir --with-mcrypt --enable-soap --enable-gd-native-ttf --enable-ftp --enable-mbstring --enable-exif --with-pear --with-curl --with-openssl


7. 检验上一条命令执行是否有错?(数值0为没问题):

[root@hao-01 mariadb]# echo $?


8. 安装依赖包:

(编译php需要以下依赖包,编译后如图错误:安装对应依赖包后,再次编译!)


[root@hao-01 php-5.6.30]# yum install -y gcc

wKioL1mLCOXhGfRVAAAMT2N3FzI675.png


[root@hao-01 php-5.6.30]# yum install -y libxml2-develwKiom1mKsR_QvAPkAAAc1R3Ozec623.png

spacer.gif

[root@hao-01 php-5.6.30]# yum install -y openssl-develwKiom1mKs5LR47WOAAAYJA0M0Sg550.png

spacer.gif

[root@hao-01 php-5.6.30]# yum install -y bzip2-develwKioL1mKs7XykgMZAAAahiBH9OU339.png

spacer.gif

[root@hao-01 php-5.6.30]# yum install -y libjpeg-develwKioL1mKs8fzJTNPAAAak7pjFM4516.png

spacer.gif

[root@hao-01 php-5.6.30]# yum install -y libpng-develwKiom1mKu4yh-9_IAAAY5qq3ccs787.png

spacer.gif

[root@hao-01 php-5.6.30]# yum install -y freetype-develwKioL1mKu6OAu75TAAAVRD_Y_JI259.png

spacer.gif

[root@hao-01 php-5.6.30]# yum install -y epel-release && yum install -y libmcrypt-develwKioL1mKu8Lhmi5iAAAUXov-54k716.png

spacer.gif

[root@hao-01 php-5.6.30]# yum install -y libcurl-develwKiom1mKu9uBSb_hAAAbm4S5WeA589.png

spacer.gif

9. 继续编译

[root@hao-01 php-5.6.30]# ./configure --prefix=/usr/local/php-fpm --with-config-file-path=/usr/local/php-fpm/etc --enable-fpm --with-fpm-user=php-fpm --with-fpm-group=php-fpm --with-mysql=/usr/local/mysql --with-mysqli=/usr/local/mysql/bin/mysql_config --with-pdo-mysql=/usr/local/mysql --with-mysql-sock=/tmp/mysql.sock --with-libxml-dir --with-gd --with-jpeg-dir --with-png-dir --with-freetype-dir --with-iconv-dir --with-zlib-dir --with-mcrypt --enable-soap --enable-gd-native-ttf --enable-ftp --enable-mbstring --enable-exif --with-pear --with-curl --with-opensslwKioL1mKu_KC2DADAAB5qTDHFPQ240.png

spacer.gif


10. 检验上一条命令执行是否有错?(数值0为没问题):

[root@hao-01 mariadb]# echo $?


11. make和make install执行:

[root@hao-01 php-5.6.30]# make && make install wKiom1mKvAygnxjBAAAzQ88yT38500.png

spacer.gif


12. 拷贝当前目录下php.iniproduction,并重命名

[root@hao-01 php-5.6.30]# cp php.ini-production /usr/local/php-fpm/etc/php-ini


13. 在/usr/local/php-fpm/etc/目录下,创建php-fpm.conf文件,并写入内容

[root@hao-01 etc]# vim /usr/local/php-fpm/etc/php-fpm.conf

添加内容如下:

[global]
pid = /usr/local/php-fpm/var/run/php-fpm.pid
error_log = /usr/local/php-fpm/var/log/php-fpm.log
[www]
listen = /tmp/php-fcgi.sock
listen.mode = 666
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024

如图格式:wKiom1mKvCixkhLNAAA4aH7NqpI254.png

spacer.gif


14. 拷贝当前目录sapi下的fpm/init.d.php-fpm(启动脚本),并重命名:

[root@hao-01 php-5.6.30]# cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm


15. php-fpm(启动脚本) 设定755权限

[root@hao-01 php-5.6.30]# chmod 755 /etc/init.d/php-fpm


16. 添加php-fpm服务 到服务列表

[root@hao-01 php-5.6.30]# chkconfig --add php-fpm


17. 设定 php-fpm服务 开机启动

[root@hao-01 php-5.6.30]# chkconfig php-fpm on


18. 创建php-fpm用户

[root@hao-01 php-5.6.30]# useradd php-fpm


19. 检测php-fpm配置文件是否有错?

[root@hao-01 php-5.6.30]# /usr/local/php-fpm/sbin/php-fpm -t


20. 启动php-fpm服务:

[root@hao-01 php-5.6.30]# service php-fpm start


21. 搜索php-fpm服务是否启动?

[root@hao-01 php-5.6.30]# ps aux |grep php-fpm


12.5 Nginx介绍


1 Nginx官网 nginx.org,最新版1.13,最新稳定版1.12

2 Nginx应用场景:web服务、反向代理(代理一台)、负载均衡(代理两台)

3 Nginx著名分支,淘宝基于Nginx开发的Tengine,使用上和Nginx一致,服务名,配置文件名都一样,和Nginx的最大区别在于Tenging增加了一些定制化模块,在安全限速方面表现突出,另外它支持对js,css合并

4 Nginx核心+lua相关的组件和模块组成了一个支持lua的高性能web容器openresty,参考http://jinnianshilongnian.iteye.com/blog/2280928      










本文转自 主内安详 51CTO博客,原文链接:http://blog.51cto.com/zhuneianxiang/1954720,如需转载请自行联系原作者
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
9月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
应用服务中间件 PHP nginx
今日小结通过aliyun的本地容器镜像部署我的nginx和php环境
简介: 本教程介绍如何基于 Dragonwell 的 Ubuntu 镜像创建一个运行 Nginx 的 Docker 容器。首先从阿里云容器镜像服务拉取基础镜像,然后编写 Dockerfile 确保 Nginx 作为主进程运行,并暴露 80 端口。最后,在包含 Dockerfile 的目录下构建自定义镜像并启动容器,确保 Nginx 在前台运行,避免容器启动后立即退出。通过 `docker build` 和 `docker run` 命令完成整个流程。
462 25
今日小结通过aliyun的本地容器镜像部署我的nginx和php环境
|
存储 SQL 关系型数据库
MySQL进阶突击系列(03) MySQL架构原理solo九魂17环连问 | 给大厂面试官的一封信
本文介绍了MySQL架构原理、存储引擎和索引的相关知识点,涵盖查询和更新SQL的执行过程、MySQL各组件的作用、存储引擎的类型及特性、索引的建立和使用原则,以及二叉树、平衡二叉树和B树的区别。通过这些内容,帮助读者深入了解MySQL的工作机制,提高数据库管理和优化能力。
|
11月前
|
数据可视化 关系型数据库 MySQL
ELK实现nginx、mysql、http的日志可视化实验
通过本文的步骤,你可以成功配置ELK(Elasticsearch, Logstash, Kibana)来实现nginx、mysql和http日志的可视化。通过Kibana,你可以直观地查看和分析日志数据,从而更好地监控和管理系统。希望这些步骤能帮助你在实际项目中有效地利用ELK来处理日志数据。
833 90
|
8月前
|
关系型数据库 MySQL 分布式数据库
Super MySQL|揭秘PolarDB全异步执行架构,高并发场景性能利器
阿里云瑶池旗下的云原生数据库PolarDB MySQL版设计了基于协程的全异步执行架构,实现鉴权、事务提交、锁等待等核心逻辑的异步化执行,这是业界首个真正意义上实现全异步执行架构的MySQL数据库产品,显著提升了PolarDB MySQL的高并发处理能力,其中通用写入性能提升超过70%,长尾延迟降低60%以上。
|
10月前
|
负载均衡 算法 关系型数据库
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL集群架构负载均衡故障排除与解决方案
本文深入探讨 MySQL 集群架构负载均衡的常见故障及排除方法。涵盖请求分配不均、节点无法响应、负载均衡器故障等现象,介绍多种负载均衡算法及故障排除步骤,包括检查负载均衡器状态、调整算法、诊断修复节点故障等。还阐述了预防措施与确保系统稳定性的方法,如定期监控维护、备份恢复策略、团队协作与知识管理等。为确保 MySQL 数据库系统高可用性提供全面指导。
|
11月前
|
关系型数据库 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解析并测试整体环境。通过此过程,重现手动配置服务器的细节,帮助熟悉各组件的安装与协同工作。
785 23
|
12月前
|
SQL 存储 缓存
MySQL的架构与SQL语句执行过程
MySQL架构分为Server层和存储引擎层,具有高度灵活性和可扩展性。Server层包括连接器、查询缓存(MySQL 8.0已移除)、分析器、优化器和执行器,负责处理SQL语句;存储引擎层负责数据的存储和读取,常见引擎有InnoDB、MyISAM和Memory。SQL执行过程涉及连接、解析、优化、执行和结果返回等步骤,本文详细讲解了一条SQL语句的完整执行过程。
427 3
|
12月前
|
应用服务中间件 PHP nginx
当你的nginx服务器和php服务器不在一起的时候,这个nginx 的root目录问题
两个服务器的网站代码目录需要对齐,docker容器里面也是一样
|
SQL 存储 关系型数据库
MySQL进阶突击系列(01)一条简单SQL搞懂MySQL架构原理 | 含实用命令参数集
本文从MySQL的架构原理出发,详细介绍其SQL查询的全过程,涵盖客户端发起SQL查询、服务端SQL接口、解析器、优化器、存储引擎及日志数据等内容。同时提供了MySQL常用的管理命令参数集,帮助读者深入了解MySQL的技术细节和优化方法。

推荐镜像

更多