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.htmlecho “
this is server yu site.
” > /var/www/yu/index.htmlifconfig 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