• 博客园logo
  • 会员
  • 周边
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
坠落的星辰
博客园    首页    新随笔    联系   管理    订阅  订阅

nginx基本概述

nginx

上级回顾:

1.NFS
2.Sersync
3.SSH
	1.ssh使用两种登录服务器的方式,哪两种?
		密码  用户名  +  密码
		秘钥  用户名  +  秘钥(私钥)
		公钥加密  私钥解密 
	
	2.大家常说的 塞key是什么操作?
		我:   发送公钥
		你:   粘贴公钥, 发送主机的IP地址 端口  用户名
		
	3.SSH与跳板机之间有什么关系吗?
		跳板机其实是一个概念, 而需要实现跳板机功能,则要借助ssh协议
		当ssh登录跳板机,在跳板机上使用ssh连接内网  进入登录其他服务器.
		
	4.SSH安全应该怎么做?或者说如何考虑?
		安全隐患:
			内:  达到百分之50%
			外:  攻击  入侵
	
		1.重要的服务,不需要公网IP   (重要!)
		2.有些服务必须需要公网IP?
			1.限制来源的IP必须是防火墙允许的地址
			2.修改端口 + 禁止root直接登录 + 秘钥验证  (不要将私钥提供出去)
		
		3.web应用防火墙:  WAF
	
4.Http协议
	1.url html http 之间的关系?
		url:  资源, 很广泛. (图片\视频\文档) http://fj.xuliangwei.com/public/ks.jpeg
		html: 标记型语言. 将一个又一个的Url资源组织在一起,形成一个网状结构,简称web网页
		http: http是web数据交互的一个基础. 将服务端的html文件传输至客户端的浏览器.

		URL 组成部分:
			协议   http://
			域名   fj.xuliangwei.com  
			端口   80
			路径   /public/ks.jpeg    ----> Uri
	
	2.http工作原理?   输入一个网站的整个过程?
		1.用户通过浏览器输入URL
		2.浏览器会有缓存  Cache
		3.DNS解析
			hosts文件
		4.DNS返回
		5.浏览器与服务端建立TCP的连接   10.0.0.1  45678  --> 10.0.0.7 80
		6.浏览器与服务端发起http的请求  
			请求的域名Host: 		www.oldboyedu.com
			请求的方法method:		GET
			请求的路径Path:			/
			请求的参数parameter:
				压缩
				缓存
				语言
				....
			请求的设备user-agent:
				手机
					IOS
					Android
					塞班
				浏览器
					google
					360
					ie
			
			请求空行
			
		7.服务端响应Headers
			响应Headers:
			响应的空行:
			响应的主体:
			
			响应的状态码: 
				200
				301
				302
				401
				403
				404
				500
				502
				503
				504
			响应的服务类型:  Nginx Apache
			.............
			
		8.tcp四次挥手

	5.http长连接,短连接?
	7.http术语 pv uv ip 并发?
		pv: 200w	页面浏览量   100 
		uv: 50w		独立设备     1
		ip: 20w		独立IP数	 
		并发: 		单位时间内的请求数
	8.游戏公司,区别对待? 在线用户数  日活跃数 月活跃数

1、介绍nginx

Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,
Nginx 是一个很强大的高性能Web和反向代理服务,它具有很多非常优越的特性:
在连接高并发的情况下,Nginx是Apache服务不错的替代品:Nginx在美国是做虚拟主机生意的老板们经常选择的软件平台之一。能够支持高达 50,000 个并发连接数的响应,感谢Nginx为我们选择了 epoll and kqueue作为开发模型。

Nginx作为负载均衡服务:Nginx 既可以在内部直接支持 Rails 和 PHP 程序对外进行服务,也可以支持作为 HTTP代理服务对外进行服务。Nginx采用C进行编写,不论是系统资源开销还是CPU使用效率都比 Perlbal 要好很多。

2、常见的web服务器

最常用的Web服务器是Apache和Microsoft的Internet信息服务器(Internet Information Services,IIS)。
Internet上的服务器也称为Web服务器,是一台在Internet上具有独立IP地址的计算机,可以向Internet上的客户机提供WWW、Email和FTP等各种Internet服务。

Web服务器是指驻留于因特网上某种类型计算机的程序。当Web浏览器(客户端)连到服务器上并请求文件时,服务器将处理该请求并将文件反馈到该浏览器上,附带的信息会告诉浏览器如何查看该文件(即文件类型)。服务器使用HTTP(超文本传输协议)与客户机浏览器进行信息交流,这就是人们常把它们称为HTTP服务器的原因。
Web服务器不仅能够存储信息,还能在用户通过Web浏览器提供的信息的基础上运行脚本和程序。

协议:
    应用层使用HTTP协议。
    HTML(标准通用标记语言下的一个应用)文档格式。
    浏览器统一资源定位器(URL)。
    为了解决HTTP协议的这一缺陷,需要使用另一种协议:安全套接字层超文本传输协议HTTPS。为了数据传输的安全,HTTPS在HTTP的基础上加入了SSL协议,SSL依靠证书来验证服务器的身份,并为浏览器和服务器之间的通信加密。

3、介绍nginx应用场景

1.代理
2.负载均衡
3.代理缓存   (proxy_cache)
4.静态资源
5.动静分离
6.Https
冰山模型中的一角  ---> 还有很多个使用场景

4、nginx 安装 配置启动

第一种:源码安装
第二种:yum --> 官方仓库 新 配置容易入手
第三种:yum --> epel仓库 旧 配置比较复杂
#1、安装官方仓库源
[root@web01 ~]# cat /etc/yum.repos.d/nginx.repo 
[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key

#2、使用yum直接安装
[root@web01 ~]# yum install nginx -y

#3、启动nginx
[root@web01 ~]# systemctl restart nginx
[root@web01 ~]# systemctl enable nginx 

5、nginx 配置

[root@web01 ~]# cat /etc/nginx/nginx.conf

user  nginx;									# nginx进程的用户身份
worker_processes  1;							# nginx的工作进程数量
error_log  /var/log/nginx/error.log warn;		# 错误日志的路径 [警告级别才会记录]
pid        /var/run/nginx.pid;					# 进程运行后,会产生一个pid


events {										# 事件模型
    worker_connections  1024;					# 每个work能够支持的连接数
	use epoll;									# 使用epoll网络模型
}


http {											# 接收用户的http请求
    include       /etc/nginx/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"';

    access_log  /var/log/nginx/access.log  main;	# 访问日志的路径
    #sendfile        on;
    #tcp_nopush     on;
    keepalive_timeout  65;		#长链接超时时间
    #gzip  on;					#启用压缩功能
	
	
	#使用Server配置网站, 每个Server{}代表一个网站
	server {
		listen 80;
		server_name test.oldxu.com;
		
		location / {					#控制网站访问的路径
			root ...;
		}
	}

    include /etc/nginx/conf.d/*.conf;		包含哪些文件
}


PS: Nginx中的http、server、location之间的关系是?
http       标签主要用来解决用户的请求与响应。
server     标签主要用来响应具体的某一个网站。
location   标签主要用于匹配网站具体url路径。

http{} 层下允许有多个Server{},可以有多个网站.
一个Server{} 下又允许有多个location{}	每个网站的uri路径不同,所以要分别进行匹配.

6、nginx 搭建游戏网站

#1.注释掉之前的默认网站
[root@web01 html]# cd /etc/nginx/conf.d/
[root@web01 conf.d]# gzip default.conf 

#2.编写游戏网站Nginx配置文件
[root@web01 conf.d]# cat game.oldxu.com.conf 
server {
	listen 80;			#该网站提供访问的端口
	server_name game.oldxu.com;	#访问该网站的域名
	
	location / {
		root /code;
		index index.html;
	}
}

#3.根据Nginx的配置文件,初始化
[root@web01 conf.d]# mkdir /code

#4.上传代码
[root@web01 conf.d]# cd /code/
[root@web01 code]# rz html5.zip
[root@web01 code]# unzip html5.zip 

#5.检测语法
[root@web01 code]# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful


#6.重载服务
[root@web01 code]# systemctl restart nginx

#7.配置域名解析

#8.Nginx访问的整体流程

http://    game.oldxu.com     /      game/yibihua/index.html

请求的uri:		/game/yibihua/index.html
真实映射位置:   /code/game/yibihua/index.html


#9.Nginx 搭建 多个游戏网站  ---> 虚拟主机

	虚拟主机:  在一台服务器上运行多套网站

Nginx配置虚拟主机有如下三种方式:

方式一、基于主机多IP方式					10.0.0.7  172.16.1.7
方式二、基于端口的配置方式					80 81 82 83
方式三、基于名称方式(多域名方式)			test1 test2 test3		<---推荐

#方式一、基于主机多IP方式
[root@web01 conf.d]# cat ip_eth0.conf 
server {
	listen 10.0.0.7:80;
	location / {
		root /ip1;
		index index.html;
	}
}
server {
	listen 172.16.1.7:80;
	location / {
		root /ip2;
		index index.html;
	}
}
[root@web01 conf.d]# mkdir /ip1 /ip2
[root@web01 conf.d]# echo "10...." > /ip1/index.html
[root@web01 conf.d]# echo "172...." > /ip2/index.html
[root@web01 conf.d]# systemctl restart nginx

#测试访问
[root@web01 ~]# curl http://10.0.0.7
10.... 
[root@web01 ~]# curl http://172.16.1.7
172....

#方式二、基于端口的配置方式	  81 82 83
	公司内部有多套系统,希望部署在一台服务器上, 而内网又没有域名.
	所以,我们可以通过相同IP,不同的端口,访问不同的网站页面.
[root@web01 conf.d]# cat port.conf 
server {
	listen 81;

	location / {
		root /81;
		index index.html;
	}
}

server {
	listen 82;

	location / {
		root /82;
		index index.html;
	}
}

server {
	listen 83;

	location / {
		root /83;
		index index.html;
	}
}
[root@web01 conf.d]# mkdir /81 /82 /83
[root@web01 conf.d]# echo "81" > /81/index.html
[root@web01 conf.d]# echo "82" > /82/index.html
[root@web01 conf.d]# echo "83" > /83/index.html


	三个网站运行在同一台服务器,只需要通过不同的域名来实现访问:
		game
		wzq
		tk
	
io网络模型:
	同步
	异步
	阻塞
	非阻塞
	同步阻塞
	同步非阻塞
	异步阻塞
	异步非阻塞
posted @ 2019-12-23 20:08  坠落的星辰  阅读(496)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3