day 44 集群架构-web服务软件

day 44 集群架构-web服务软件

Nignx是目前最流行的静态web服务软件

1、功能介绍:

Nginx (“engine x”) 是一个开源的、支持高性能、高并发的WWW服务和代理服务软件。

它是由俄罗斯人IgorSysoev开发的,最初被应用在俄罗斯的大型网站www.rambler.ru上。

后来作者将源代码以类BSD许可证的形式开源出来供全球使用。

2、3大主要功能:

1)网页服务:web服务

apache,lighttpd,IIS

还支持动态web服务

PHP(fastcgi_pass)

JAVA(proxy_pass)          重点

Python(uwsgi_pass)

=============================

memcache(memcache_pass)

...

2)负载均衡\反向代理

haproxy,lvs,F5,netscaler

只支持http,现在tcp/udp

3)缓存服务器

squid,varnish

3、特点:

2008年冒头,当时Apache老大,Nginx如何超越对手

最大特点:静态小文件高并发,占用资源少。软件本身小

企业面试时需要解答如下Nginx HTTP服务器的特色及优点:

1)支持高并发:能支持几万并发连接(特别是静态小文件业务环境)。

2)资源消耗少:在3万并发连接下,开启10个Nginx线程消耗不到200MB内存。

3)可以做HTTP反向代理及加速缓存,即负载均衡功能,内置对RS节点服务

器健康检查功能,这相当于专业的haproxy软件或lvs的功能。

具备squid等专业缓存软件等的缓存功能。

4、Nginx作为web服务器的主要应用场景:

1)静态web服务器:

使用Nginx运行HTML、JS、CSS、小图片等静态数据(此功能类似lighttpd软件)

2)配合运行动态web服务器:

Nginx结合FastCGI运行PHP等动态程序(例如使用fastcgi_pass方式)

Nginx结合proxy_pass支持Java动态程序(tomcat/resin服务)

Nginx结合uwsgi_pass支持Python

3)反向代理/负载均衡

http负载均衡

4)做web缓存服务器(把文件放入内存里)。

5、反向代理与负载均衡

代理:海外代购,微商:代理:代替别人做事。

正向代理:由内向外。 代替 效率低

代替局域网内PC,请求外部应用服务。

反向代理:由外向内 代替 效率低

代替外部的用户请求内部的应用服务器。

负载均衡:转发、效率高

甩手掌柜。

6、为什么Nginx总体性能比Apache高?

Nginx使用最新的epoll(Linux2.6内核)和kqueue(freebsd)异步网络I/O模型,而Apache则使用的是传统的select模型。目前Linux下能够承受高并发访问的Squid、Memcached软件都采用的是epoll模型。

Apache则使用的是传统的select模型,Nginx使用高并发的epoll模型

select模型:伙伴去宿舍找你,一个一个找。。效率低。

epoll模型: 伙伴去宿舍找你,先问宿管大妈,看看在哪间宿舍,然后直奔具体宿舍。效率高。

7、软件安装:

Linux系统如何安装软件?

1、rpm安装

简单 快。依赖多,解决依赖困难繁琐。

2、yum安装 *****

简单快,自动解决依赖。不能选择软件版本或软件存放路径。

3、编译安装(源码编译)*****

慢 复杂 需要GCC编译器,可以自定义安装(版本、软件路径)

4、将源码制作成rpm,然后放到yum仓库,实现yum自动安装。

一次性慢 复杂,安装快,可以自定义安装(版本、软件路径)

5、二进制安装

制作RPM YUM仓库搭建

https://blog.oldboyedu.com/autodeploy-rpm/

互联网 就用nginx

linux系统安装软件方法:

1)yum install nginx -y(rpm包,自动解决所有依赖软件)

简单,没法定制。

2)rpm -ivh rpm包(自己解决所有依赖软件)

简单,没法定制,没法自动解决所有依赖软件

3)编译安装(c语言)

可以定制,编译过程复杂,时间长。

./configure 配置

make 编译

make install 安装

4)利用源码制作符合企业需求的rpm软件包,放到yum仓库里,最后yum安装。

简单,可以随意定制。

rpm包定制

http://blog.oldboyedu.com/autodeploy-rpm/

yum仓库搭建

http://blog.oldboyedu.com/autodeploy-yum/

8、Nginx安装

两种安装方法:

1)yum安装:

epel源:版本低

nginx官方源:版被高

8.1 配置官方源yum安装 2)编译安装:1.编译讲得多 2.练习编译过程

[root@web ~]# vim /etc/yum.repos.d/nginx.repo

[nginx]

name=nginx repo

baseurl=http://nginx.org/packages/centos/7/$basearch/

gpgcheck=0

enabled=1

[root@web01 ~]# rpm -qa nginx

nginx-1.16.0-1.el7.ngx.x86_64

[root@web01 ~]# systemctl start nginx

[root@web01 ~]# systemctl enable nginx

[root@web01 ~]# systemctl status nginx

[root@web01 ~]# netstat -lntup|grep nginx

tcp        0      0 0.0.0.0:80      0.0.0.0:*  LISTEN  8509/nginx: master

8.2 编译安装(和8.1二选一)

pcre:URL重写软件,即实现伪静态需要这个软件

下载:

mkdir -p /server/tools

cd /server/tools

wget http://nginx.org/download/nginx-1.16.0.tar.gz

#安装依赖。

yum install pcre pcre-devel -y

yum install openssl openssl-devel -y  #https加密用他。

#编译安装步骤

tar xf nginx-1.16.0.tar.gz

cd nginx-1.16.0/

useradd -s /sbin/nologin www -M

id www

./configure  --user=www --group=www --prefix=/application/nginx-1.16.0/ --with-http_stub_status_module  --with-http_ssl_module --with-pcre

make

make install

ln -s /application/nginx-1.16.0/ /application/nginx

/application/nginx/sbin/nginx

netstat -lntup|grep nginx

注意:

1)每一步结尾直接echo $?验证是否正确。返回0代表步骤正确

2)验证最终的安装是否正确。

wget 10.0.0.8

curl 10.0.0.8

#configure参数的作用

--prefix=PATH  路径

--user=USER    用户

--group=GROUP  组

--with-pcre    伪静态

--with-http_stub_status_module 状态

--with-http_ssl_module      加密 443

编译安装配置:

[root@web02 /application/nginx]# tree

.

├── conf

│   ├── fastcgi.conf        #和动态服务的接口配置参数,配合php

│   ├── fastcgi.conf.default

│   ├── fastcgi_params

│   ├── fastcgi_params.default

│   ├── koi-utf

│   ├── koi-win

│   ├── mime.types            #媒体类型

│   ├── mime.types.default

│   ├── nginx.conf            #主配置文件

│   ├── nginx.conf.default

│   ├── scgi_params

│   ├── scgi_params.default  #和动态服务的接口配置参数

│   ├── uwsgi_params

│   ├── uwsgi_params.default  #和动态服务的接口配置参数,配合Python

│   └── win-utf

├── fastcgi_temp

├── html            #默认站点目录。 

│   ├── 50x.html

│   └── index.html  #默认的首页,10.0.0.8不指定文件,默认加载index.html首页。

├── logs

│   ├── access.log  #访问日志

│   ├── error.log  #Nginx错误日志。

│   └── nginx.pid  #进程号对应文件。

├── sbin

│   └── nginx      #启动命令。

yum安装配置路径:

[root@web01 ~]# rpm -ql nginx

/etc/logrotate.d/nginx

/etc/nginx         

/etc/nginx/conf.d

/etc/nginx/conf.d/default.conf

/etc/nginx/fastcgi_params

/etc/nginx/koi-utf

/etc/nginx/koi-win

/etc/nginx/mime.types

/etc/nginx/modules

/etc/nginx/nginx.conf

/etc/nginx/scgi_params

/etc/nginx/uwsgi_params

/etc/nginx/win-utf

/usr/sbin/nginx

/usr/sbin/nginx-debug

/usr/share/nginx/html

/usr/share/nginx/html/50x.html

/usr/share/nginx/html/index.html

/var/cache/nginx

/var/log/nginx

你可能感兴趣的:(day 44 集群架构-web服务软件)