百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Nginx+PHP+MySQL+CentOS7环境搭建Web环境

lipiwang 2024-10-16 13:09 10 浏览 0 评论

一个IT从业者,分享IT的各种相关内容。点个关注,不迷路,总有能帮到你的分享内容。什么?帮不到。那谢谢你这么俊/这么美,来关注我!


01 环境介绍

系统:CentOS7 1804 Server With GUI安装,无额外包

Web:Nginx v1.14.0

数据库:MySQL v8.0.11

PHP:v7.2.6

02 预安装软件

#yum -y install gcc gcc-c++ autoconf automake cmake
#yum -y install openssl-devel //安装MySQL时需要

03 安装MySQL

系统已默认安装了mariadb-libs,需先卸载。

#yum list installed | grep mariadb
#yum remove mariadb-libs

安装MySQL rpm包:

#rpm -ivh mysql-community-common-8.0.11-1.el7.x86_64.rpm \
mysql-community-libs-8.0.11-1.el7.x86_64.rpm \
mysql-community-client-8.0.11-1.el7.x86_64.rpm \
mysql-community-devel-8.0.11-1.el7.x86_64.rpm \
mysql-community-server-8.0.11-1.el7.x86_64.rpm

04 安装Nginx

下载openssl安装包,解压到/usr/local,解压后的文件夹路径/usr/local/openssl-1.1.0h。

编译安装Nginx v1.14.0

#tar -zxvf nginx-1.14.0.tar.gz
#cd nginx-1.14.0
#./configure --with-openssl=/usr/local/openssl-1.1.0h --with-http_ssl_module
#make && make install

05 安装PHP

安装libjpeg相关包:
#yum -y install libjpeg-turbo-devel
安装libpng相关包:
#yum -y install libpng-devel
安装freetype相关包:
#yum -y install freetype-devel
安装openldap相关包:
#yum -y install openldap-devel
将/usr/lib64中openldap相关包拷贝到/usr/lib:
#cp -frp /usr/lib64/libldap* /usr/lib/
编译安装PHP。
#tar -zxvf php-7.2.6.tar.gz
#cd php-7.2.6
#./configure --prefix=/usr/local/php --with-gd --with-png-dir --with-jpeg-dir --with-freetype-dir --enable-bcmath --enable-ctype --enable-sockets --enable-mbstring --with-gettext --with-ldap --with-ldap-sasl --enable-fpm --with-zlib-dir --with-pdo-mysql --enable-mysqlnd --with-mysqli --with-mysql-sock
编辑Makefile文件:
#vi Makefile
找到“EXTRA_LIBS = ”行,在末尾添加“-llber”
make安装PHP:
#make && make install

06 配置MySQL

启动mysqld服务:
#systemctl start mysqld
设置mysqld开机启动:
#systemctl enable mysqld
服务启动后,mysql生成的临时密码记录在/var/log/mysqld.log中,通过如下命令查看:
#grep ‘temporary password’ /var/log/mysqld.log
通过临时密码登录:
#mysql -u root -p //回车后输入临时密码。
修改root密码:
mysql> alter user 'root'@'localhost' IDENTIFIED BY 'NewPassword';
mysql>flush privileges;

07 配置PHP

复制安装文件中的php.ini-production到/usr/local/php/lib下,重命名为php.ini。

#cp php.ini-production /usr/local/php/lib/php.ini

也可以使用php.ini-development。php.ini-production和php.ini-development的区别是前者拥有较高的安全性设定,适合服务器上线运营当产品,后者适合开发测试,如本地测试环境。

之所以拷贝到/usr/local/php/lib目录下,是因为编译时未指定--with-config-file-path参数,则默认是在安装目录lib文件夹下,即PREFIX/lib。

生成ldap.so文件,使php支持ldap:
#cd php-7.2.6/ext/ldap
# /usr/local/php/bin/phpize
# ./configure --with-php-config=/usr/local/php/bin/php-config --with-ldap
#make && make install
配置php-fpm:
#cd /usr/local/php/etc
# cp php-fpm.conf.default php-fpm.conf
注:若php-fpm.conf末尾是include=NONE/etc/php-fpm.d/*.conf,则需改为include=/usr/local/php/etc/php-fpm.d/*conf
#cd php-fpm.d
#cp www.conf.default www.conf
编辑www.conf,根据需要修改“user = nobody”和“group = nobody”,及其他内容。

08 配置Nginx

编辑Nginx配置文件支持PHP:

#cd /usr/local/nginx/conf

#vi nginx.conf

修改相应字段为以下内容:

location / {
root html;
index index.php index.html index.htm;
}
location ~* \.php$ {
root html;
fastcgi_index index.php;
fastcgi_pass 127.0.0.1:9000;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param SCRIPT_NAME $fastcgi_script_name;
}

启动程序

#/usr/local/php/sbin/php-fpm
#/usr/local/nginx/sbin/nginx

关闭防火墙:

#systemctl stop firewalld
#systemctl disable firewalld

09 问题解决

安装Nginx

  1. 编译时,configure不加任何参数,编译汇总处提示OpenSSL library is not used

原因是没有指定openssl的解压路径,则下载openssl,解压后,使用./configure --with-openssl=/usr/local/openssl-1.1.0h --with-http_ssl_module编译即可。如果pcre和zlib出现类似的问题,解决方法同理。

安装PHP

  1. make test时提示“ldap.o: undefined reference to symbol 'ber_strdup'”

该问题已知在php7.2.0以上版本出现,说明「./configure 」沒抓好一些环境变数值。在PHP源码目录下 vi Makefile 找到 EXTRA_LIBS 行,在行末添加 ‘ -llber ‘ 保存退出再次make即可。

相关推荐

前端入门——css 网格轨道详细介绍

上篇前端入门——cssGrid网格基础知识整体大概介绍了cssgrid的基本概念及使用方法,本文将介绍创建网格容器时会发生什么?以及在网格容器上使用行、列属性如何定位元素。在本文中,将介绍:...

Islands Architecture(孤岛架构)在携程新版首页的实践

一、项目背景2022,携程PC版首页终于迎来了首次改版,完成了用户体验与技术栈的全面升级。作为与用户连接的重要入口,旧版PC首页已经陪伴携程走过了22年,承担着重要使命的同时,也遇到了很多问题:维护/...

HTML中script标签中的那些属性

HTML中的<script>标签详解在HTML中,<script>标签用于包含或引用JavaScript代码,是前端开发中不可或缺的一部分。通过合理使用<scrip...

CSS 中各种居中你真的玩明白了么

页面布局中最常见的需求就是元素或者文字居中了,但是根据场景的不同,居中也有简单到复杂各种不同的实现方式,本篇就带大家一起了解下,各种场景下,该如何使用CSS实现居中前言页面布局中最常见的需求就是元...

CSS样式更改——列表、表格和轮廓

上篇文章主要介绍了CSS样式更改篇中的字体设置Font&边框Border设置,这篇文章分享列表、表格和轮廓,一起来看看吧。1.列表List1).列表的类型<ulstyle='list-...

一文吃透 CSS Flex 布局

原文链接:一文吃透CSSFlex布局教学游戏这里有两个小游戏,可用来练习flex布局。塔防游戏送小青蛙回家Flexbox概述Flexbox布局也叫Flex布局,弹性盒子布局。它决定了...

css实现多行文本的展开收起

背景在我们写需求时可能会遇到类似于这样的多行文本展开与收起的场景:那么,如何通过纯css实现这样的效果呢?实现的难点(1)位于多行文本右下角的展开收起按钮。(2)展开和收起两种状态的切换。(3)文本...

css 垂直居中的几种实现方式

前言设计是带有主观色彩的,同样网页设计中的css一样让人摸不头脑。网上列举的实现方式一大把,或许在这里你都看到过,但既然来到这里我希望这篇能让你看有所收获,毕竟这也是前端面试的基础。实现方式备注:...

WordPress固定链接设置

WordPress设置里的最后一项就是固定链接设置,固定链接设置是决定WordPress文章及静态页面URL的重要步骤,从站点的SEO角度来讲也是。固定链接设置决定网站URL,当页面数少的时候,可以一...

面试发愁!吃透 20 道 CSS 核心题,大厂 Offer 轻松拿

前端小伙伴们,是不是一想到面试里的CSS布局题就发愁?写代码时布局总是对不齐,面试官追问兼容性就卡壳,想跳槽却总被“多列等高”“响应式布局”这些问题难住——别担心!从今天起,咱们每天拆解一...

3种CSS清除浮动的方法

今天这篇文章给大家介绍3种CSS清除浮动的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。首先,这里就不讲为什么我们要清楚浮动,反正不清除浮动事多多。下面我就讲3种常用清除浮动的...

2025 年 CSS 终于要支持强大的自定义函数了?

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!1.什么是CSS自定义属性CSS自...

css3属性(transform)的一个css3动画小应用

闲言碎语不多讲,咱们说说css3的transform属性:先上效果:效果说明:当鼠标移到a标签的时候,从右上角滑出二维码。实现方法:HTML代码如下:需要说明的一点是,a链接的跳转需要用javasc...

CSS基础知识(七)CSS背景

一、CSS背景属性1.背景颜色(background-color)属性值:transparent(透明的)或color(颜色)2.背景图片(background-image)属性值:none(没有)...

CSS 水平居中方式二

<divid="parent"><!--定义子级元素--><divid="child">居中布局</div>...

取消回复欢迎 发表评论: