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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

实验环境: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,如需转载请自行联系原作者

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
29天前
|
JSON JavaScript 前端开发
Vue3源码架构简析及Monorepo流程构建
【10月更文挑战第12天】Vue3源码架构简析及Monorepo流程构建
Vue3源码架构简析及Monorepo流程构建
|
20天前
|
数据采集 监控 前端开发
二级公立医院绩效考核系统源码,B/S架构,前后端分别基于Spring Boot和Avue框架
医院绩效管理系统通过与HIS系统的无缝对接,实现数据网络化采集、评价结果透明化管理及奖金分配自动化生成。系统涵盖科室和个人绩效考核、医疗质量考核、数据采集、绩效工资核算、收支核算、工作量统计、单项奖惩等功能,提升绩效评估的全面性、准确性和公正性。技术栈采用B/S架构,前后端分别基于Spring Boot和Avue框架。
|
15天前
|
运维 NoSQL Java
后端架构演进:微服务架构的优缺点与实战案例分析
【10月更文挑战第28天】本文探讨了微服务架构与单体架构的优缺点,并通过实战案例分析了微服务架构在实际应用中的表现。微服务架构具有高内聚、低耦合、独立部署等优势,但也面临分布式系统的复杂性和较高的运维成本。通过某电商平台的实际案例,展示了微服务架构在提升系统性能和团队协作效率方面的显著效果,同时也指出了其带来的挑战。
55 4
|
1月前
|
Java Spring
Spring底层架构源码解析(三)
Spring底层架构源码解析(三)
110 5
|
1月前
|
XML Java 数据格式
Spring底层架构源码解析(二)
Spring底层架构源码解析(二)
|
1月前
|
存储 前端开发 API
DDD领域驱动设计实战-分层架构
DDD分层架构通过明确各层职责及交互规则,有效降低了层间依赖。其基本原则是每层仅与下方层耦合,分为严格和松散两种形式。架构演进包括传统四层架构与改良版四层架构,后者采用依赖反转设计原则优化基础设施层位置。各层职责分明:用户接口层处理显示与请求;应用层负责服务编排与组合;领域层实现业务逻辑;基础层提供技术基础服务。通过合理设计聚合与依赖关系,DDD支持微服务架构灵活演进,提升系统适应性和可维护性。
独家直播|DB-GPT架构设计与源码解读(第一期)
🚀 DB-GPT首期源码解读系列上线啦! 10.8 晚7点,与DB-GPT项目发起人陈发强一起,深入探索DB-GPT的架构设计与源码解读。 🔎 直播看点: ● 架构全剖析:从设计思考到架构逻辑,全面剖析DB-GPT。 ● 源码速度解读:多模型管理、智能体、RAG、AWEL等核心模块一网打尽。 ● 项目作者面对面:陈发强,蚂蚁集团DB-GPT开源项目发起人,分享实战经验与洞见。 ● 有问必答:围绕DB-GPT的使用问题有问必答,线上帮你解issue! 👉 立即扫码预约,与DB-GPT作者零距离交流!
|
2月前
|
运维 持续交付 API
深入理解并实践微服务架构:从理论到实战
深入理解并实践微服务架构:从理论到实战
133 3
|
2月前
|
SQL 缓存 运维
亿级流量架构理论+秒杀实战系列(一)
亿级流量架构理论+秒杀实战系列(一)
|
6天前
|
缓存 负载均衡 JavaScript
探索微服务架构下的API网关模式
【10月更文挑战第37天】在微服务架构的海洋中,API网关犹如一座灯塔,指引着服务的航向。它不仅是客户端请求的集散地,更是后端微服务的守门人。本文将深入探讨API网关的设计哲学、核心功能以及它在微服务生态中扮演的角色,同时通过实际代码示例,揭示如何实现一个高效、可靠的API网关。