LNMP搭建;带三个站点(Typecho、discuz、dedecms)

Stella981
• 阅读 780

在亚马逊云主机搭建环境 准备工作,下好所需的包

mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz
nginx-1.12.1.tar.gz   php-5.6.30.tar.bz2

安装msyql

解压mysql

mysql 是二进制免编译包,所以省去的编译的过程

移动到/usr/local/下,更名为mysql

tar -zxvf mysql-5.6.35-linux-glibc2.5-x86_64.tar.g
mv mysql-5.6.35-linux-glibc2.5-x86_64 /usr/local/mysql

初始化

进入所在目录进行

cd /usr/local/mysql

初始化前,记得确定是否有data目录

./scripts/mysql_install_db --user=mysql --datadir=/data/mysql

安装缺少的依赖包,否则不能成功初始化

yum install -y perl-Data-Dumper.x86_64
yum install -y libaio

都是在mysql目录下进行的

拷贝配置文件

cp support-files/my-default.cnf /etc/my.cnf

拷贝启动脚本

cp support-files/mysql.server /etc/init.d/mysqld

更改配置文件

vim /etc/my.cnf

在[mysqld] 下 增加

datadir=/data/mysql
socket=/tmp/mysql.sock

更改启动脚本

vim /etc/init.d/mysqld

找到下面两个项,添加上路径

basedir=/usr/local/mysql
datadir=/data/mysql

检查开启服务

/etc/init.d/mysqld start

屏幕输出

Starting MySQL.Logging to '/data/mysql/ip-172-31-45-37.us-east-2.compute.internal.err'.
SUCCESS!

将mysql 加入到服务列表

chkconfig --add mysqld

配置mysql服务,开机启动

chkconfig mysqld on

安装php-fpm

安装依赖包

yum install -y gcc
yum install -y libxml2-devel.x86_64
yum install -y openssl-devel.x86_64
yum install -y bzip2-devel.x86_64
yum install -y libjpeg-devel
yum install -y libpng-devel
yum install -y freetype-devel
yum install -y libcurl-devel.x86_64

安装第三方yum源 //因为是亚马逊的主机不支持安装拓展源,使用安装第三方源

wget http://www.atomicorp.com/installers/atomic
sh atomic
yum  install  php-mcrypt  libmcrypt  libmcrypt-devel

初始化

./configure --prefix=/usr/local/php-fpm  
--with-config-file-path=/usr/local/php-fpm/etc 
--enable-fpm 
--with-fpm-user=php-fpm 
--with-fpm-group=php-fpm 
--with-mysql=/usr/local/mysql 
--with-mysqli=/usr/local/mysql/bin/mysql_config 
--with-pdo-mysql=/usr/local/mysql 
--with-mysql-sock=/tmp/mysql.sock 
--with-libxml-dir 
--with-gd 
--with-jpeg-dir 
--with-png-dir 
--with-freetype-dir 
--with-iconv-dir 
--with-zlib-dir 
--with-mcrypt 
--enable-soap 
--enable-gd-native-ttf 
--enable-ftp 
--enable-mbstring 
--enable-exif 
--with-pear 
--with-curl 
--with-openssl 
--disable-fileinfo  //编译错误之后新加入

编译

make && make install

出错

make: *** [ext/fileinfo/libmagic/apprentice.lo] Error 1

当配置PHP时出现 make: *** [ext/fileinfo/libmagic/apprentice.lo] Error 1 时
是因为服务器内存不足1G。
只需要在配置命令中添加 --disable-fileinfo即可

拷贝主配置文件

cp php.ini-production /usr/local/php-fpm/etc/php.ini

新增配置文件

vim /usr/local/php-fpm/etc/php-fpm.con
[global]  
pid = /usr/local/php-fpm/var/run/php-fpm.pid   
error_log = /usr/local/php-fpm/var/log/php-fpm.log  
include = etc/php-fpm.d/*.conf   //可以自定义pool

拷贝启动脚本

cp /usr/local/src/php-5.6.30/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm

将php-fpm加入到服务列表里

chkconfig --add php-fpm

配置开机启动php-fpm

chkconfig php-fpm on

开启服务器

service php-fpm start

查看进程,服务是否开启

ps aux |grep php-fpm

Nginx安装

./configure --prefix=/usr/local/nginx

给Nginx创建启动脚本

vim /etc/init.d/nginx
#!/bin/bash
# chkconfig: - 30 21
# description: http service.
# Source Function Library
. /etc/init.d/functions
# Nginx Settings
NGINX_SBIN="/usr/local/nginx/sbin/nginx"
NGINX_CONF="/usr/local/nginx/conf/nginx.conf"
NGINX_PID="/usr/local/nginx/logs/nginx.pid"
RETVAL=0
prog="Nginx"
start()
{
echo -n $"Starting $prog: "
mkdir -p /dev/shm/nginx_temp
daemon $NGINX_SBIN -c $NGINX_CONF
RETVAL=$?
echo
return $RETVAL
}
stop()
{
echo -n $"Stopping $prog: "
killproc -p $NGINX_PID $NGINX_SBIN -TERM
rm -rf /dev/shm/nginx_temp
RETVAL=$?
echo
return $RETVAL
}
reload()
{
echo -n $"Reloading $prog: "
killproc -p $NGINX_PID $NGINX_SBIN -HUP
RETVAL=$?
echo
return $RETVAL
}
restart()
{
stop
start
}
configtest()
{
$NGINX_SBIN -c $NGINX_CONF -t
return 0
}
case "$1" in
start)
start
;;
stop)
stop
;;
reload)
reload
;;
restart)
restart
;;
configtest)
configtest
;;
*)
echo $"Usage: $0 {start|stop|reload|restart|configtest}"
RETVAL=1
esac
exit $RETVAL

自定义 nginx.conf文件

user nobody nobody;
worker_processes 2;
error_log /usr/local/nginx/logs/nginx_error.log crit;
pid /usr/local/nginx/logs/nginx.pid;
worker_rlimit_nofile 51200;
events
{
    use epoll;
    worker_connections 6000;
}
http
{
    include mime.types;
    default_type application/octet-stream;
    server_names_hash_bucket_size 3526;
    server_names_hash_max_size 4096;
    log_format combined_realip '$remote_addr $http_x_forwarded_for [$time_local]'
    ' $host "$request_uri" $status'
    ' "$http_referer" "$http_user_agent"';
    sendfile on;
    tcp_nopush on;
    keepalive_timeout 30;
    client_header_timeout 3m;
    client_body_timeout 3m;
    send_timeout 3m;
    connection_pool_size 256;
    client_header_buffer_size 1k;
    large_client_header_buffers 8 4k;
    request_pool_size 4k;
    output_buffers 4 32k;
    postpone_output 1460;
    client_max_body_size 10m;
    client_body_buffer_size 256k;
    client_body_temp_path /usr/local/nginx/client_body_temp;
    proxy_temp_path /usr/local/nginx/proxy_temp;
    fastcgi_temp_path /usr/local/nginx/fastcgi_temp;
    fastcgi_intercept_errors on;
    tcp_nodelay on;
    gzip on;
    gzip_min_length 1k;
    gzip_buffers 4 8k;
    gzip_comp_level 5;
    gzip_http_version 1.1;
    gzip_types text/plain application/x-javascript text/css text/htm
    application/xml;
    include vhost/*.conf;   //新增这一行,定义默认虚拟主机的目录
}

检查一下是否存在语法问题

/usr/local/nginx/sbin/nginx -t

重启服务

/usr/local/nginx/sbin/nginx -s reload

报错:

nginx: [error] invalid PID number "" in "/usr/local/nginx/logs/nginx.pid"

原来服务器没有启动

service nginx start 

更改配置文件权限

chmod 755 /etc/init.d/nginx

将nginx加入到服务列表里

chkconfig --add nginx

配置开启启动nginx服务

chkconfig nginx on

搭建 blog、cms、bbs

下好所需文件
解压,丢解压好的包到/data/wwwroot/目录
为了保证访问,给目录权限

chmod 755 /data/wwwroot/

blog 《Typecho》

配置vhost

vim /usr/local/nginx/conf/vhost/build.conf

内容如下:

server
{
    listen 80 ;
    server_name blog.in-86.com;
    index index.html index.htm index.php;
    root /data/wwwroot/build;

access_log /tmp/build.com.log combined_realip;   //访问日志

        if (!-e $request_filename) {
            rewrite ^(.*)$ /index.php$1 last;    
        }

location ~ \.php(\/.*)*$     
    {
         set $path_info "";
                set $real_script_name $fastcgi_script_name;
                if ($fastcgi_script_name ~ "^(.+?\.php)(/.+)$") {
                        set $real_script_name $1;
                        set $path_info $2;
                }
                fastcgi_param SCRIPT_FILENAME $document_root$real_script_name;
                fastcgi_param SCRIPT_NAME $real_script_name;
                fastcgi_param PATH_INFO $path_info;

        include fastcgi_params;
        fastcgi_pass unix:/tmp/php-fcgi.sock;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME /data/wwwroot/build$fastcgi_script_name;
    }
}

高亮为 Typecho 这个程序的必要配置,如不这样配置会导致管理内页访问404

创建pool配置文件

vim /usr/local/php-fpm/etc/php-fpm.d/blog.conf

内容如下:

[blog]
listen = /tmp/php-fcgi.sock
listen.mode = 666
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024

配置好记得检查语法,重新加载服务

nginx

/usr/local/nginx/sbin/nginx -t
/usr/local/nginx/sbin/nginx -s reload

php-fpm

/usr/local/php-fpm/sbin/php-fpm -t
/etc/init.d/php-fpm reload

关闭selinux防火墙

getenforce  //检查防火墙状态
setenforce 0  //临时关闭
vim /etc/selinux/config  //改配置文件永久关闭

检查iptables

iptables -F
iptables -I INPUT -p tcp --dport 80 -j ACCEP  //放行80
iptables -nvL  //查看规则

netstat -lntp  //查看nginx是否开始监听80端口

检查是否通

curl -x127.0.0.1:80 blog.in-86.com -I

出错:
curl 返回码200,证明本地访问没有问题,但是浏览器访问不到
检查了80端口的连通性
Windows
telnet 主机IP 80
发现80端口不通的,多次检查,才发现域名解析的主机名错了;调整解析的主机名以后,就能正常访问了。

浏览器安装Typecho 再次出现问题。mysql不能进入,不然就进入了创建不了数据库 方法操作很简单,如下:

# /etc/init.d/mysqld stop               //停止MySQL服务的运行
# mysqld_safe --user=mysql --skip-grant-tables --skip-networking & //跳过受权表访问
# mysql -u root mysql                  //登录mysql

在mysql5.7以下的版本如下:

mysql> UPDATE user SET Password=PASSWORD('newpassword') where USER='root' and host='127.0.0.1' or host='localhost';    //把空的用户密码都修改成非空的密码就行了。

在mysql5.7版本如下:

update mysql.user set authentication_string=password('newpassword') where user='root' and host='127.0.0.1' or host='localhost';


mysql> FLUSH PRIVILEGES;
mysql> quit # /etc/init.d/mysqld restart //离开并重启mysql
# mysql -uroot -p
Enter password: <输入新设的密码newpassword> 

这时就能正常进入了

mysql -uroot -p //登录
create database typecho;  //创建数据库
grant all on *.* to root@127.0.0.1 identified by 'newpassword'; 

然后就可以成功的配置 安装Typecho

重Typecho的安装步骤,即可完成discuz、dedecms的安装(mysql除外)数据库统一使用root 密码 newpassword

安装discuz的需要对几个特殊的目录给予写的权限,在解压好所有文件的时候,我就直接执行的chmod 755 -R ,所有就省去了这个步骤(因为是测试,权限的不是特别重要)

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
Java获得今日零时零分零秒的时间(Date型)
publicDatezeroTime()throwsParseException{    DatetimenewDate();    SimpleDateFormatsimpnewSimpleDateFormat("yyyyMMdd00:00:00");    SimpleDateFormatsimp2newS
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这