Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。
其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、简单的配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。
Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等
1.正向代理
在客户端(浏览器)配置代理服务器,通过代理服务器进行互联网的访问
2.反向代理
讲请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据后,在返回给客户端,此时反向代理服务器和目标服务器对外就是一个服务器,暴漏的是代理服务器的地址,隐藏了真实服务器的ip
为了加快网站解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析速度,降低原来单个服务器的压力
把动态资源和静态资源分开来访问,减缓了访问单个服务器的压力
docker pull nginx:1.17.8
docker images
使用的外部链接端口未9091,80端口留在后面挂载
sudo docker run --name nginx -p 9091:80 -d nginx:1.17.8
docker ps
http://39.105.82.148:9091
参数含义
–rm:容器终止运行后,自动删除容器文件。
–name nginx-test:容器的名字叫做nginx-test,名字自己定义.
-p: 端口进行映射,将本地 8080 端口映射到容器内部的 80 端口
-d:容器启动后,在后台运行
# 创建www目录
mkdir -p /server/nginx/html
# 创建日志目录
mkdir -p /server/nginx/logs
# 创建配置目录
mkdir -p /server/nginx/conf
html: 目录将映射为 nginx 容器配置的虚拟目录。
logs: 目录将映射为 nginx 容器的日志目录。
conf: 目录里的配置文件将映射为 nginx 容器的配置文件。
windows宿主机访问centOS7虚拟机中的docker服务
问题描述:在笔记本windows10中,centos7虚拟机运行了docker nginx容器,但是windows10的浏览器无法访问docker中的Nginx服务。
问题解决:1、虚拟机命令:ifconfig
查看docker容器的网段、centos的IP地址:
docker容器的网段为:172.17.0.0 centos虚拟机的IP地址为:192.168.158.10
管理员身份打windows10的dos窗口,或者运行-CMD
添加如下路由:C:\windows\system32>ROUTE -p add 172.17.0.0 mask 255.255.0.0 192.168.158.10
1.拷贝容器内 Nginx
默认配置文件到本地当前目录下的 conf 目录,容器ID可以查看 docker ps 命令输入中的第一列
[root@docker html]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
ef0dc2b26ab0 nginx "/docker-entrypoint.…" 13 minutes ago Up 13 minutes 0.0.0.0:80->80/tcp nginx-test-web
93292199bc47 nginx:1.17.8 "nginx -g 'daemon of…" About an hour ago Up About an hour 0.0.0.0:9091->80/tcp nginx
9a0767c57853 5726af297dd4 "docker-entrypoint.s…" 2 weeks ago Exited (0) 5 days ago rabbitmq3.7.7
d15046dcce27 redis "docker-entrypoint.s…" 2 weeks ago Exited (0) About an hour ago myredis
9682287ec60b 5fac85ee2c68 "docker-entrypoint.s…" 2 weeks ago Exited (0) 2 weeks ago niuzi_mysql
[root@docker html]# docker cp ef0dc2b26ab0:/etc/nginx/nginx.conf /home/nginx/conf/
# nginx的id
# docker cp ef0dc2b26ab0:/etc/nginx/nginx.conf /home/nginx/conf/
2.挂载命令
# docker run --rm -d -p 80:80 --name nginx-test-web \
-v /home/nginx/html:/usr/share/nginx/html \
-v /home/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /home/nginx/logs:/var/log/nginx \
--privileged=true \
nginx
命令说明:
–rm:容器终止运行后,自动删除容器文件。
-p 8081:80: 将容器的 80 端口映射到主机的 8082 端口.
–name nginx-test-web:将容器命名为 nginx-test-web
-v /home/nginx/www:/usr/share/nginx/html:将我们自己创建的 www 目录挂载到容器的 /usr/share/nginx/html。
-v /home/nginx/conf/nginx.conf:/etc/nginx/nginx.conf:将我们自己创建的 nginx.conf 挂载到容器的 /etc/nginx/nginx.conf。
-v /home/nginx/logs:/var/log/nginx:将我们自己创建的 logs 挂载到容器的 /var/log/nginx。
nginx的基本配置需要注意的有以下几点:
1、几个常见配置项:
2、惊群现象:一个网路连接到来,多个睡眠的进程被同时叫醒,但只有一个进程能获得链接,这样会影响系统性能。
3、每个指令必须有分号结束。
3.编写代码
完成命令后 进入 /home/nginx/html目录
vi index.html
#编辑模式
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Nginx test !!!</title>
</head>
<body>
<h1>还怕大雨吗-</h1>
<p></p>
<a href='https://blog.csdn.net/qsy190557020'> 博客入口 </a>
</body>
</html>
4.访问
在浏览器里面输入http://ip:80/,输出结果如下,如果在访问时出现403错误,加权登录
# 进入容器
docker exec -it nginx /bin/bash
# 检查配置文件
nginx -t
# 重新载入配置文件
nginx -s reload
# 重启 Nginx
nginx -s reopen
# 停止 Nginx
nginx -s stop
首先需要进入 /usr/local/nginx/sbin
1.查看nginx版本号
./nginx-v
2.启动nginx
./nginx
3.关闭nginx
./nginx -s stop
4.重新加载nginx
./nginx -s reload
1.实现效果
(1).打开浏览器,在浏览器输入地址 www.123.com,跳转到linux的tomcat主页面中
2.安装并启动tomcat
(1)安装tomcat。运行,端口号8080
(2)tar -zxvf tomcat压缩包
(3)进入bin启动。./startup.sh
(4) 查看日志 cd logs/ tail -f catalina.out
(5)通过windows浏览器访问tomcat查看是否能访问
3.配置host的文件进行配置
(1) C:\Windows\System32\drivers\etc 的host文件配置
虚拟机ip www.aaa.com
(2) 配置反向代理
server{
listen 80;
charset utf-8;
server_name 虚拟机ip;
location / {
proxy_pass http://虚拟机ip:8080;
proxy_redirect default;
}
}
docker配置需要重新挂载
可直接通过虚拟机ip访问到tomcat
location正则匹配**
location [ 空格 | = | ~ | ~* |^|! | !~* ] /uri/ {}
= 开头:表示精确匹配
^~ 开头:注意这不是一个正则表达式,它的目的是优于正则表达式的匹配;如果该 location 是最佳匹配,则不再进行正则表达式检测。
~ 开头:表示区分大小写的正则匹配;
~* 开头:表示不区分大小写的正则匹配
!~ && !~*:表示区分大小写不匹配的正则和不区分大小写的不匹配的正则
准备2个服务,以tomcat为例
在nginx配置文件中进行负载均衡配置
vi nginx.conf
upstream myserver {
server ip:端口;
server ip:端口;
}
server {
server_name ip;
listen 80;
location / {
proxy_pass 路径/myserver
}
}
客户端发送请求反向代理服务器,服务器访问服务端,请求通过nginx平均分配给多个服务端,
负载均衡方式
1.轮询(默认)
2.权重/加权(weighted)
3.随机(random)
4.哈希(hash)
5.一致性哈希(consistenthash)
为了加快网站的解析速度,我们可以把动态页面和静态页面交给不同的服务器来解析,来加快解析速度,提高请求的访问效率,降低原来单个服务器的压力
Nginx 动静分离简单来说就是把动态跟静态请求分开,不能理解成只是单纯的把动态页面和
静态页面物理分离。严格意义上说应该是动态请求跟静态请求分开,可以理解成使用 Nginx
处理静态页面,Tomcat 处理动态页面。动静分离从目前实现角度来讲大致分为两种,
一种是纯粹把静态文件独立成单独的域名,放在独立的服务器上,也是目前主流推崇的方案;
另外一种方法就是动态跟静态文件混合在一起发布,通过 nginx 来分开
配置如下
server {
listen 端口;
server_name localhost;
#拦截后台请求
location / {
proxy_pass http://localhost:8888;
proxy_set_header X-Real-IP $remote_addr;
}
#拦截静态资源
location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|js|css)$ {
root /Users/dalaoyang/Downloads/static;
}
}
重点是添加 location,
最后检查 Nginx 配置是否正确即可,然后测试动静分离是否成功,之需要删除后端 tomcat
服务器上的某个静态文件,查看是否能访问,如果可以访问说明静态资源 nginx 直接返回
了,不走后端 tomcat 服务器
配置完成之后重启nginx或重新加载配置
高可用HA(High Availability)是分布式系统架构设计中必须考虑的因素之一,它通常是指,通过设计减少系统不能提供服务的时间。如果一个系统能够一直提供服务,那么这个可用性则是百分之百,但是天有不测风云。所以我们只能尽可能的去减少服务的故障。
在生产环境上很多时候是以Nginx
做反向代理对外提供服务,但是一天Nginx难免遇见故障,如:服务器宕机。当Nginx
宕机那么所有对外提供的接口都将导致无法访问。
虽然我们无法保证服务器百分之百可用,但是也得想办法避免这种悲剧,目前使用较多的是用keepalived
来实现Nginx
的高可用。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BWc95Rjb-1626334140137)(H:\nginx\nginx.assets\1626332113876.png)]
服务器集群虚拟出来一台 虚拟网关vip(不真实存在,自然不存在宕机问题),
此vip由两台机器共同协商生成。当有一台机器宕机时,另一台机器一样能维持vip。这保证了,只要两台机器不同时宕机,vip就存在
详细操作见
作者 》SimpleWu
链接 https://www.cnblogs.com/SimpleWu/p/11004902.html
完结
转载请注明作者 https://blog.csdn.net/qsy190557020
百分之百可用,但是也得想办法避免这种悲剧,目前使用较多的是用keepalived
来实现Nginx
的高可用。
服务器集群虚拟出来一台 虚拟网关vip(不真实存在,自然不存在宕机问题),
此vip由两台机器共同协商生成。当有一台机器宕机时,另一台机器一样能维持vip。这保证了,只要两台机器不同时宕机,vip就存在
详细操作见
作者 》SimpleWu
链接 https://www.cnblogs.com/SimpleWu/p/11004902.html
完结
转载请注明作者 https://blog.csdn.net/qsy190557020
联系作者: 190557020