解锁成就,LNMP源码Discuz搭建论坛系统!

前言:LNMP动态网站部署架构是一套由Linux + Nginx + MySQL + PHP组成的动态网站系统解决 方案,具有免费、高效、扩展性强且资源消耗低等优良特性。我们有了这个架构可以搭建一个动态网站,搭建成之后购买域名等等操作,便可以实现构建自己的私人网站

通常情况下我们习惯用Yum仓库的包进行安装,这次我们学习用源码安装软件.

一.如何利用源码安装软件?

经过我的学习总结为4个步骤!
简单来说就是解压,编译,生成,安装

  1. 下载及解压源码包文件。
    tar xzvf FileName.tar.g
    cd FileDirectory

  2. 编译源码包代码
    ./configure --prefix=/usr/local/program

  3. 生成二进制安装程序
    make

  4. 运行二进制的服务程序安装包。
    make install

二.搭建LNMP架构

1.准备工作

(1)Yum安装源码环境
下载源码包到linux上

[root@a ~]# yum install -y apr* autoconf automake bison bzip2 bzip2* compat* cpp curl curl-devel fontconfig fontconfig-devel freetype freetype* freetype-devel gcc gcc-c++ gd gettext gettext-devel glibc kernel kernel-headers keyutils keyutils-libs-devel krb5-devel libcom_err-devel libpng libpng-devel libjpeg* libsepol-devel libselinux-devel libstdc++-devel libtool* libgomp libxml2 libxml2-devel libXpm* libtiff libtiff* make mpfr ncurses* ntp openssl openssl-devel patch pcre-devel perl php-common php-gd policycoreutils telnet t1lib t1lib* nasm nasm* wget zlib-devel

(2)下载源码包,并存放到/usr/local/src中
这些源码包我放到我的云盘里了需要的可以下载
链接: https://pan.baidu.com/s/1hxQoZrWYv2dKLx9QJnUYXg 提取码: 5rbp

解锁成就,LNMP源码Discuz搭建论坛系统!_第1张图片

[root@a ~]# cd /usr/local/src 
[root@a src]# ls 
zlib-1.2.8.tar.gz       libmcrypt-2.5.8.tar.gz  pcre-8.35.tar.gz
cmake-2.8.11.2.tar.gz   libpng-1.6.12.tar.gz    php-5.5.14.tar.gz
Discuz_X3.2_SC_GBK.zip  libvpx-v1.3.0.tar.bz2   t1lib-5.1.2.tar.gz
freetype-2.5.3.tar.gz   mysql-5.6.19.tar.gz     tiff-4.0.3.tar.gz
jpegsrc.v9a.tar.gz      nginx-1.6.0.tar.gz      yasm-1.2.0.tar.gz
libgd-2.1.0.tar.gz      openssl-1.0.1h.tar.gz

(3)安装CMake,它是一款常用的编译工具。

[root@a src]# tar xzvf cmake-2.8.11.2.tar.gz 
[root@a src]# cd cmake-2.8.11.2/ 
[root@a cmake-2.8.11.2]# ./configure 
[root@a cmake-2.8.11.2]# make  
[[email protected]]# make install 

2.配置mysql服务

增加mysql用户,切不允许登录系统
[root@a cmake-2.8.11.2]# cd .. 
[root@a src]# useradd mysql -s /sbin/nologin 

创建保存MySQL数据库程序和数据库文件的目录
[root@a src]# mkdir -p /usr/local/mysql/var 
[root@a src]# chown -Rf mysql:mysql /usr/local/mysql 

解压、编译、安装MySQL数据库服务程序
[root@a src]# tar xzvf mysql-5.6.19.tar.gz 
[root@a src]# cd mysql-5.6.19/
[root@a mysql-5.6.19]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATAD IR=/usr/local/mysql/var -DSYSCONFDIR=/etc 
[root@a mysql-5.6.19]# make 
[root@a mysql-5.6.19]# make install

先删除/etc目录中的默认配置文件,执行脚本
[root@a mysql-5.6.19]# rm -rf /etc/my.cnf 
[root@a mysql-5.6.19]# cd /usr/local/mysql 
[root@a mysql]# ./scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql -datadir=/usr/local/mysql/var

把系统新生成的MySQL数据库配置文件链接到/etc目录中,然后把程序目录中的开机程序文件复制到/etc/rc.d/init.d目录中
[root@a mysql]# ln -s my.cnf /etc/my.cnf 
[root@a mysql]# cp ./support-files/mysql.server /etc/rc.d/init.d/mysqld
[root@a mysql]# chmod 755 /etc/rc.d/init.d/mysqld

编辑刚复制的MySQL数据库脚本文件,把第46、47行的basedir与datadir参数
分别修改为MySQL数据库程序的保存目录和真实 数据库的文件内容
[root@a mysql]# vim /etc/rc.d/init.d/mysqld 
 46 basedir=/usr/local/mysql
 47 datadir=/usr/local/mysql/var 

[root@a mysql]# service mysqld start 
Starting MySQL. SUCCESS!  
[root@linuxprobe mysql]# chkconfig mysqld on

想要把命令所保存的目录永久性地定义到PATH变量中, 需要编辑/etc/profile文件并写入追加的命令目录
[root@a mysql]# vim /etc/profile 
 74 export PATH=$PATH:/usr/local/mysql/bin 
 
MySQL数据库服务程序还会调用到一些程序文件和函数库文件
[root@a mysql]# mkdir /var/lib/mysql
[root@a mysql]# ln -s /usr/local/mysql/lib/mysql /usr/lib/mysql
[root@a mysql]# ln -s /tmp/mysql.sock /var/lib/mysql/mysql.sock 
[root@a mysql]# ln -s /usr/local/mysql/include/mysql /usr/include/mysql

现在,MySQL数据库服务程序已经启动,接下来准备对MySQL数据库进行初始化

[root@a mysql]# mysql_secure_installation 

默认全选择y就可以,我这里不在赘述!

3.配置Nginx服务

nginx配置思路和mysql大致一致,不在赘述又不懂的地方可以评论区提问哦。

安装提供Perl语言兼容的正则表达式库的软件包pcre

[root@a ~]# cd /usr/local/src
[root@a src]# tar xzvf pcre-8.35.tar.gz 
[root@a src]# cd pcre-8.35
[root@a pcre-8.35]# ./configure --prefix=/usr/local/pcre
[root@a pcre-8.35]# make
[root@a pcre-8.35]# make install

openssl软件包是用于提供网站加密证书服务的程序文件

[root@a pcre-8.35]# cd /usr/local/src
[root@a src]# tar xzvf openssl-1.0.1h.tar.gz
[root@a src]# cd openssl-1.0.1h
[root@a openssl-1.0.1h]# ./config --prefix=/usr/local/openssl
[root@a openssl-1.0.1h]# make
[root@a openssl-1.0.1h]# make install

openssl软件包安装后默认会在/usr/local/openssl/bin目录中提供很多的可用命令,将这个目录添加到PATH环境变量中,并写入到配置文件中,最后执行source命令以便让新的PATH环境变量内容可以立即生效:

[root@a pcre-8.35]# vim /etc/profile
 65 for i in /etc/profile.d/*.sh ; do
 66 if [ -r "$i" ]; then
 67 if [ "${-#*i}" != "$-" ]; then
 68 . "$i"
 69 else
 70 . "$i" >/dev/null
 71 fi
 72 fi
 73 done
 74 export PATH=$PATH:/usr/local/mysql/bin:/usr/local/openssl/bin
 75 unset i
 76 unset -f pathmunge
[root@a pcre-8.35]# source /etc/profile

zlib软件包是用于提供压缩功能的函数库文件

[root@a pcre-8.35]# cd /usr/local/src
[root@a src]# tar xzvf zlib-1.2.8.tar.gz 
[root@a src]# cd zlib-1.2.8
[root@a zlib-1.2.8]# ./configure --prefix=/usr/local/zlib
[root@a zlib-1.2.8]# make
[root@a zlib-1.2.8]# make install

创建一个用户,用于执行nginx服务程序

[root@a zlib-1.2.8]# cd ..
[root@a src]# useradd www -s /sbin/nologin

安装nginx,–prefix参数用于定义服务程序稍后安装到的位置,–user与–group参数用于指定执行Nginx服务程序的用户名和用户组。在使用参数调用openssl、zlib、pcre软件包时,请写出软件源码包的解压路径,而不是程序的安装路径

[root@a src]# tar xzvf nginx-1.6.0.tar.gz 
[root@a src]# cd nginx-1.6.0/
[root@a nginx-1.6.0]# ./configure --prefix=/usr/local/nginx
--without-http_memcached_module --user=www --group=www
--with-http_stub_status_module --with-http_ssl_module
--with-http_gzip_static_module --with-openssl=/usr/local
/src/openssl-1.0.1h --with-zlib=/usr/local/src/zlib-1.2.8
--with-pcre=/usr/local/src/pcre-8.35
[root@a nginx-1.6.0]# make
[root@a nginx-1.6.0]# make install

要想启动Nginx服务程序以及将其加入到开机启动项中,也需要有脚本文件。内容是我上网上差查的。

[root@a nginx-1.6.0]# vim /etc/rc.d/init.d/nginx
#!/bin/bash
. /etc/rc.d/init.d/functions
. /etc/sysconfig/network
[ "$NETWORKING" = "no" ] && exit 0
nginx="/usr/local/nginx/sbin/nginx"
prog=$(basename $nginx)
NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf"
[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx
lockfile=/var/lock/subsys/nginx
make_dirs() {
     

user=`$nginx -V 2>&1 | grep "configure arguments:" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`
        if [ -z "`grep $user /etc/passwd`" ]; then
                useradd -M -s /bin/nologin $user
        fi
options=`$nginx -V 2>&1 | grep 'configure arguments:'`
for opt in $options; do
        if [ `echo $opt | grep '.*-temp-path'` ]; then
                value=`echo $opt | cut -d "=" -f 2`
                if [ ! -d "$value" ]; then
                        # echo "creating" $value
                        mkdir -p $value && chown -R $user $value
                fi
        fi
done
}
start() {
[ -x $nginx ] || exit 5
[ -f $NGINX_CONF_FILE ] || exit 6
make_dirs
echo -n $"Starting $prog: "
daemon $nginx -c $NGINX_CONF_FILE
retval=$?
echo
[ $retval -eq 0 ] && touch $lockfile
return $retval
}
stop() {
echo -n $"Stopping $prog: "
killproc $prog -QUIT
retval=$?
echo
[ $retval -eq 0 ] && rm -f $lockfile
return $retval
}
restart() {
#configtest || return $?
stop
sleep 1
start
}
reload() {
#configtest || return $?
echo -n $"Reloading $prog: "
killproc $nginx -HUP
RETVAL=$?
echo
}
force_reload() {
restart
}
configtest() {
$nginx -t -c $NGINX_CONF_FILE
}
rh_status() {
status $prog
}
rh_status_q() {
rh_status >/dev/null 2>&1
}
case "$1" in
start)
        rh_status_q && exit 0
        $1
        ;;
stop)
        rh_status_q || exit 0
        $1
        ;;
restart|configtest)
$1
;;
reload)
        rh_status_q || exit 7
        $1
        ;;
force-reload)
        force_reload
        ;;
status)
        rh_status
        ;;
condrestart|try-restart)
        rh_status_q || exit 0
        ;;
*)
echo $"Usage: $0 {
     start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"
exit 2
esac

保存脚本文件后记得为其赋予755权限,以便能够执行这个脚本。

[root@a nginx-1.6.0]# chmod 755 /etc/rc.d/init.d/nginx
[root@a nginx-1.6.0]# /etc/rc.d/init.d/nginx restart
Restarting nginx (via systemctl):                          
[  OK  ]
[root@a nginx-1.6.0]# chkconfig nginx on

Nginx服务程序在启动后就可以在浏览器中输入服务器的IP地址来查看到默认网页了
解锁成就,LNMP源码Discuz搭建论坛系统!_第2张图片

4.配置php

PHP(Hypertxt Preprocessor,超文本预处理器)是一种通用的开源脚本语言

1. 安装yasm,yasm源码包是一款常见的开源汇编器

[root@a nginx-1.6.0]# cd ..
[root@a src]# tar zxvf yasm-1.2.0.tar.gz
[root@a src]# cd yasm-1.2.0
[root@a yasm-1.2.0]# ./configure
[root@a yasm-1.2.0]# make
[root@a yasm-1.2.0]# make install

2.libmcrypt源码包是用于加密算法的扩展库程序

[root@a yasm-1.2.0]# cd ..
[root@a src]# tar zxvf libmcrypt-2.5.8.tar.gz
[root@a src]# cd libmcrypt-2.5.8
[root@a libmcrypt-2.5.8]# ./configure
[root@a libmcrypt-2.5.8]# make
[root@a libmcrypt-2.5.8]# make install

3.libvpx源码包是用于提供视频编码器的服务程序

[root@a libmcrypt-2.5.8]# cd ..
[root@a src]# tar xjvf libvpx-v1.3.0.tar.bz2
[root@a src]# cd libvpx-v1.3.0
[root@a libvpx-v1.3.0]# ./configure --prefix=/usr/local/libvpx --enable-shared --enable-vp9
[root@a libvpx-v1.3.0]# make
[root@a libvpx-v1.3.0]# make install

4.tiff源码包是用于提供标签图像文件格式的服务程序

[root@a libvpx-v1.3.0]# cd ..
[root@a src]# tar zxvf tiff-4.0.3.tar.gz
[root@a src]# cd tiff-4.0.3
[root@a tiff-4.0.3]# ./configure --prefix=/usr/local/tiff --enable-shared
[root@a tiff-4.0.3]# make
[root@a tiff-4.0.3]# make install

5.libpng源码包是用于提供png图片格式支持函数库的服务程序

[root@a tiff-4.0.3]# cd ..
[root@a src]# tar zxvf libpng-1.6.12.tar.gz
[root@a src]# cd libpng-1.6.12
[root@a libpng-1.6.12]# ./configure --prefix=/usr/local/libpng --enable-shared
[root@a libpng-1.6.12]# make
[root@a libpng-1.6.12]# make install

6.freetype源码包是用于提供字体支持引擎的服务程序

[root@a libpng-1.6.12]# cd ..
[root@a src]# tar zxvf freetype-2.5.3.tar.gz
[root@a src]# cd freetype-2.5.3
[root@a freetype-2.5.3]# ./configure --prefix=/usr/local/freetype --enable-shared
[root@a freetype-2.5.3]# make
[root@a freetype-2.5.3]# make install

7.jpeg源码包是用于提供jpeg图片格式支持函数库的服务程序

[root@a freetype-2.5.3]# cd ..
[root@a src]# tar zxvf jpegsrc.v9a.tar.gz
[root@a src]# cd jpeg-9a
[root@a jpeg-9a]# ./configure --prefix=/usr/local/jpeg --enable-shared
[root@a jpeg-9a]# make
[root@a jpeg-9a]# make install

8.libgd源码包是用于提供图形处理的服务程序

[root@a jpeg-9a]# cd ..
[root@a src]# tar zxvf libgd-2.1.0.tar.gz
[root@a src]# cd libgd-2.1.0
[root@a libgd-2.1.0]# ./configure --prefix=/usr/local/libgd --enable-shared --with-jpeg=/usr/local/jpeg --with-png=/usr/local/libpng --with-freetype=/usr/local/freetype --with-fontconfig=/usr/local/freetype --with-xpm=/usr/ --with-tiff=/usr/local/tiff --with-vpx=/usr/local/libvpx
[root@a libgd-2.1.0]# make
[root@a libgd-2.1.0]# make install

9.t1lib源码包是用于提供图片生成函数库的服务程序

[root@a cd libgd-2.1.0]# cd ..
[root@a src]# tar zxvf t1lib-5.1.2.tar.gz
[root@a src]# cd t1lib-5.1.2
[root@a t1lib-5.1.2]# ./configure --prefix=/usr/local/t1lib --enable-shared
[root@a t1lib-5.1.2]# make
[root@a t1lib-5.1.2]# make install
[root@a t1lib-5.1.2]# ln -s /usr/lib64/libltdl.so /usr/lib/libltdl.so 
[root@a t1lib-5.1.2]# cp -frp /usr/lib64/libXpm.so* /usr/lib/

10.安装php

[root@a t1lib-5.1.2]# cd ..
[root@a src]# tar -zvxf php-5.5.14.tar.gz
[root@a src]# cd php-5.5.14
[root@a php-5.5.14]# export LD_LIBRARY_PATH=/usr/local/libgd/lib
[root@a php-5.5.14]# ./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --with-mysql=/usr/local/mysql --with-mysqli=/usr/local/mysql/bin/mysql_config --with-mysql-sock=/tmp/mysql.sock --with-pdo-mysql=/usr/local/mysql --with-gd --with-png-dir=/usr/local/libpng --with-jpeg-dir=/usr/local/jpeg --with-freetype-dir=/usr/local/freetype --with-xpm-dir=/usr/ --with-vpx-dir=/usr/local/libvpx/ --with-zlib-dir=/usr/local/zlib --with-t1lib=/usr/local/t1lib --with-iconv --enable-libxml --enable-xml --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --enable-opcache --enable-mbregex --enable-fpm --enable-mbstring --enable-ftp --enable-gd-native-ttf --with-openssl --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --without-pear --with-gettext --enable-session --with-mcrypt --with-curl --enable-ctype 
[root@a php-5.5.14]# make
[root@a php-5.5.14]# make install

11.删除当前默认的配置文件,将php服务程序目录中相应的配置文件复制过来

[root@a php-5.5.14]# rm -rf /etc/php.ini
[root@a php-5.5.14]# ln -s /usr/local/php/etc/php.ini /etc/php.ini
[root@a php-5.5.14]# cp php.ini-production /usr/local/php/etc/php.ini
[root@a php-5.5.14]# cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf
[root@a php-5.5.14]# ln -s /usr/local/php/etc/php-fpm.conf /etc/php-fpm.conf

12.php-fpm.conf是php服务程序重要的配置文件之一,我们需要启用该配置文件中第25行左右的pid文件保存目录,然后分别将第148和149行的user与group参数分别修改为www账户和用户组名称:

[root@a php-5.5.14]# vim /usr/local/php/etc/php-fpm.conf
1 ;;;;;;;;;;;;;;;;;;;;;
2 ; FPM Configuration ;
3 ;;;;;;;;;;;;;;;;;;;;;
4 
5 ; All relative paths in this configuration file are relative to PHP's instal l
6 ; prefix (/usr/local/php). This prefix can be dynamically changed by using t he
7 ; '-p' argument from the command line.
8 
9 ; Include one or more files. If glob(3) exists, it is used to include a bunc h of
10 ; files from a glob(3) pattern. This directive can be used everywhere in the
11 ; file.
12 ; Relative path can also be used. They will be prefixed by:
13 ; - the global prefix if it's been set (-p argument)
14 ; - /usr/local/php otherwise
15 ;include=etc/fpm.d/*.conf
16 
17 ;;;;;;;;;;;;;;;;;;
18 ; Global Options ;
19 ;;;;;;;;;;;;;;;;;;
20 
21 [global]
22 ; Pid file
23 ; Note: the default prefix is /usr/local/php/var
24 ; Default Value: none
25 pid = run/php-fpm.pid
26 

145 ; Unix user/group of processes
146 ; Note: The user is mandatory. If the group is not set, the default user's g roup
147 ; will be used.
148 user = www
149 group = www
150 

13. 把管理php服务的脚本文件复制到/etc/rc.d/init.d中

 [root@a php-5.5.14]# cp sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm
[root@a php-5.5.14]# chmod 755 /etc/rc.d/init.d/php-fpm
[root@a php-5.5.14]# chkconfig php-fpm on

14.编辑php.ini配置文件,在305行的disable_functions参数后面追加上要禁止的功能

[root@a php-5.5.14]# vim /usr/local/php/etc/php.ini

300 
301 ; This directive allows you to disable certain functions for security reasons.
302 ; It receives a comma-delimited list of function names. This directive is
303 ; *NOT* affected by whether Safe Mode is turned On or Off.
304 ; http://php.net/disable-functions
305 disable_functions =passthru,exec,system,chroot,scandir,chgrp,chown,shell_exec,proc_open,proc_get_status,ini_alter,ini_alter,ini_restor e,dl,openlog,syslog,readlink,symlink,popepassthru,stream_socket_server,escapeshellcmd,dll,popen,disk_free_space,checkdnsrr,checkdnsrr,g etservbyname,getservbyport,disk_total_space,posix_ctermid,posix_get_last_error,posix_getcwd,posix_getegid,posix_geteuid,posix_getgid,po six_getgrgid,posix_getgrnam,posix_getgroups,posix_getlogin,posix_getpgid,posix_getpgrp,posix_getpid,posix_getppid,posix_getpwnam,posix_ getpwuid,posix_getrlimit,posix_getsid,posix_getuid,posix_isatty,posix_kill,posix_mkfifo,posix_setegid,posix_seteuid,posix_setgid,posix_ setpgid,posix_setsid,posix_setuid,posix_strerror,posix_times,posix_ttyname,posix_uname
306 

15.最后,还需要编辑Nginx服务程序的主配置文件
把第2行的井号(#)删除,然后在后面写上负责运行Nginx服务程序的账户名称和用户组名称

[root@a php-5.5.14]# vim /usr/local/nginx/conf/nginx.conf
 1 
 2 user www www;
 3 worker_processes 1;
 4 
 5 #error_log logs/error.log;
 6 #error_log logs/error.log notice;
 7 #error_log logs/error.log info;
 8 
 9 #pid logs/nginx.pid;
 10 
 11 

index参数后面写上网站的首页名称

 40 
 41 #access_log logs/host.access.log main;
 42 
 43 location / {
     
 44 root html;
 45 index index.html index.htm index.php;
 46 }
 47 

最后是将第65~71行参数前的井号(#)删除来启用参数,主要是修改第69行的脚本名称路径参数,其中$document_root变量即为网站信息存储的根目录路径,若没有设置该变量,则Nginx服务程序无法找到网站信息,因此会提示“404页面未找到”的报错信息

 62 
 63 #pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
 64 
 65 location ~ \.php$ {
     
 66 root html;
 67 fastcgi_pass 127.0.0.1:9000;
 68 fastcgi_index index.php;
 69 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
 70 include fastcgi_params;
 71 }
 72 

16.LNMP搭建完了,呼呼呼!!!

三.搭建Discuz论坛系统

1.Discuz! X3.2软件包的后缀是.zip格式,因此应当使用专用的unzip命令来进行解压

[root@a php-5.5.14 ]# cd /usr/local/src/
[root@a src]# unzip Discuz_X3.2_SC_GBK.zip
[root@a src]# rm -rf /usr/local/nginx/html/{index.html,50x.html}*
[root@a src]# mv upload/* /usr/local/nginx/html/
[root@a src]# chown -Rf www:www /usr/local/nginx/html
[root@a src]# chmod -Rf 755 /usr/local/nginx/html

2.在浏览器中输入搭建好的LNMP架构的虚拟机IP192.168.10.10/install/便可以开始安装论坛系统了

解锁成就,LNMP源码Discuz搭建论坛系统!_第3张图片3.跳过安装步骤了哈,都是默认选项就行了,直接放一张结果图
解锁成就,LNMP源码Discuz搭建论坛系统!_第4张图片
4.OK,功夫不负有心人,完成啦!
解锁成就,LNMP源码Discuz搭建论坛系统!

你可能感兴趣的:(Linux基础)