文章目录
LNMP是linux、nginx、mysql、php的简写;LNMP与LAMP环境一样也是用来做web网站后台的,nginx是轻量级的,进程间的通讯使用php-fpm独立使用;apache则是比较臃肿的,调用php的模块来完成的,需要加载很多模块,运行起来相对较慢。
一、安装php
1.下载
打开php官网 https://www.php.net/downloads.php 找到需要下载的版本,复制下载链接
输入 ‘wget 下载链接’ --回车
如果提示 -bash: wget:未找到命令 需要先安装wget
下载好了输入 ls 查看文件名
可以看到压缩包的名字叫 php-7.3.5.tar.gz
2.解压
输入 tar -zxvf php-7.3.5.tar.gz 解压文件
3.安装gcc gcc++ libxml2-devel(已安装可忽略)
输入 **yum install gcc gcc++ libxml2-devel **
4.配置参数
输入 cd php-7.3.5 进入目录
再输入 ./configure --prefix=/usr/local/php7 --enable-fpm
/usr/local/php7 指的是安装的目录
–enable-fpm 后面安装 nginx需要
出现这句话说明成功了
这就装好了?不,这才一半!!!
5.编译
输入 make
编译过程比较久……
如果出现以下代码
virtual memory exhausted: Cannot allocate memory
make: *** [ext/fileinfo/libmagic/apprentice.lo] Error 1
说明内存不够
很多哥们在购买服务器的时候、前期都会买配置比较低的服务器以节省成本、内存往往会购买一个GB的服务器、那么这个时候在搭建PHP环境的时候可能会出现内存不够的情况、因为编译过程是一个内存消耗较大的动作
此时此刻怎么办?加内存?NO NO NO
因为内存满了,所以先去重启服务器。然后重复 第四步–配置参数 那里
代码改成
./configure --prefix=/usr/local/php7 --enable-fpm –disable-fileinfo
重复第五步
安装到这,出现以下代说明编译成功
6.安装
输入 make install
这一步就安装成功了
7.测试
输入 echo $?
OK,PHP安装完毕!
二、安装Mysql
1.下载
打开mysql官网 https://downloads.mysql.com/archives/community/
版本看自己需要,个人原因不喜欢用最新的。
找到需要下载的版本,复制下载链接,输入 ‘wget 下载链接’ --回车
2.解压
输入 tar -zxvf mysql-8.0.13.tar.gz 解压文件
3.安装需要的库(已安装可忽略)
因为高版本mysql都用cmake安装,所以下载cmake
输入 yum install cmake gcc-c++ ncurses-devel perl-Data-Dumper boost boost-doc boost-devel
安装完毕
5.配置参数以及编译和安装
进入mysql目录进行编译
输入 cd mysql-8.0.13
输入 cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql
输入 cd mysql-8.0.13
输入
cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DSYSCONFDIR=/etc/mysql \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DMYSQL_TCP_PORT=3306 \
-DENABLED_LOCAL_INFILE=1 \
-DENABLE_DOWNLOADS=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DEXTRA_CHARSETS=all \
-DDEFAULT_CHARSET=utf8mb4 \
-DDEFAULT_COLLATION=utf8mb4_general_ci \
-DWITH_DEBUG=1 \
-DMYSQL_MAINTAINER_MODE=0 \
-DMITH_SSL:STRING=bundled \
-DWITH_ZLIB:STRING=bundled \
-DDOWNLOAD_BOOST=1 \
-DWITH_BOOST=/usr/local/boost
参数具体含义
-DCMAKE_INSTALL_PREFIX #指定MYSQL的安装路径
-DMYSQL_DATADIR #指定MYSQL的数据存放路径
-DSYSCONFDIR #指定MYSQL的配置文件路径
-DWITH_INNOBASE_STORAGE_ENGINE #innodb存储引擎
-DWITH_MYISAM_STORAGE_ENGINE #myisam存储引擎
-DWITH_ARCHIVE_STORAGE_ENGINE #archive存储引擎
-DWITH_MEMORY_STORAGE_ENGINE #memory存储引擎
-DWITH_READLINE #readline库
-DMYSQL_TCP_PORT #指定TCP端口
-DENABLED_LOCAL_INFILE #本地数据导入
-DENABLE_DOWNLOADS #是否要下载可选的文件
-DWITH_PARTITION_STORAGE_ENGINE #安装数据库分区
-DEXTRA_CHARSETS #启用额外的字符集类型
-DDEFAULT_CHARSET #指定默认的字符集
-DDEFAULT_COLLATION #设定默认排序规则
-DWITH_DEBUG #是否开启debug
-DMYSQL_MAINTAINER_MODE #是否启用MySQL维护者特定的开发环境
-DMITH_SSL:STRING #设置MySQL通讯时支持ssl协议
-DWITH_ZLIB:STRING #允许MySQL使用zlib library
-DDOWNLOAD_BOOST #从MySQL 5.7.5开始Boost库是必需的
-DWITH_BOOST #boost库安装目录
如编译过程出现错误,请参考 mqsql编译常见问题:
编译成功
安装mysql
输入 make install
出现以下代码说明内存不足
c++: internal compiler error: Killed (program cc1plus)
Please submit a full bug report,
with preprocessed source if appropriate.
See <http://bugzilla.redhat.com/bugzilla> for instructions.
make[2]: *** [sql/CMakeFiles/sql_gis.dir/gis/crosses.cc.o] Error 4
make[1]: *** [sql/CMakeFiles/sql_gis.dir/all] Error 2
make: *** [all] Error 2
解决方法:
创建交换分区 并 开启
dd if=/dev/zero of=/swapfile bs=64M count=64
mkswap /swapfile
swapon /swapfile
然后继续 make install
安装完成后可以关闭交换分区 并删除交换分区 文件
swapoff /swapfile
rm /swapfile
6.建立用户及用户组、赋予目录权限
因为mysql默认禁止root登录
groupadd mysql
useradd -g mysql mysql -s /sbin/nologin
chown mysql:mysql -R /usr/local/mysql/
7.初始化数据库
进入mysql安装目录的bin目录
输入cd /usr/local/mysql/bin
输入 ./mysqld --initialize --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data/ --lc_messages_dir=/usr/local/mysql/share/ --lc_messages=en_US
8.映射
ln -s /usr/local/mysql/bin/mysql /usr/bin
ln -s /usr/local/mysql/bin/mysqld /usr/bin
9.进入数据库
mysql -u root
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
出现的问题是:找不到mysql.sock
如果你可以运行
find / -name mysql.sock
这条命令,并且能查到结果的话,只需将查到的结果做一个软连接到/tmp目录下即可解决
但是,我执行了这条语句之后,并没有任何反应,没有找到mysql.sock文件。
在这之前,需要明白mysql.sock这个文件有什么用?
连接localhost通常通过一个Unix域套接字文件进行,一般是/tmp/mysql.sock。如果套接字文件被删除了,本地客户就不能连接。这可能发生在你的系统运行一个cron任务删除了/tmp下的临时文件。
如果你因为丢失套接字文件而不能连接,你可以简单地通过重启服务器重新创建得到它。因为服务器在启动时重新创建它。
如果和我一样,重启服务器还是没有任何变化,你可以先执行下面的语句:
四、编译mysql常见问题
====================================================================
Running cmake version 2.8.12.2
– Found Git: /usr/bin/git (found version “1.7.1”)
– Configuring with MAX_INDEXES = 64U
– CMAKE_GENERATOR: Unix Makefiles
CMake Error at cmake/os/Linux.cmake:40 (MESSAGE):
GCC 4.8 or newer is required!
Call Stack (most recent call first):
CMakeLists.txt:239 (INCLUDE)
这是因为gcc版本低于4.8
解决方法:
升级gcc
参考文章 https://www.xingchenw.cn/article/187
====================================================================
错误:
– BOOST_INCLUDE_DIR /usr/local/include
– LOCAL_BOOST_DIR
– LOCAL_BOOST_ZIP
– Could not find (the correct version of) boost.
– MySQL currently requires boost_1_66_0
CMake Error at cmake/boost.cmake:100 (MESSAGE):
You can download it with -DDOWNLOAD_BOOST=1 -DWITH_BOOST=
解决方法
更新Boost: 参考文章 https://www.xingchenw.cn/article/191
更新之后重新进行编译(-DWITH_BOOST=/usr/include指的是boost的安装目录)
sudo cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/mydata/mysql/data -DSYSCONFDIR=/etc -DMYSQL_USER=mysql -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DMYSQL_UNIX_ADDR=/var/run/mysql/mysql.sock -DMYSOL_TCP_PORT=3306 -DENABLED_LOCAL_INFILE=1 -DENABLE_DOWNLOADS=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_DEBUG=0 -DMYSQL_MAINTAINER_MODE=0 -DWITH_SSL:STRING=bundled -DWITH_ZLIB:STRING=bundLed -DWITH_BOOST=/usr/include
==================================================================
错误:
Cannot find appropriate system libraries for WITH_SSL=system.
Make sure you have specified a supported SSL version.
Valid options are :
system (use the OS openssl library),
yes (synonym for system),
</path/to/custom/openssl/installation>,
wolfssl (use wolfSSL. See extra/README-wolfssl.txt on how to set this up)
CMake Error at cmake/ssl.cmake:68 (MESSAGE):
Please install the appropriate openssl developer package.
Call Stack (most recent call first):
cmake/ssl.cmake:357 (FATAL_SSL_NOT_FOUND_ERROR)
CMakeLists.txt:764 (MYSQL_CHECK_SSL)
– Configuring incomplete, errors occurred!
See also “/home/mysql-8.0.11/CMakeFiles/CMakeOutput.log”.
See also “/home/mysql-8.0.11/CMakeFiles/CMakeError.log”.
解决方法:
安装依赖
yum install –y openssl openssl-devel ncurses ncurses-devel libai