01 - nginx - 安装、配置文件、默认网站、虚拟主机

时间:2022-01-08 20:17:45

一、运维:

01 - nginx - 安装、配置文件、默认网站、虚拟主机

  . 介绍服务器。
服务器逻辑:
服务器选择
操作系统
部署逻辑 业务环境部署逻辑
业务部署图
软件部署文档
日常维护文档 测试
开发上传代码到源码系统
上线 - 测服务器,内测
预发布测试,公测 上线
产品需求确认
产品研发确认
产品测试确认
产品流程文档
跟踪统计用户反馈情况 . 架构部署,自测环境,预生产环境,生产环境。

二、Nginx:

    Apache: 消耗资源
Nginx介绍:
轻量级的WEB服务器,和反向代理服务器
延伸版本tengine(淘宝)、openresrt(章亦春)等
官网:http://nginx.org
中文文档:http://www.nginx.cn/doc/index.html Nginx管理
Nginx优化
Nginx负载均衡
Nginx缓存 环境:
. Vmware虚拟机 2核4G
. 网卡:桥接
. centos7.
. 防火墙:关闭
. Selinux:关闭
. 网段:192.168.10.0/ 主机名 IP 角色
Master.ayiltuan.com 192.168.10.40 主分发器
Backup.aliltuan.com 192.168.10.41 备分发器
Web01.ayituan.com 192.168.10.42 数据服务器1
Web02.ayituan.com 192.168.10.43 数据服务器2 Nginx目录:
安装
相关目录介绍
启动
验证测试

三、Nginx的安装:

   http://nginx.org

    、Nginx安装
1.1)获得软件 wget http://nginx.org/download/nginx-1.15.5.tar.gz -P /usr/src
1.2)安装前准备 cd /usr/src tar xf nginx-1.15..tar.gz
cd nginx-1.15. yum -y install gcc pcre-devel zlib zlib-devel 1.3)配置
)检查环境 是否 满足安装条件 依赖解决
)指定安装方式 配置文件 命令文件 各种文件放哪里 开启模块功能【内 置模块 三方模块】
)指定软件安装在那里 ./configure --prefix=/usr/local/nginx 1.4)编译 使用gcc将源码生成可执行程序
make -j4 1.5)安装
make install 、相关目录
nginx path prefix: "/usr/local/nginx"
nginx binary file: "/usr/local/nginx/sbin/nginx"
nginx modules path: "/usr/local/nginx/modules"
nginx configuration prefix: "/usr/local/nginx/conf"
nginx configuration file: "/usr/local/nginx/conf/nginx.conf"
nginx pid file: "/usr/local/nginx/logs/nginx.pid"
nginx error log file: "/usr/local/nginx/logs/error.log"
nginx http access log file: "/usr/local/nginx/logs/access.log" 、Nginx启动
/usr/local/nginx/sbin/nginx 、验证
netstat –ntpl
lsof -i :
yum -y install lsof 、浏览器测试
elinks
文本界面浏览器
elinks http://192.168.10.42 --dump 百度:(方法比技能更重要!)

01 - nginx - 安装、配置文件、默认网站、虚拟主机

四、Nginx的配置文件:

/usr/local/nginx/conf/nginx.conf

    #启动子进程程序默认用户
#user nobody;
#一个主进程和多个工作进程。工作进程是单进程的,且不需要特殊授权即可运行;这里定义的是工作进程数量
worker_processes 1; #全局错误日志的位置及日志格式
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info; #pid logs/nginx.pid; events {
#每个工作进程最大的并发数
worker_connections 1024;
} #http服务器设置
http {
#设定mime类型,类型由mime.type文件定义
include mime.types; #
default_type application/octet-stream; #日志格式
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#$remote_addr与$http_x_forwarded_for用以记录客户端的ip地址;
#$remote_user:用来记录客户端用户名称;
#$time_local: 用来记录访问时间与时区;
#$request: 用来记录请求的url与http协议;
#$status: 用来记录请求状态;成功是200,
#$body_bytes_sent :记录发送给客户端文件主体内容大小;
#$http_referer:用来记录从那个页面链接访问过来的;
#$http_user_agent:记录客户浏览器的相关信息; #全局访问日志路径
#access_log logs/access.log main;
#sendfile指令指定 nginx 是否调用sendfile 函数(zero copy 方式)来输出文件,对于普通应用,必须设为on。如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络IO处理速度,降低系统uptime。
sendfile on; #此选项允许或禁止使用socke的TCP_CORK的选项,此选项仅在使用sendfile的时候使用
#tcp_nopush on; #长连接超时时间
#keepalive_timeout 0;
keepalive_timeout 65; #开启压缩
#gzip on; #配置虚拟主机
server {
#虚拟主机使用的端口
listen 80;
#虚拟主机域名
server_name localhost; #虚拟主机支持的字符集
#charset koi8-r; #虚拟主机的访问日志路径
#access_log logs/host.access.log main; #定义web根路径
location / {
#根目录路径
root html;
#索引页
index index.html index.htm;
} #error_page 404 /404.html; # redirect server error pages to the static page /50x.html
# #根据错误码 返回对应的页面
error_page 500 502 503 504 /50x.html; #定义页面路径
location = /50x.html {
root html;
} #定义反向代理服务器 数据服务器是lamp模型
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#} #定义PHP为本机服务的模型
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ \.php$ {
# root html;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
# include fastcgi_params;
#} # deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#拒绝apache DR目录及子目录下的.htaccess文件访问
#location ~ /\.ht {
# deny all;
#}
} # another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
# listen 8000;
# listen somename:8080;
# server_name somename alias another.alias; # location / {
# root html;
# index index.html index.htm;
# }
#} #https的配置方案
# HTTPS server
#
#server {
# listen 443 ssl;
# server_name localhost; # ssl_certificate cert.pem;
# ssl_certificate_key cert.key; # ssl_session_cache shared:SSL:1m;
# ssl_session_timeout 5m; # ssl_ciphers HIGH:!aNULL:!MD5;
# ssl_prefer_server_ciphers on; # location / {
# root html;
# index index.html index.htm;
# }
#} }

操作验证:

useradd -s /sbin/nologin -r www   # 创建一个 www用户

#启动子进程程序默认用户
#user nobody;   # www

worker_processes 1; # 有几个核,就写几个 4

killall nginx
  yum search killall
  yum -y install psmisc

/usr/local/nginx/sbin/nginx
lsof -i :80

实现了负载均衡;每个工作进程下:最多1024个并发数;

01 - nginx - 安装、配置文件、默认网站、虚拟主机

五、Nginx默认网站、访问控制、登录验证、日志管理、防盗链、日志截断

../sbin/nginx -g ../conf/nginx.conf
验证是否 ok 在重启

关了,在重启:
  killall nginx
  /usr/local/nginx/sbin/nginx

重启:
  killall -s HUP nginx

    1、默认网站
当Nginx配置⽂文件中有且只有只一个Server的时候,该Server就被Nginx认为是默认网站,
所有发给Nginx服务器80端⼝口的数据都会默认给该Server. server {
listen 80;
server_name localhost;
location / {
root html;
index index.html index.htm;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
} 2、访问控制
location /a {
allow 192.168.1.0/24;
deny all;
#return 404;
return http://www.jd.com; } 3、登陆验证
auth_basic 语法: auth_basic string | off; 默认值: auth_basic off;
auth_basic_user_file file; location /b { auth_basic ”登陆验证";
auth_basic_user_file /etc/nginx/htpasswd; } 4、日志管理
Nginx访问日志主要有两个参数控制 log_format
log_format #用来定义记录日志的格式(可以定义多种日志格式,取不同名字即 可) access_log
#用来指定日至文件的路径及使用的何种日志格式记录日志 access_log logs/access.log main; log_format格式变量:
$remote_addr #记录访问网站的客户端地址
$remote_user #远程客户端用户名
$time_local #记录访问时间与时区
$request #用户的http请求起始行信息
$status #http状态码,记录请求返回的状态码,例如:200、301、404等
$body_bytes_sent #服务器发送给客户端的响应body字节数
$http_referer #记录此次请求是从哪个连接访问过来的,可以根据该参数进 行防盗链设置。
$http_user_agent #记录客户端访问信息,例如:浏览器、手机客户端等
$http_x_forwarded_for #当前端有代理服务器时,设置web节点记录客户端 地址的配置,此参数生效的前提是代理服务器也要进行相关的x_forwarded_for设置 案例
自定义一个json格式的访问日志
log_format main_json '{"@timestamp":"$time_local",'
'"client_ip": "$remote_addr",'
'"request": "$request",'
'"status": "$status",'
'"bytes": "$body_bytes_sent",'
'"x_forwarded": "$http_x_forwarded_for",'
'"referer": "$http_referer"' '}'; access_log logs/access_json.log main_json; 5、防盗链
location /images/ {
alias /data/images/;
valid_referers none blocked *.ayitula.com;
if ($invalid_referer) {
rewrite ^/ http://www.ayitula.com/daolian.gif;
#return 403;
}
} 6、日志截断
mv access.log access.log.0
killall -USR1 `cat master.nginx.pid`
sleep 1
gzip access.log.0

六、Nginx虚拟主机

就是把一台物理服务器划分成多个“虚拟”的服务器,每一个虚拟主机都可以有独立的域名和独立的目录
同时发布两个网站:
  DocumentRoot /usr/local/nginx/html/web1
  DocumentRoot /usr/local/nginx/html/web2

    1、基于IP的虚拟主机 

        实现条件:
1) 两个IP
2)DR 存在
3)索引页 index.html
#每个网站都需要一个IP
#缺点 需要多个IP 如果是公网IP 每个IP都需要付费 逻辑网卡,添加子网卡
ifconfig
ifconfig ens33:1 192.168.10.52/24 up mkdir /usr/local/nginx/html/web1
mkdir /usr/local/nginx/html/web2 echo web1 > mkdir /usr/local/nginx/html/web1/index.html 配置:
server {
listen 192.168.10.42:80;
location / {
root html/web1;
index index.html index.htm index.php;
} } server {
listen 192.168.10.52:80;
location / {
root html/web2;
index index.html index.htm;
} } 运行:
../sbin/nginx -g nginx.conf # 测试一下。才能关掉,在启动。
killall nginx ../sbin/nginx # 启动
netstat -ntpl # 查看已经启动得进程 测试:
elinks http://192.168.10.42 --dump
elinks http://192.168.10.52 --dump
ok 2、基于端口的虚拟主机 #只需要一个IP
#缺点 端口你是无法告诉公网用户 无法适用于公网客户 适合内部用户 ifconfig ens33:1 down 配置:
server {
listen 80;
#server_name www.abc.com;
location / {
root html/web1;
index index.html index.htm index.php;
} } server {
listen 8080;
#server_name www.abc.com;
location / {
root html/web2;
index index.html index.htm;
} } 启动:
../sbin/nginx -g nginx.conf # 测试一下。才能关掉,在启动。
killall nginx
netstat -ntpl 测试:
elinks http://192.168.10.42 --dump # 没加端口,默认是80
elinks http://192.168.10.42:8080 --dump 3、基于域名的虚拟主机 一个网站必然有一个域名
配置:
vim /etc/hosts
。。。
192.168.10.42 www.abc.com
192.168.10.42 www.cbd.com
server {
listen 80;
server_name www.abc.com;
location / {
root html/web1;
index index.html index.htm index.php;
} } server {
listen 80;
server_name www.cbd.com;
location / {
root html/web2;
index index.html index.htm;
} } 测试:
elinks www.abc.com --dump # 没加端口,默认是80
elinks www.cbd.com --dump

01 - nginx - 安装、配置文件、默认网站、虚拟主机的更多相关文章

  1. 【nginx运维基础(2)】Nginx的配置文件说明及虚拟主机配置示例

    配置文件说明 #定义Nginx运行的用户和用户组 user www www; #nginx进程数,建议设置为当前主机的CPU总核心数. worker_processes 8; #全局错误日志定义类型, ...

  2. nginx笔记 安装nginx 配置 反向代理 多虚拟主机

    1,检测linux上是否 通过yum安装了nginxrpm   -qi  nginx 2.安装nginx之前的依赖包yum install gcc patch libffi-devel python- ...

  3. Nginx 反向代理 负载均衡 虚拟主机配置

    Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代理服务器的作用,区分正向代理和反向代理的区别,搭建使用Nginx反向搭理和负载均衡,了解Nginx常 ...

  4. Nginx 反向代理 负载均衡 虚拟主机

    Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代理服务器的作用,区分正向代理和反向代理的区别,搭建使用Nginx反向搭理和负载均衡,了解Nginx常 ...

  5. 【转】Nginx 反向代理 负载均衡 虚拟主机配置

    原文:http://www.cnblogs.com/itdragon/p/8059000.html Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代 ...

  6. nginx安装配置并布置网站

    之前做的网站都是用的apache,关于apache和Nginx的区别也不说了,百度上也都有,而且apche和nginx可以共存,这个之后再说. 首先安装nginx,我用的云主机,直接用yum安装 #y ...

  7. Nginx(http协议代理 搭建虚拟主机 服务的反向代理 在反向代理中配置集群的负载均衡)

    Nginx 简介 Nginx (engine x) 是一个高性能的 HTTP 和反向代理服务.Nginx 是由伊戈尔·赛索耶夫为俄罗斯访问量第二的 Rambler.ru 站点(俄文:Рамблер)开 ...

  8. Nginx安装、默认虚拟主机、Nginx用户认证和域名重定向

    6月7日任务 12.6 Nginx安装12.7 默认虚拟主机12.8 Nginx用户认证12.9 Nginx域名重定向 扩展nginx.conf 配置详解 http://www.ha97.com/51 ...

  9. Linux centosVMware Nginx安装、 默认虚拟主机、Nginx用户认证、Nginx域名重定向

    一. Nginx安装 cd /usr/local/src wget http://nginx.org/download/nginx-1.12.1.tar.gz 版本在http://nginx.org/ ...

随机推荐

  1. 恢复SharePoint Server 2013 中的“新颖快建视图”

    初始化后就很漂亮的"新颖快建视图" 在配置好了OWA(Office Web Apps)的环境下,可以使用独特的"新颖快建视图"新建文件与文件夹,如下图所示: F ...

  2. 自己写了一个无缝滚动的插件(jQuery)

    效果图: html代码: 1 <h1>无缝滚动,向右滚动</h1> 2 <ul id="guoul1"> 3 <li><img ...

  3. c&num;实现数据集合转换为csv文本

    需求 1.将一个数据集合导出到一个csv文件中,集合类型可以视为 List<T>,T为任意类型,T包含多个属性,可指定部分属性进行导出 2.软件中有多种不同类型的数据类型需要进行导出 需求 ...

  4. iOS 的一点理解(一) 代理delegate

    做了一年的iOS,想记录自己对知识点的一点理解. 第一篇,想记录一下iOS中delegate(委托,也有人称作代理)的理解吧. 故名思议,delegate就是代理的含义, 一件事情自己不方便做,然后交 ...

  5. 安装tensorflow

    官网:http://tensorflow.org/安装步骤:1.sudo apt-get install python-pip python-dev python-virtualenv 3    co ...

  6. 通过虚拟机VMware来练习安装ESXi

    关于VMware vSphere组件ESXi,大家请自行百度.大概的意思我简单的先理解为这个组件是通过在服务器上安装上ESXi系统,继而虚拟化整个服务器的硬件资源为之后虚拟各种客户端所用.相比较大家较 ...

  7. jquery中&colon;input和input的区别分析

    :input表示选择表单中的input,select,textarea,button元素,input仅仅选择input元素. <html> <head> <style&g ...

  8. 论文笔记:Fast&lpar;er&rpar; RCNN

    在 RCNN 初步试水取得成功后,研究人员又迅速跟进,针对 RCNN 中的几点不足提出改进,接连推出了 fast-rcnn 和 faster-rcnn.关于这两篇论文,网上相关的文章实在是多如牛毛,因 ...

  9. 我永远爱着OOP——第二单元作业总结

    第二单元的电梯真是愉♂快呢,多线程编程作为java编程OOP中的重要组成部分,通过这一个单元的学习,我也是有了很多全新的认识 那么下面就先例行一下公事 三次作业分析 第五次作业 设计分析 实现的电梯是 ...

  10. 互斥量、条件变量与pthread&lowbar;cond&lowbar;wait&lpar;&rpar;函数的使用,详解&lpar;二&rpar;

    1.Linux“线程” 进程与线程之间是有区别的,不过linux内核只提供了轻量进程的支持,未实现线程模型.Linux是一种“多进程单线程”的操作系统.Linux本身只有进程的概念,而其所谓的“线程” ...