Pi编译安装PHP/Nginx并安装完整LEMP环境

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: 安装 Nginx+Php+Mysql#添加Nginx、Php最新源并刷新源sudo add-apt-repository ppa:nginx/stablesudo add-apt-repository ppa:ondrej/phpsudo ...
  • 安装 Nginx+Php+Mysql
#添加Nginx、Php最新源并刷新源
sudo add-apt-repository ppa:nginx/stable
sudo add-apt-repository ppa:ondrej/php
sudo apt-get update

#安装Nginx
sudo apt-get install nginx

#安装Php7.1 FPM
sudo apt-get install php7.1-fpm
#php7.1 curl扩展
sudo apt-get install php7.1-curl

#安装Mysql
sudo install mysql-server
#备份Mysql数据库
mysqldump -u root -p 欲备份的数据库名 > 导出的数据库名.sql
#恢复mysql数据库
mysql -u root -p 恢复的数据库名 < 导出过的数据库名.sql
#如恢复的数据库不存在 需要手动创建
create database 恢复的数据库名;

  • 编译安装Nginx/1.11.4升级HTTP/2.0
#下载并解压Nginx源码
wget -c https://nginx.org/download/nginx-1.11.4.tar.gz
tar -zxvf nginx-1.11.4.tar.gz

#下载并解压OpenSSL源码
wget -c https://www.openssl.org/source/openssl-1.1.0.tar.gz
tar -zxvf openssl-1.1.0.tar.gz

#下载并解压nginx-ct源码
wget -O nginx-ct.zip -c https://github.com/grahamedgecombe/nginx-ct/archive/v1.3.0.zip
unzip nginx-ct.zip

#修复Nginx/1.11.3无法编译的问题<font style="color:red">此问题在Nginx 1.11.4已经解决,1.11.4请忽略</font>
#由于OpenSSL 1.1.0 删除了 SSL_R_NO_CIPHERS_PASSED导致Nginx无法编译。这里我们需要修复nginx源码中的[一个文件](https://github.com/nginx/nginx/commit/af9e72533a69de3b8b7ed59be7be9b37203b5c82)

#用文本编辑器打开 ./nginx-1.11.3/src/event/ngx_event_openssl.c
#找到这个位置,大约在第2000行附近
if (n == SSL_R_BAD_CHANGE_CIPHER_SPEC                        /*  103 */
         || n == SSL_R_BLOCK_CIPHER_PAD_IS_WRONG                  /*  129 */
         || n == SSL_R_DIGEST_CHECK_FAILED                        /*  149 */
         || n == SSL_R_ERROR_IN_RECEIVED_CIPHER_LIST              /*  151 */
         || n == SSL_R_EXCESSIVE_MESSAGE_SIZE                     /*  152 */
         || n == SSL_R_LENGTH_MISMATCH                            /*  159 */
         || n == SSL_R_NO_CIPHERS_PASSED                          /*  182 */
         
修改为

if (n == SSL_R_BAD_CHANGE_CIPHER_SPEC                        /*  103 */
         || n == SSL_R_BLOCK_CIPHER_PAD_IS_WRONG                  /*  129 */
         || n == SSL_R_DIGEST_CHECK_FAILED                        /*  149 */
         || n == SSL_R_ERROR_IN_RECEIVED_CIPHER_LIST              /*  151 */
         || n == SSL_R_EXCESSIVE_MESSAGE_SIZE                     /*  152 */
         || n == SSL_R_LENGTH_MISMATCH                            /*  159 */
#ifdef SSL_R_NO_CIPHERS_PASSED
         || n == SSL_R_NO_CIPHERS_PASSED                          /*  182 */
#endif

#保存


#编译Nginx

#进入Nginx源码目录
cd ./nginx-1.11.4

#生成编译配置
./configure \
#设置OpenSSL源码目录
--with-openssl=../openssl-1.1.0 \
#设置nginx-ct源码目录
--add-module=../nginx-ct-1.3.0 \
--with-debug \
--with-pcre-jit \
--with-ipv6 \
--with-http_ssl_module \
#启用HTTP/2.0模块
--with-http_v2_module \
--with-http_stub_status_module \
--with-http_realip_module \
--with-http_auth_request_module \
--with-http_addition_module \
--with-http_dav_module \
--with-http_gzip_static_module \
--with-http_sub_module \
--with-mail \
--with-mail_ssl_module
#如无缺失依赖库,将会生成MakeFile

#开始编译
make
#编译完成后安装
sudo make install
#默认安装在 /usr/local/nginx 下

#install Nginx End.

  • 编译安装Php7.0
#从http://php.net/get/php-7.0.8.tar.gz/from/a/mirror 下载源码并解压
tar -xzvf xxxx.tar.gz 

#安装依赖
apt-get install libxml2-dev  libssl-dev libcurl4-gnutls-dev libmcrypt-dev

#解压镜像,然后进入文件夹中
./configure --prefix=/usr/local/php7 \
--exec-prefix=/usr/local/php7 \
--bindir=/usr/local/php7/bin \
--sbindir=/usr/local/php7/sbin \
--includedir=/usr/local/php7/include \
--libdir=/usr/local/php7/lib/php \
--mandir=/usr/local/php7/php/man \
--enable-mbstring \
--with-curl \
--with-gd \
--with-config-file-path=/usr/local/php7/etc \
--enable-fpm \
--enable-mysqlnd \
--with-pdo-mysql=mysqlnd \
--with-mysql-sock=/var/run/mysqld/mysqld.sock

#如提示缺少依赖包,请根据错误提示安装

#开始编译
make
#编译测试
make test
#安装
make install

#install Php7 End.

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
Ubuntu 网络协议 应用服务中间件
在 Ubuntu 上安装 Nginx
在 Ubuntu 上安装和配置 Nginx 非常简单。首先更新系统包,然后通过 `apt` 安装 Nginx,检查服务状态并配置防火墙规则。访问服务器 IP 测试是否成功显示默认页面。还可管理服务、创建虚拟主机及排查常见问题,适合新手快速上手部署高性能 Web 服务。
1391 0
|
前端开发 应用服务中间件 nginx
docker安装nginx,前端项目运行
通过上述步骤,你可以轻松地在Docker中部署Nginx并运行前端项目。这种方法不仅简化了部署流程,还确保了环境的一致性,提高了开发和运维的效率。确保按步骤操作,并根据项目的具体需求进行相应的配置调整。
1514 25
|
应用服务中间件 网络安全 nginx
轻松上手Nginx Proxy Manager:安装、配置与实战
Nginx Proxy Manager (NPM) 是一款基于 Nginx 的反向代理管理工具,提供直观的 Web 界面,方便用户配置和管理反向代理、SSL 证书等。本文档介绍了 NPM 的安装步骤,包括 Docker 和 Docker Compose 的安装、Docker Compose 文件的创建与配置、启动服务、访问 Web 管理界面、基本使用方法以及如何申请和配置 SSL 证书,帮助用户快速上手 NPM。
14758 1
|
应用服务中间件 Linux nginx
Mac os 安装 nginx 教程(success)
这篇文章是关于如何在Mac OS系统上使用Homebrew安装nginx及其依赖,并解决安装过程中可能出现的权限问题。
2339 0
Mac os 安装 nginx 教程(success)
|
8月前
|
关系型数据库 MySQL PHP
PHP和Mysql前后端交互效果实现
本文介绍了使用PHP连接MySQL数据库的基本函数及其实现案例。内容涵盖数据库连接、选择数据库、执行查询、获取结果等常用操作,并通过用户登录和修改密码的功能实例,展示了PHP与MySQL的交互过程及代码实现。
465 0
PHP和Mysql前后端交互效果实现
|
关系型数据库 MySQL Linux
查看Linux、Apache、MySQL、PHP版本的技巧
以上就是查看Linux、Apache、MySQL、PHP版本信息的方法。希望这些信息能帮助你更好地理解和使用你的LAMP技术栈。
581 17
|
关系型数据库 MySQL PHP
源码编译安装LAMP(HTTP服务,MYSQL ,PHP,以及bbs论坛)
通过以上步骤,你可以成功地在一台Linux服务器上从源码编译并安装LAMP环境,并配置一个BBS论坛(Discuz!)。这些步骤涵盖了从安装依赖、下载源代码、配置编译到安装完成的所有细节。每个命令的解释确保了过程的透明度,使即使是非专业人士也能够理解整个流程。
462 18
|
关系型数据库 MySQL 网络安全
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
505 25
|
SQL 关系型数据库 MySQL
PHP与MySQL的高效交互:从基础到实践####
本文深入探讨了PHP与MySQL数据库之间的高效交互技术,涵盖了从基础连接到高级查询优化的全过程。不同于传统的摘要概述,这里我们直接以一段精简代码示例作为引子,展示如何在PHP中实现与MySQL的快速连接与简单查询,随后文章将围绕这一核心,逐步展开详细讲解,旨在为读者提供一个从入门到精通的实战指南。 ```php <?php // 数据库配置信息 $servername = "localhost"; $username = "root"; $password = "password"; $dbname = "test_db"; // 创建连接 $conn = new mysqli($se
429 31
|
存储 关系型数据库 MySQL
PHP与MySQL动态网站开发:从基础到实践####
本文将深入探讨PHP与MySQL的结合使用,展示如何构建一个动态网站。通过一系列实例和代码片段,我们将逐步了解数据库连接、数据操作、用户输入处理及安全防护等关键技术点。无论您是初学者还是有经验的开发者,都能从中获益匪浅。 ####