Nginx网站服务与搭建

Nginx网站服务

优点 承载量高

Nginx服务基础
Nginx访问控制
Nginx虚拟主机
LNMP架构部署及应用

一款高性能、轻量级Web服务软件
稳定性高
系统资源消耗低
对HTTP并发连接的处理能力高
单台物理服务器可支持 30000 - 50000 个并发请求包

搭建Nginx服务

搭建环境

先放入环境包:

在这里插入图片描述

开始:

关闭防火墙:

	systemctl stop firewalld
	setenforce 0

在这里插入图片描述

安装依赖包:

	yum -y install  pcre-devel  zlib-devel

在这里插入图片描述
装完之后 创建一个不可登录用户

	useradd -M -s /sbin/nologin nginx

解压缩

	tar zxvf nginx-1.12.2.tar.gz

在这里插入图片描述

进入 nginx
然后开始配置

	cd nginx-1.12.2/
	./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module

这两个地方别打错

在这里插入图片描述

在这里插入图片描述

安装:

	make && make install

在这里插入图片描述

装完之后开始链接:

ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin

在这里插入图片描述

配置文件和语法检查:

	nginx -t

在这里插入图片描述
syntax is ok 语法已经通过
test is successful 前面是配置 意思测试通过

尝试服务的启动:
nginx 开启服务
netstat -anpt | grep nginx 查看服务是否启动

在这里插入图片描述
killall -1 nginx 安全重启
killall -3 nginx 停止服务

在这里插入图片描述

为了方便管理nginx 创建一个脚本
vi /etc/init.d/nginx

脚本内容:

#!/bin/bash
#chkconfig: 35 80 20
#description: Nginx HTTP Server
PROG="/usr/local/nginx/sbin/nginx"
PIDF="/usr/local/nginx/logs/nginx.pid"
case "$1" in
start)
$PROG
;;
stop)
kill -s QUIT $(cat $PIDF)
;;
restart)
$0 stop
$0 start
;;
reload)
kill -s HUP $(cat $PIDF)
;;
*)
	echo "Usage: $0 {start|stop|restart|reload}"
	exit 1
	esac
	eixt 0

在这里插入图片描述

	chmod +x /etc/init.d/nginx  
	chkconfig --add nginx

如果他提示 nginx不支持chkongif那就是你脚本配置前面几句话写错了在这里插入图片描述
在这里插入图片描述

检查一下服务:

chkconfig --list

在这里插入图片描述
配置建个链接 然后修改配置:

ln -s /usr/local/nginx/conf/nginx.conf /etc/  
vi /etc/nginx.conf

在这里插入图片描述
修改配置:

在这里插入图片描述

在这里插入图片描述
这里会给警告
超过资源数的限制 1024 因为我们写的 4096
在这里插入图片描述
怎么解决呢
进入:

ulimit -n

然后重定向

	ulimit -n 65535 >> /etc/rc.local

在这里插入图片描述

现在再查看一下,修改成功

ulimit -n

在这里插入图片描述
开启统计模块功能
定义一下

vi /etc/nginx.conf

添加这个

location ~ /status{
stub_status on;
access_log off;
}

在这里插入图片描述
然后重启服务

systemctl stop nginx
systemctl start nginx

提示错误。

在这里插入图片描述

开始检查问题
查看问题详细输入:

systemctl status nginx.service -l

在这里插入图片描述

然后进入 /etc/rc.d/init.d/nginx
发现 exit 写成了 eixt 修改后 保存
在这里插入图片描述
然后启动nginx 发现要重新加载 就重新加载一下
再开启nginx服务 就可以了

在这里插入图片描述
用浏览器访问IP地址
192.168.100.111

在这里插入图片描述
再去看统计模块 IP地址后面加status

在这里插入图片描述
进入 /usr/local/nginx/logs查看

	cd /usr/local/nginx/logs
	ll

在这里插入图片描述
就会看到

在这里插入图片描述
进入 查看访问的情况

	vi chen.com.access.log

在这里插入图片描述

验证nginx:

yum install httpd-tools

在这里插入图片描述

htpasswd -c /usr/local/nginx/passwd.db  chen
这里密码设的是 159357

在这里插入图片描述
设置权限

chown nginx /usr/local/nginx/passwd.db

编辑配置文件 启用认证功能 在根目录加授权方式

vi /etc/nginx.conf

auth_basic "secret";
auth_basic_user_file /usr/local/nginx/passwd.db;

在这里插入图片描述
重启nginx 先检查语法

在这里插入图片描述
进入浏览器 访问 主机IP
在这里插入图片描述
chen
159357

可以访问
在这里插入图片描述
限制用户不可登录
vi /etc/nginx.conf

allow all;
deny IP

在这里插入图片描述

重启服务 访问IP 发现也可以访问 因为 他执行顺序 先允许所有 再拒绝 nginx和apache不一样 apche这样 是拒绝 但是 nginx是允许的
在这里插入图片描述

在这里插入图片描述
把 执行顺序 变一下 就不允许了

在这里插入图片描述

在这里插入图片描述
接下来还要做其他功能 把这四行删掉

在这里插入图片描述

配置虚拟主机

基于域名配置

虚拟主机和站点同时配的话 虚拟主机启动了 会优先访问虚拟主机

进入配置 vi /etc/nginx.conf
修改配置

在这里插入图片描述

在这里插入图片描述

检查语法 重启服务

在这里插入图片描述
创建文件
mkdir -p /var/www/chen
mkdir -p /var/www/yu
echo “

this is server chen site.

” > /var/www/chen/index.html
echo “

this is server yu site.

” > /var/www/yu/index.html

在这里插入图片描述

ifconfig ens33:1 192.168.100.122/24

在这里插入图片描述
进入配置 添加配置

vi  /etc/nginx.conf

在这里插入图片描述

在这里插入图片描述

检查语法
在这里插入图片描述
重启服务 访问IP

在这里插入图片描述
基于端口

进配置改端口
在这里插入图片描述
在这里插入图片描述
虚拟主机结束 后面用不着 进入配置删掉

末尾删除的 只剩一个括弧
在这里插入图片描述

在这里插入图片描述

然后重启 服务
创建 安装MySQL服务
安装依赖包

在这里插入图片描述
创建运行用户:

在这里插入图片描述
编译安装
解压缩
在这里插入图片描述

cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DSYSCONFDIR=/etc \
-DSYSTEMD_PID_DIR=/usr/local/mysql \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DWITH_BOOST=boost \
-DWITH_SYSTEMD=1

在这里插入图片描述
make && make install
数据库很慢 要等等
在这里插入图片描述

安装完后
chown -R mysql:mysql /usr/local/mysql/

vi /etc/my.cnf
[client]
port = 3306
default-character-set = utf8
socket = /usr/local/mysql/mysql.sock
[mysql]
port = 3306
default-character-set = utf8
socket = /usr/local/mysql/mysql.sock
[mysqld]
user = mysql
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
port = 3306
character_set_server = utf8
pid-file = /usr/local/mysql/mysqld.pid
socket = /usr/local/mysql/mysql.sock
server-id = 1

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES

chown mysql:mysql /etc/my.cnf
cd /usr/local/mysql/lib/p
echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile
echo 'export PATH' >> /etc/profile
tail -5 /etc/profile
source /etc/profile

echo $PATH
mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data


在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

开启服务 开机自启动
在这里插入图片描述

可以尝试登录

在这里插入图片描述

安装PHP解析环境

yum -y install libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel curl curl-devel openssl openssl-devel

在这里插入图片描述
解压缩

在这里插入图片描述
./configure --prefix=/usr/local/php --with-mysql-sock=/usr/local/mysql/mysql.sock --with-mysqli --with-zlib --with-curl --with-gb --with-jpeg-dir --with-png-dir --with-freetype-dir --with-openssl --enable-fpm --enable-mbstring --enable-xml --enable-session --enable-ftp --enable-pdo --enable-tokenizer --enable-zip

在这里插入图片描述
编译安装

make && make install

配置文件编辑

cp php.ini-development /usr/local/php/lib/php.ini
vi /usr/local/php/lib/php.ini   
/usr/local/php/bin/php -m | wc -l

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
配置及优化FPM模块

[root@localhost php-7.1.10]# cd
[root@localhost ~]# cd /usr/local/php/etc/
[root@localhost etc]# cp php-fpm.conf.default php-fpm.conf
[root@localhost etc]# cd /usr/local/php/etc/php-fpm.d/
[root@localhost php-fpm.d]# cp www.conf.default www.conf
[root@localhost php-fpm.d]# cd /usr/local/php/etc/
[root@localhost etc]# vi php-fpm.conf
[root@localhost etc]# 

在这里插入图片描述
启动fpm模块

/usr/local/php/sbin/php-fpm -c /usr/local/php/lib/php.ini
netstat -anpt | grep 9000

在这里插入图片描述
创建链接
在这里插入图片描述

让Nginx支持PHP功能

编辑配置文件
vi /etc/nginx.conf
重启服务

在这里插入图片描述
创建PHP网页

	vi /usr/local/nginx/html/index.php

在这里插入图片描述

访问 IP/index.php

在这里插入图片描述
测试数据库工作是否正常
配置数据库
mysql
mysql> create database bbs;
mysql> grant all privileges on bbs.* to ‘bbsuser’@‘localhost’ identified by ‘admin123’;
mysql> grant all privileges on bbs.* to ‘bbsuser’@’%’ identified by ‘admin123’;
mysql> flush privileges;

在这里插入图片描述
配置PHP网页

在这里插入图片描述

浏览器访问IP
访问成功说明PHP具有访问MySQL数据库的权限
在这里插入图片描述

部署Discuz 社区论坛 Web应用

解压缩

在这里插入图片描述

[root@localhost ~]# cd dir_SC_UTF8/
[root@localhost dir_SC_UTF8]# cp -r upload/ /usr/local/nginx/html/bbs
[root@localhost dir_SC_UTF8]# cd /usr/local/nginx/html/bbs/

在这里插入图片描述
在这里插入图片描述
给权限
在这里插入图片描述
浏览器访问
IP/bbs/install/index.php

只能安装一次。。。要注意
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

访问IP/bbs/index.php
在这里插入图片描述

设置安装目录仅自己可见

cd /usr/local/nginx/html/bbs/
ll
在这里插入图片描述

mv install/ install.lock
chmod 600 install.lock/
ll
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值