实战从源码编译LAMP架构+Discuz搭建bbs论坛

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

实验环境:RHEL6.5  server1.example.com 172.25.254.1

实验环境:RHEL6.5

实验内容:1.MYSQL源码编译

                2.NGINX源码编译

                3.PHP源码编译

                4.搭建论坛

安装包:cmake-2.8.12.2-4.el6.x86_64.rpm 

             mysql-boost-5.7.11.tar.gz

             gd-devel-2.0.35-11.el6.x86_64.rpm  

             nginx-1.9.14.tar.gz  

             re2c-0.13.5-1.el6.x86_64.rpm

             php-5.6.19.tar.bz2

             Discuz_X3.2_SC_UTF8.zip


1.MYSQL源码编译

1)

[root@server1 1.mysql编译]# ls

cmake-2.8.12.2-4.el6.x86_64.rpm   mysql-boost-5.7.11.tar.gz

[root@server1 1.mysql编译]# tar -zxf mysql-boost-5.7.11.tar.gz

[root@server1 1.mysql编译]# cd mysql-5.7.11

2 )

[root@server1 1.mysql编译]# yum update cmake-2.8.12.2-4.el6.x86_64.rpm 

[root@server1 mnt]# yum install cmake gcc gcc-c++ ncurses-devel bison -y

3) 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  \       ##mysql引擎

-DWITH_INNOBASE_STORAGE_ENGINE=1  \

-DDEFAULT_CHARSET=utf8    \        ##使用utf8字符

-DDEFAULT_COLLATION=utf8_general_ci     \        ##校验字符

-DEXTRA_CHARSETS=all \            ##安装所有扩展字符集

-DWITH_BOOST=boost/boost_1_59_0/ \        ##boost路径

[root@server1 mysql-5.7.11]# make             ###编译

[root@server1 mysql-5.7.11]# make install     ###安装

注意:

rm -fr CMakeCache.txt    ##错误解决完毕每次删除

lscpu   ##检测cpu

top  按1     ##检测每个cpu负载

make -j2##用两个cpu做编译


4)设定mysql信息

[root@server1 php-5.6.19]# groupadd -g 27 mysql

[root@server1 php-5.6.19]# useradd -u 27 -g 27 -s /bin/false mysql

[root@server1 php-5.6.19]# cp /usr/local/lnmp/mysql/support-files/mysql.server /etc/init.d/

[root@server1 php-5.6.19]# mv /etc/my.cnf /etc/my.cnf.bak

[root@server1 php-5.6.19]# cp /usr/local/lnmp/mysql/support-files/my-default.cnf /etc/my.cnf

[root@server1 php-5.6.19]# vim /etc/profile

PATH=$PATH:/usr/local/lnmp/mysql/bin

[root@server1 php-5.6.19]# source /etc/profile

[root@server1 php-5.6.19]# chown -R mysql.mysql /usr/local/lnmp/mysql

[root@server1 php-5.6.19]# mysqld --initialize --user=mysql

( --initialize-insecure ##密码为空,--user=mysql ##运行用户 --basedir=    ##mysql基本目录 --datadir= ##mysql数据目录)

2016-09-15T04:12:17.004704Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).

。。。。。。。。。。。。。。

2016-09-15T04:12:17.626882Z 1 [Note] A temporary password is generated for root@localhost: jT!#LrMg-5t1    《《《数据库密码(安全初始化时需要使用)


[root@server1 php-5.6.19]# chown -R root /usr/local/lnmp/mysql/

[root@server1 php-5.6.19]# chown -R mysql /usr/local/lnmp/mysql/data/

[root@server1 php-5.6.19]# /etc/init.d/mysql.server start

[root@server1 php-5.6.19]# mysql_secure_installation   ####安全初始化

Securing the MySQL server deployment.

Enter password for user root:         ###此处输入前边产生的密码

Press y|Y for Yes, any other key for No: y

Please enter 0 = LOW, 1 = MEDIUM and 2 = STRONG: 1    ##选择密码类型

Change the password for root ? ((Press y|Y for Yes, any other key for No) : y   ###修改密码

New password: 

Re-enter new password: 

Estimated strength of the password: 100 

Do you wish to continue with the password provided?(Press y|Y for Yes, any other key for No) : y

Remove anonymous users? (Press y|Y for Yes, any other key for No) : y

Remove test database and access to it? (Press y|Y for Yes, any other key for No) : y 

Reload privilege tables now? (Press y|Y for Yes, any other key for No) : y

All done! 


2.NGINX源码编译

    2.1关闭debug调式模式,屏蔽nginx版本号

[root@server1 mnt]# tar -zxf nginx-1.9.14.tar.gz 

[root@server1 mnt]# cd nginx-1.9.14

[root@server1 nginx-1.9.14]# vim src/core/nginx.h    ##伪装版本

        #define nginx_version      1009014

        #define NGINX_VERSION      "1.9.14"

        #define NGINX_VER          "willis/" 

[root@server1 nginx-1.9.14]# vim auto/cc/gcc  ##关闭debug调式

   178 # debug

   179 #CFLAGS="$CFLAGS -g"

[root@server1 fpm]# groupadd -g 666 nginx

[root@server1 fpm]# useradd -u 666 -g 666 -s /sbin/nologin nginx

    2.2编译安装

[root@server1 nginx-1.9.14]# yum  insall pcre-devel openssl-devel -y

[root@server1 nginx-1.9.14]# ./configure \

> --prefix=/usr/local/lnmp/nginx \

> --with-http_ssl_module \

> --with-http_stub_status_module    ##监控模块

[root@server1 nginx-1.9.14]# make

[root@server1 nginx-1.9.14]# make  install

[root@server1 nginx-1.9.14]# cd /usr/local/lnmp/nginx/

[root@server1 nginx]# vim /etc/profile

    export PATH=$PATH:/usr/local/lnmp/mysql/bin:/usr/local/lnmp/nginx/sbin

[root@server1 nginx]# source /etc/profile

[root@server1 nginx]# nginx     ##开启nginx

[root@server1 nginx]# netstat -antple |grep nginx

tcp        0      0 0.0.0.0:80                  0.0.0.0:*                   LISTEN      0          181762     29192/nginx

[root@server1 nginx]# curl -I localhost   ##检测http协议提供程序

HTTP/1.1 200 OK

Server: willis/       ###显示版本已经隐藏

Date: Thu, 15 Sep 2016 04:48:49 GMT

Content-Type: text/html

Content-Length: 612

Last-Modified: Wed, 14 Sep 2016 21:26:20 GMT

Connection: keep-alive

ETag: "57d9c07c-264"

Accept-Ranges: bytes

[root@server1 nginx]# du -sh /usr/local/lnmp/nginx/      ###轻量级nginx

944K/usr/local/lnmp/nginx/

[root@server1 nginx]# nginx -t          ##检测nginx配置

nginx: the configuration file /usr/local/lnmp/nginx/conf/nginx.conf syntax is ok

nginx: configuration file /usr/local/lnmp/nginx/conf/nginx.conf test is successful

[root@server1 nginx]# nginx -s reload     ##加载配置


3.PHP源码编译

    3.1编译安装php

[root@server1 mnt]# ls

gd-devel-2.0.35-11.el6.x86_64.rpm   re2c-0.13.5-1.el6.x86_64.rpm   php-5.6.19.tar.bz2

[root@server1 mnt]# yum install libxml2-devel  curl-devel  gd-devel-2.0.35-11.el6.x86_64.rpm   gmp-devel  net-snmp-devel.x86_64  re2c-0.13.5-1.el6.x86_64.rpm  -y

[root@server1 mnt]# tar -jxf php-5.6.19.tar.bz2 

[root@server1 mnt]# cd php-5.6.19

[root@server1 php-5.6.19]# ./configure --prefix=/usr/local/lnmp/php \

> --with-config-file-path=/usr/local/lnmp/php/etc \

> --with-mysql=mysqlnd \##自动加载mysql信息

> --with-mysqli=mysqlnd \

> --with-pdo-mysql=mysqlnd \

> --with-openssl \

> --with-snmp \##加载简单网管协议

> --with-gd \##支持图形

> --with-zlib \##支持网页压缩

> --with-curl \##支持文本浏览

> --with-libxml-dir \##支持xml

> --with-png-dir \##支持png图片

> --with-jpeg-dir \##支持jpeg

> --with-freetype-dir \

> --without-pear \##不联网安装

> --with-gettext \##

> --with-gmp \##支持gmp

> --enable-inline-optimization \

> --enable-soap \##支持动态加载模块

> --enable-ftp \##支持ftp

> --enable-sockets \##支持套结字

> --enable-mbstring \

> --enable-fpm \

> --with-fpm-user=nginx \##使php和nginx权限一致

> --with-fpm-group=nginx

[root@server1 php-5.6.19]# make

[root@server1 php-5.6.19]# make  install

    3.2php 配置

[root@server1 php-5.6.19]# cp php.ini-production /usr/local/lnmp/php/etc/php.ini

[root@server1 php-5.6.19]# cd /usr/local/lnmp/php/etc

[root@server1 etc]# cp php-fpm.conf.default  php-fpm.conf

[root@server1 etc]# vim php-fpm.conf

    25 pid = run/php-fpm.pid

[root@server1 etc]# vim php.ini 


    925 date.timezone = Asia/Shanghai

    1001 pdo_mysql.default_socket=/usr/local/lnmp/mysql/data/mysql.sock

    1150 mysql.default_socket=/usr/local/lnmp/mysql/data/mysql.sock

    1209 mysqli.default_socket=/usr/local/lnmp/mysql/data/mysql.sock

[root@server1 etc]# cd /mnt/php-5.6.19/sapi/fpm/

[root@server1 fpm]# mv  init.d.php-fpm  /etc/init.d/fpm     

[root@server1 fpm]# chmod +x /etc/init.d/fpm 

[root@server1 fpm]# chmod 775 /usr/local/ln

[root@server1 fpm]# /etc/init.d/fpm start

[root@server1 fpm]# vim /etc/profile

    export  PATH=$PATH: /usr/local/lnmp/php/bin: /usr/local/lnmp/php/sbin

[root@server1 fpm]# source /etc/profile

[root@server1 fpm]# php -m ##查看php支持插件

    3.3配置nginx使其支持php

[root@server1 fpm]# vim /usr/local/lnmp/nginx/html/index.php  ##php测试页

<?php

phpinfo();

?>

[root@server1 fpm]# vim /usr/local/lnmp/nginx/conf/nginx.conf

 47         location / {

 48             root   html;

 49             index  index.php index.html index.htm;

 50         }

 73         location ~ \.php$ {

 74             root           html;

 75             fastcgi_pass   127.0.0.1:9000;

 76             fastcgi_index  index.php;

 77             fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;

 78             include        fastcgi.conf;   ##修改成存在的名称

 79         }

[root@server1 fpm]# nginx -t

nginx: the configuration file /usr/local/lnmp/nginx/conf/nginx.conf syntax is ok

nginx: configuration file /usr/local/lnmp/nginx/conf/nginx.conf test is successful

[root@server1 fpm]# nginx -s reload

    3.4 测试nginx对php支持


wKiom1feHTfQPCfmAAEAv9mPOmQ984.png


4.搭建论坛

    4.1新建数据库并赋权限

[root@server1 mnt]# ls

        Discuz_X3.2_SC_UTF8.zip

[root@server1 mnt]# unzip Discuz_X3.2_SC_UTF8.zip  -d /usr/local/lnmp/nginx/html

[root@server1 mnt]# cd /usr/local/lnmp/nginx/html

[root@server1 html]# mv upload/ bbs

[root@server1 html]# chmod -R 777 bbs/

[root@server1 html]# mysql -uroot -p

    mysql> CREATE DATABAsE discuz;

    Query OK, 1 row affected (0.00 sec)

    mysql> CREATE USER discuz@localhost identified by 'Willis123./';

    Query OK, 0 rows affected (0.00 sec)

    mysql> GRANT ALL ON discuz.* to discuz@localhost identified by 'Willis123./';

    Query OK, 0 rows affected, 1 warning (0.00 sec)

    4.2网页搭建论坛


wKiom1feHZ6DLC9XAACLDewwPrE014.png


wKioL1feHZ_DPLtTAACT8DXslV8254.png


wKiom1feHZ_g9Qu_AAAwWEYIa8o202.png


wKioL1feHaChV9R0AAB5dzlZi24670.png


wKioL1feHaGi4aB9AABh8zJpbBE050.png



wKiom1fU1xvjSEWzAAE7ITyYv_M734.png



    搞定.


本文转自willis_sun 51CTO博客,原文链接:http://blog.51cto.com/willis/1853585,如需转载请自行联系原作者

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
XML 运维 前端开发
LAMP架构调优(四)——资源压缩传输
LAMP架构调优(四)——资源压缩传输
15 2
|
1月前
|
运维 Linux Apache
LAMP架构调优(二)——修改Apache运行用户
LAMP架构调优(二)——修改Apache运行用户
197 1
|
30天前
|
运维 Linux Apache
LAMP架构调优(三)——模块的安装与调用
LAMP架构调优(三)——模块的安装与调用
9 0
|
1月前
|
运维 Linux Apache
LAMP架构调优(十)——Apache禁止指定目录PHP解析与错误页面优化
LAMP架构调优(十)——Apache禁止指定目录PHP解析与错误页面优化
199 2
|
1月前
|
运维 Linux Apache
LAMP架构调优(九)——Apache Rewrite功能实战
LAMP架构调优(九)——Apache Rewrite功能实战
12 1
|
1月前
|
运维 安全 Linux
LAMP架构调优(八)——Apache Worker模式调优
LAMP架构调优(八)——Apache Worker模式调优
9 0
|
1月前
|
缓存 运维 Linux
LAMP架构调优(七)——Apache Prefork模式调优
LAMP架构调优(七)——Apache Prefork模式调优
19 2
|
1月前
|
运维 网络协议 Linux
LAMP架构调优(六)——开启长链接
LAMP架构调优(六)——开启长链接
11 3
|
1月前
|
存储 缓存 运维
LAMP架构调优(五)——网页缓存设置
LAMP架构调优(五)——网页缓存设置
10 1
|
4天前
|
敏捷开发 监控 数据管理
构建高效微服务架构的五大关键策略
【4月更文挑战第20天】在当今软件开发领域,微服务架构已经成为一种流行的设计模式,它允许开发团队以灵活、可扩展的方式构建应用程序。本文将探讨构建高效微服务架构的五大关键策略,包括服务划分、通信机制、数据管理、安全性考虑以及监控与日志。这些策略对于确保系统的可靠性、可维护性和性能至关重要。