一、mysql数据库的源码编译
1.解压数据库源码包
[root@server1 ~]# tar zxf mysql-boost-5.7.17.tar.gz
2.安装源码编译工具cmake
[root@server1 ~]# yum install cmake-2.8.12.2-4.el6.x86_64.rpm
3.创建一个新的目录
[root@server1 mysql-5.7.17]# mkdir -p /usr/local/lnmp
4.创建预编译环境
[root@server1 mysql-5.7.17]# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/lnmp/mysql \
> -DMYSQL_DATADIR=/usr/local/lnmp/mysql/data \
> -DMYSQL_UNIX_ADDR=/usr/local/lnmp/mysql/data/mysql.sock \
> -DWITH_MYISAM_STORAGE_ENGINE=1 \
> -DWITH_INNOBASE_STORAGE_ENGINE=1 \
> -DDEFAULT_CHARSET=utf8 \
> -DDEFAULT_COLLATION=utf8_general_ci \
> -DEXTRA_CHARSETS=all \
在初次编译后,会发现有很多依赖性未解决,在安装过程中会逐一解决
5.安装gcc gcc-c++
[root@server1 mysql-5.7.17]# yum install gcc gcc-c++ -y
再次编译出现以下报错
添加划线部分再次编译
[root@server1 mysql-5.7.17]# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/lnmp/mysql -DMYSQL_DATADIR=/usr/local/lnmp/mysql/data -DMYSQL_UNIX_ADDR=/usr/local/lnmp/mysql/data/mysql.sock -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DEXTRA_CHARSETS=all -DWITH_BOOST=boost/boost_1_59_0/
编译完成出现以下报错
6.安装ncurses-devel bison
[root@server1 mysql-5.7.17]# yum install ncurses-devel
[root@server1 mysql-5.7.17]# yum install bison -y
删除文件,再次编译
编译成功
7.编译
[root@server1 mysql-5.7.17]# make
8.编译并安装
[root@server1 mysql-5.7.17]# make install
注意:编译时虚拟机内存大小最好为20G,把cpu核数加大,这样编译速度会加快
二、数据库的配置
1.切换到源码编译目录,进入mysql,将默认配置文件复制到/etc/my.cnf
[root@server1 ~]# cd /usr/local/lnmp
[root@server1 lnmp]# ls
mysql
[root@server1 lnmp]# cd mysql
[root@server1 mysql]# ls
[root@server1 mysql]# cd /etc/
[root@server1 etc]# cp my.cnf my.cnf.backup
[root@server1 ~]# cd mysql-5.7.17/
[root@server1 mysql-5.7.17]# cd support-files/
[root@server1 support-files]# cp my-default.cnf /etc/my.cnf
cp: overwrite `/etc/my.cnf'? y
2.编辑/etc/my.cnf
[root@server1 ~]# vim /etc/my.cnf
3.新建mysql的用户和组
[root@server1 ~]# groupadd -g 27 mysql
[root@server1 ~]# useradd -u 27 -g 27 -M -d /usr/local/lnmp/mysql/data -s /sbin/nologin mysql
4.在/usr/local/lnmp/mysql目录下,新建data目录,将mysql目录下所有文件的所有组都改为mysql,只有data目录的所以人为mysql
[root@server1 ~]# cd /usr/local/lnmp/mysql
[root@server1 mysql]# mkdir data
[root@server1 mysql]# chgrp mysql /usr/local/lnmp/mysql -R
[root@server1 mysql]# chown mysql data -R
[root@server1 mysql]# ll
total 60
drwxr-xr-x 2 root mysql 4096 Apr 25 07:58 bin
-rw-r--r-- 1 root mysql 17987 Nov 28 2016 COPYING
drwxr-xr-x 2 mysql mysql 4096 Apr 26 21:04 data
drwxr-xr-x 2 root mysql 4096 Apr 25 07:57 docs
drwxr-xr-x 3 root mysql 4096 Apr 25 07:57 include
drwxr-xr-x 4 root mysql 4096 Apr 25 07:58 lib
drwxr-xr-x 4 root mysql 4096 Apr 25 07:58 man
drwxr-xr-x 10 root mysql 4096 Apr 25 07:59 mysql-test
-rw-r--r-- 1 root mysql 2478 Nov 28 2016 README
drwxr-xr-x 28 root mysql 4096 Apr 25 07:59 share
drwxr-xr-x 2 root mysql 4096 Apr 25 07:59 support-files
5.将编译生存的mysql二进制命令放进系统的环境变量文件中,保证可以直接调用该二进制命令
[root@server1 ~]# vim ~/.bash_profile
[root@server1 ~]# source ~/.bash_profile
6.将编译完成的mysql启动脚本复制到系统启动服务的默认目录中,给启动脚本添加可执行权限
[root@server1 ~]# cd mysql-5.7.17/
[root@server1 mysql-5.7.17]# cd support-files/
[root@server1 support-files]# cp mysql.server /etc/init.d/mysqld
[root@server1 support-files]# cd /etc/init.d/
[root@server1 init.d]# chmod +x mysqld
7.对mysql的配置初始化
[root@server1 ~]# mysqld --user=mysql --initialize
如果这条命令执行失败,显示,需要进入data目录下,将里边的东西都删掉,再次执行则成功
[root@server1 ~]# cd /usr/local/lnmp
[root@server1 lnmp]# ls
mysql
[root@server1 lnmp]# cd mysql
[root@server1 mysql]# cd data
[root@server1 data]# ls
auto.cnf ibdata1 ib_logfile1 performance_schema sys
ib_buffer_pool ib_logfile0 mysql server1.err
[root@server1 data]# rm -fr *
8.开启mysqld
[root@server1 ~]# /etc/init.d/mysqld start
9.查看是否可以登陆进入mysql
[root@server1 ~]# mysql -uroot -p
如果不能成功进入,报这个错误
mysql: [Warning] Using a password on the command line interface can be insecure.
ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/usr/local/lnmp/mysql/data/mysql.sock’ (2)
(1)可能是mysql.sock目录位置没有写对,可能在编译的时候就编写错误,也可能在 my.conf 文件中的socket:指定位置没有写对
(2)有可能是3306端口被占用了
解决问题的方法:
<1>netstat -anp | grep 3306 ##查看占用3306端口的pid
<2>kill -9 pid(如果端口被占用,删除占用的端口号)
<3> /etc/init.d/mysqld stop ##把mysql服务关掉
<4> 然后把data目录下的东西都删掉 :rm -fr *
<5> /etc/init.d/mysqld start ##再打开mysql服务
<6> mysqld --user=mysql --initialize ##再次生成初始化密码
<7> mysql -uroot -p新密码 ##再次登录则可以成功进入
10.mysql数据初始化
[root@server1 ~]# mysql_secure_installation
12.登陆数据库测试是否可以访问
[root@server1 ~]# mysql -uroot -predhat
三、php源码编译
1.解压php源码包
[root@server1 ~]# tar jxf php-5.6.35.tar.bz2
2.解决依赖性
[root@server1 ~]# yum install -y libmcrypt-devel-2.5.8-9.el6.x86_64.rpm
[root@server1 ~]# yum install -y libmcrypt-2.5.8-9.el6.x86_64.rpm
[root@server1 ~]# yum install libcurl-devel -y
[root@server1 ~]# yum install -y openssl-devel
[root@server1 ~]# yum install -y libxml2-devel
[root@server1 ~]# yum install gmp-devel-4.3.1-7.el6_2.2.x86_64 freetype-devel -y
[root@server1 ~]# yum install libjpeg-turbo-devel-1.2.1-1.el6.x86_64 -y
[root@server1 ~]# yum install -y 2:libpng-devel-1.2.49-1.el6_2.x86_64
[root@server1 ~]# yum install -y net-snmp-devel
[root@server1 ~]# yum install -y freetype-devel
3.进入解压目录创造预编译环境
4.编译与安装
[root@server1 php-5.6.35]# make && make install
5.创建nginx用户
[root@server1 php-5.6.35]# useradd -M -d /usr/local/lnmp/nginx -s /sbin/nologin nginx
6.配置php服务的pid
[root@server1 php-5.6.35]# cd /usr/local/lnmp/php/etc/
[root@server1 etc]# ls
pear.conf php-fpm.conf.default
[root@server1 etc]# cp php-fpm.conf.default php-fpm.conf
[root@server1 etc]# vim php-fpm.conf
25 pid = run/php-fpm.pid ##去掉注释
149 user = nginx ##保证用户和组都是ngnix
150 group = nginx
7.修改php服务的时区
[root@server1 ~]# cd php-5.6.35
[root@server1 php-5.6.35]# cp php.ini-production /usr/local/lnmp/php/etc/php.ini
[root@server1 php-5.6.35]# vim /usr/local/lnmp/php/etc/php.ini
date.timezone = Asia/Shanghai
8.将php启动脚本复制到系统启动服务的默认目录中,给启动脚本添加可执行权限
[root@server1 php-5.6.35]# cd sapi/fpm/
[root@server1 fpm]# cp init.d.php-fpm /etc/init.d/php-fpm
[root@server1 fpm]# ll /etc/init.d/php-fpm
-rw-r--r-- 1 root root 2359 Apr 27 00:38 /etc/init.d/php-fpm
[root@server1 fpm]# chmod +x /etc/init.d/php-fpm
9.开启php服务
[root@server1 fpm]# /etc/init.d/php-fpm start
Starting php-fpm done
10.查看php服务的监听端口
[root@server1 fpm]# netstat -tnlp
四、nginx源码编译
1.解压nginx源码包
[root@server1 ~]# tar zxf nginx-1.14.0.tar.gz
2.隐藏nginx版本号
[root@server1 ~]# cd nginx-1.14.0
[root@server1 nginx-1.14.0]# ls
[root@server1 nginx-1.14.0]# vim src/core/nginx.h
#define NGINX_VER "nginx/"
3.关闭 debug日至
[root@server1 nginx-1.14.0]# vim auto/cc/gcc
171 # debug
172 #CFLAGS="$CFLAGS -g"
4.创造预编译环境
[root@server1 nginx-1.14.0]# ./configure --prefix=/usr/local/lnmp/nginx --with-threads --with-file-aio --with-http_ssl_module --with-http_stub_status_module --user=nginx --group=nginx
解决编译过程中的依赖性
[root@server1 nginx-1.14.0]# yum install pcre-devel -y
再次编译,编译成功
5.编译并安装
[root@server1 nginx-1.14.0]# make && make install
6.查看nginx大小
[root@server1 nginx-1.14.0]# cd /usr/local/lnmp
[root@server1 lnmp]# ls
nginx
[root@server1 lnmp]# du -sh nginx
980K nginx
7.配置nginx服务
[root@server1 lnmp]# cd nginx/
[root@server1 nginx]# cd conf/
[root@server1 conf]# vim nginx.conf
user nginx nginx;
worker_processes 1;
location / {
root html;
index index.php index.html index.htm; ##添加index.php放在最前边
}
location ~ \.php$ {
root html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
#fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
include fastcgi.conf; ##修改的地方
}
[root@server1 conf]# cd ..
8.nginx语法检测
[root@server1 nginx]# cd sbin/
[root@server1 sbin]# ls
nginx
[root@server1 sbin]# ./nginx -t ##nginx语法检测
[root@server1 sbin]# ./nginx -v ##查看nginx版本
nginx version: nginx/
[root@server1 sbin]# ./nginx -V ##可以查看编译脚本
9.创建软连接
[root@server1 sbin]# ln -s /usr/local/lnmp/nginx/sbin/nginx /usr/local/sbin/
10.开启nginx服务
[root@server1 sbin]# nginx
11.查看nginx的端口号为80
[root@server1 sbin]# netstat -tnlp
12.浏览器测试:输入172.25.7.1,显示nginx页面
13.编辑php测试页面
[root@server1 sbin]# cd ..
[root@server1 nginx]# cd html/
[root@server1 html]# vim index.php
[root@server1 html]# cat index.php
<?php
phpinfo()
?>
14.浏览器再次访问172.25.7.1/index.php,显示以下界面,表示nginx和php结合成功